Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
groverのコードを なんとなく読んでみた Ryo Ichiki
Slide 2
Slide 2 text
自己紹介 3社目:HRテック系ベンチャー(現在) Ruby, TypeScript 2社目:不動産テック系ベンチャー Ruby, PHP, JavaScript 1社目:小さい受託開発会社 C# 大学:理学部(情報系ではない) C, R, Ruby GitHub:ryichk X:@ryichk_dev
Slide 3
Slide 3 text
groverとは? HTMLをPDFやPNG画像、JPEG画像に変換できるgemです。 内部でPuppeteerとChromiumを使って変換しています。 PuppeteerはChromeを操作するNode.jsのライブラリです。 なのでgroverを使うためにはNode.jsの環境も必要です。 https://github.com/Studiosity/grover
Slide 4
Slide 4 text
groverを知ったきっかけ HTMLをPDFに変換するメジャーなgemとしてwicked_pdfがあります。 このwicked_pdfを別のgemにリプレイスする必要がありました。 wicked_pdfは内部でwkhtmltopdfというライブラリ(gemではない)を使っています。 wkhtmltopdfは2023/1/2にアーカイブされておりメンテが終了している状態です。 EC2のOSをAmazon Linux 2023へアップグレードした際に動かなくなるリスクがあり、仮 に動いたとしても...
Slide 5
Slide 5 text
groverの他にも候補がありました ・ferrum ・prawn
Slide 6
Slide 6 text
Groverの使い方 https://github.com/Studiosity/grover?tab=readme-ov-file#usage
Slide 7
Slide 7 text
Railsで使う場合 https://github.com/Studiosity/grover?tab=readme-ov-file#from-a-view-template
Slide 8
Slide 8 text
Grover#to_pdf を見ていく
Slide 9
Slide 9 text
Grover#to_pdf 〜
Slide 10
Slide 10 text
Grover::Processor#convert
Slide 11
Slide 11 text
Grover::Processor#convert
Slide 12
Slide 12 text
Grover::Processor#spawn_process
Slide 13
Slide 13 text
Open3.#popen3について popen3(*cmd) -> [IO, IO, IO, Thread] 外部プログラムcmdを実行し、そのプロセスの標準入力、標準出力、標準エラー出力に 接続されたパイプと実行したプロセスを待つためのスレッドを4要素の配列で返す。 https://docs.ruby-lang.org/ja/latest/method/Open3/m/popen3.html
Slide 14
Slide 14 text
Open3.#popen3 を使って別プロセスを立ち上げ、 Node.js 経由で processor.cjs を実行している
Slide 15
Slide 15 text
Grover::Processor#convert
Slide 16
Slide 16 text
Grover::Processor#ensure_packages_are_initiated
Slide 17
Slide 17 text
Grover::Processor#ensure_packages_are_initiated 要はNode.jsのプロセスが問題なく起 動しているか確認している
Slide 18
Slide 18 text
Grover::Processor#convert
Slide 19
Slide 19 text
Grover::Processor#call_js_method
Slide 20
Slide 20 text
Grover::Processor#call_js_method
Slide 21
Slide 21 text
Grover::Processor#call_js_method つまり、 processor.cjsに method, url_or_html, options を渡している method = :pdf
Slide 22
Slide 22 text
processor.cjs(超ざっくり) 1. puppeteerでChromeブラウザを起動し、接続する 2. 引数で渡されたURL or HTML文字列をブラウザで読み込む 3. puppeteerのPage.pdf()メソッドを実行 a. 読み込んだページの PDFを生成する 4. 生成されたPDFを標準出力に書き出す 5. Chromeブラウザの接続を閉じて終了
Slide 23
Slide 23 text
まとめ・感想 ・groverはpuppeteerというNode.jsのライブラリを Ruby経由で無理やり操作するためのgemという感じ ・やっていることはシンプル。 ・だけど細かく見ていくと複雑 ・Ruby経由でNode.jsのライブラリを実行できるなら他にも色々できそう (Node.jsに限らず)
Slide 24
Slide 24 text
ご清聴ありがとうございました