Skip to content

Latest commit

 

History

History
70 lines (48 loc) · 2.02 KB

README.md

File metadata and controls

70 lines (48 loc) · 2.02 KB

cherry-api

RuboCop RSpec

Ruby on Rails PDF generator based on headless Chrome


Usage

Copy .env.sample to .env.

Copy config/database.yml.sample to config/database.yml.

docker-compose up -d

To create PDF from HTML

curl --location --request POST 'localhost:3003/html_to_pdf' \
--header 'Content-type: application/json' \
--data-raw '{"content": "<h1> Awesome! </h1>", "scale": 0.5, "landscape": true}'

To create QR-code from TEXT

curl --location --request POST 'localhost:3003/text_to_qr' \
--header 'Content-type: application/json' \
--data-raw '{"content": "https://github.com/faraquet/cherry-api"}'

Authentication

By default authentication disabled.

To enable it please use TOKEN_AUTHENTICATABLE=true in your .env file.

Create a new user:

To enable self-registration via API please make sure that you SELF_REGISTRATION_AVAILABLE is set to true in your .env file.

curl -X POST -H 'Content-type: application/json' -d '{"email": "[email protected]", "password": "testpassword"}' localhost:3003/register

Authenticate a user:

curl -X POST -H 'Content-type: application/json' -d '{"email": "[email protected]", "password": "testpassword"}' localhost:3003/login

On successful login, {"auth_token": <token>, "expires_at": <datetime>} will be returned. By default this token will be expired after 24 hours.

After that you have to add Authorization header to your request:

curl --location --request POST 'localhost:3003/html_to_pdf' \
--header 'Content-type: application/json' \
--header 'Authorization: <token>' \
--data-raw '{"content": "<h1> Awesome! </h1>", "scale": 0.5, "landscape": true}'

Todo

  • Readme
  • More options to pdf-generation
  • Specs