ConvertAPI Ruby Client

Gem Build Status License: MIT

Convert your files with our online file conversion API

ConvertAPI helps in converting various file formats. Creating PDF and Images from various sources like Word, Excel, Powerpoint, images, web pages or raw HTML codes. Merge, Encrypt, Split, Repair and Decrypt PDF files and many other file manipulations. You can integrate it into your application in just a few minutes and use it easily.

Installation

Add this line to your application's Gemfile:

gem 'convert_api'

Usage

Configuration

You can get your secret at https://www.convertapi.com/a/auth

ConvertApi.configure do |config|
  config.api_secret = 'your-api-secret'
end

Or

You can get your token at https://www.convertapi.com/a/access-tokens

ConvertApi.configure do |config|
  config.token = 'your-token'
end

File conversion

Example to convert file to PDF. All supported formats and options can be found here.

result = ConvertApi.convert('pdf', { File: '/path/to/my_file.docx' })

# save to file
result.file.save('/path/to/save/file.pdf')

Other result operations:

# save all result files to folder
result.save_files('/path/to/save/files')

# get result file io
io = result.file.io

# get conversion cost
conversion_cost = result.conversion_cost 

Convert file url

result = ConvertApi.convert('pdf', { File: 'https://website/my_file.docx' })

Specifying from format

result = ConvertApi.convert(
  'pdf', 
  {File: /path/to/my_file'}, 
  from_format: 'docx'
)

Additional conversion parameters

ConvertAPI accepts extra conversion parameters depending on converted formats. All conversion parameters and explanations can be found here.

result = ConvertApi.convert(
  'pdf', 
  {File: /path/to/my_file.docx',
  PageRange: '1-10',
  PdfResolution: '150'}
)

Accessing result file properties

You can access result file collection like this:

result = ConvertApi.convert('pdf', { File: 'https://website/my_file.docx' })

puts result.files[0].url
puts result.files[0].size

User information

You can always check your remaining seconds programmatically by fetching user information.

user_info = ConvertApi.user

puts user_info['ConversionsConsumed']

Alternative domain

Set config base_uri attribute to use other service domains. Dedicated to the region domain list.

ConvertApi.configure do |config|
  config.base_uri = URI('https://eu-v2.convertapi.com/')
end

More examples

Find more advanced examples in the examples/ folder.

Development

Run CONVERT_API_SECRET=your_secret rake spec to run the tests.

Or

Run CONVERT_API_TOKEN=your_token rake spec to run the tests.

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 tags, and push the .gem file to rubygems.org.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/ConvertAPI/convertapi-ruby. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

The gem is available as open source under the terms of the MIT License.