InvoicePrinter comes with a server that can be run from a command line with invoice_printer_server
. Since 2.x releases this server is packaged separately in invoice_printer_server
gem.
Apart from this you can also manually mount the server inside of your Rack application.
Once installed, InvoicePrinter Server provides invoice_printer_server
executable that starts the Puma server:
$ invoice_printer_server -h 0.0.0.0 -p 5000
-h
defines a host and -p
defines a port. For help you can run --help
.
By default server binds to 0.0.0.0:9393
.
Get the public image and run it:
$ sudo docker pull strzibnyj/invoice_printer_server:$VERSION
$ sudo docker run -d -p 9393:9393 -v ~/path/to/invocies:/data:Z -t docker.io/strzibnyj/invoice_printer_server
You can use latest
as a $VERSION
. Specifying the -v
option is only required when using the /print
action to create the documents at certain path. It will allow you to provide the desired filename as "/data/invoice-name.pdf".
The server will then be available on 0.0.0.0:9393
.
Docker image already contains the optional invoice_printer_fonts
gem.
If you want you can always run the server from your custom program or mount it directly from a Rack app.
InvoicePrinter::Server
is a Rack app as any other. Example:
require 'rack/handler/puma'
require 'invoice_printer/server'
Rack::Handler::Puma.run InvoicePrinter::Server.freeze.app
Endpoints accept similar arguments as the corresponding methods to InvoicePrinter
. render
is used for directly getting the PDF output whereas print
would accept filename
option and save the document to that
file.
A content type is always application/json
both for requests and responses.
Directly render PDF data.
Options:
document
- JSON representation of the documentlabels
- JSON for labelsfont
- path to font file or builtin font namebold_font
- path to bold font file or builtin font namestamp
- path to stamp filelogo
- path to logotype filebackground
- path to background filepage_size
- letter or A4 page size
These parameters are the same as for the command line.
On success a 200
response is returned:
{ "result": "ok", "data": "base64 encoded PDF document" }
On error a 400
response is returned:
{ "result": "error", "error": "error description" }
Example of calling the API to render a document using curl
:
$ curl -X POST http://0.0.0.0:9393/render -H "Content-Type: application/json" --data '{"document":{"number":"c. 198900000001","provider_name":"Petr Novy","provider_tax_id":"56565656","provider_tax_id2":"","provider_lines":"Rolnická 1\n747 05 Opava\nKateřinky","purchaser_name":"Adam Cerny","purchaser_tax_id":"","purchaser_tax_id2":"","purchaser_lines":"Ostravská 1\n747 70 Opava","issue_date":"05/03/2016","due_date":"19/03/2016","subtotal":"Kc 10.000","tax":"Kc 2.100","tax2":"","tax3":"","total":"Kc 12.100,-","bank_account_number":"156546546465","account_iban":"IBAN464545645","account_swift":"SWIFT5456","items":[{"name":"Konzultace","quantity":"2","unit":"hod","price":"Kc 500","tax":"","tax2":"","tax3":"","amount":"Kc 1.000"},{"name":"Programovani","quantity":"10","unit":"hod","price":"Kc 900","tax":"","tax2":"","tax3":"","amount":"Kc 9.000"}],"note":"Osoba je zapsána v zivnostenském rejstríku."}}'
See /examples/clients/node.js.
Print resulting document to a file.
Options:
document
- JSON representation of the documentlabels
- JSON for labelsfont
- path to font file or builtin font namebold_font
- path to bold font file or builtin font namestamp
- path to stamp filelogo
- path to logotype filebackground
- path to background filepage_size
- letter or A4 page sizefilename
- path for saving the generated output PDF
On success a 200
response is returned:
{ "result": "ok", "path": "/path/basically/what/was/sent/as/filepath" }
On error a 400
response is returned:
{ "result": "error", "error": "error description" }