Orshot Node.js API SDK
View on Rubygems: rubygems.org/gems/orshot
Installation
Add this line to your application's Gemfile:
gem 'orshot'And then execute:
$ bundle
Or install it yourself as:
$ gem install orshot
Usage
If you don't have your API key, get one from orshot.com.
Initialise a client
require 'orshot'
client = Orshot::Client.new('os-ha2jdus1cbz1dpt4mktgjyvx')Generate image
response = client.render_from_template({'template_id' => 'open-graph-image-1', 'modifications' => {'title': 'From ruby sdk new'}, 'response_type' => 'base64', 'response_format' => 'png'})
puts response['data']Generate signed URL
response = client.generate_signed_url({'template_id' => 'open-graph-image-1', 'modifications' => {'title': 'From ruby sdk new'}, 'render_type' => 'images', 'response_format' => 'png', 'expires_at': 1744276943})
puts response['data']Example
Base64 response format
require 'orshot'
client = Orshot::Client.new('os-ha2jdus1cbz1dpt4mktgjyvx')
response = client.render_from_template({'template_id' => 'open-graph-image-1', 'modifications' => {'title': 'From ruby sdk new'}, 'response_type' => 'base64', 'response_format' => 'png'})
puts response['data']Output
{"content"=>"...", "format"=>"png", "type"=>"base64", "responseTime"=>3357.47}
Binary response format
require 'orshot'
client = Orshot::Client.new('os-ha2jdus1cbz1dpt4mktgjyvx')
File.open("og.png", "w") do |file|
  response = client.render_from_template({'template_id' => 'open-graph-image-1', 'modifications' => {'title': 'From ruby sdk new'}, 'response_type' => 'binary', 'response_format' => 'png'})
  file.binmode
  file.write(response)
endData is written to the file og.png
URL response format
require 'orshot'
client = Orshot::Client.new('os-ha2jdus1cbz1dpt4mktgjyvx')
response = client.render_from_template({'template_id' => 'open-graph-image-1', 'modifications' => {'title': 'From ruby sdk new'}, 'response_type' => 'url', 'response_format' => 'png'})
puts response['data']Output
{"content"=>"https://storage.orshot.com/00632982-fd46-44ff-9a61-f52cdf1b8e62/images/nNSTZlMHFkr.png", "type"=>"url", "format"=>"png", "responseTime"=>3950.87}
Signed URL
require 'orshot'
client = Orshot::Client.new('os-ha2jdus1cbz1dpt4mktgjyvx')
response = client.generate_signed_url({'template_id' => 'open-graph-image-1', 'modifications' => {'title': 'From ruby sdk new'}, 'render_type' => 'images', 'response_format' => 'png', 'expires_at' => 1744276943})
puts response['data']Output
{"url"=>"https://api.orshot.com/v1/generate/images?expiresAt=1744276943&id=37&templateId=open-graph-image-1&title=From%20ruby%20sdk%20new&signature=1225f4b65dd19ce6ac6f03c5fq6e42cfb7e254fac26492b35d58e2e2d65c7021"}
render_from_template
Use this function to render an image/pdf. This method accepts a hash with the following keys
| key | required | description | 
|---|---|---|
| template_id | Yes | ID of the template ( open-graph-image-1,tweet-image-1,beautify-screenshot-1, ...) | 
| modifications | Yes | Modifications for the selected template. | 
| response_type | No | base64,binary,url(Defaults tobase64). | 
| response_format | No | png,webp,pdf,jpg,jpeg(Defaults topng). | 
For available templates and their modifications refer Orshot Templates Page
generate_signed_url
Use this function to generate signed URL. This method accepts a hash with the following keys
| key | required | description | 
|---|---|---|
| template_id | Yes | ID of the template ( open-graph-image-1,tweet-image-1,beautify-screenshot-1, ...) | 
| modifications | Yes | Modifications for the selected template. | 
| expires_at | Yes | Expires at in unix timestamp (Number). | 
| render_type | No | images,pdfs(Defaults toimages). | 
| response_format | No | png,webp,pdf,jpg,jpeg(Defaults topng). | 
Development
Run bundle install
After checking out the repo, run bin/setup to install dependencies. You can also run bin/console for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and the created tag, and push the .gem file to rubygems.org.
Code of Conduct
Everyone interacting in the Orshot project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.