Skip to main content

A certificate generator, from a SVG to a lot of PDFs

Project description

A certificate generator, from a SVG to a lot of PDFs

How to use it as a lib

Install certg from PyPI and then…

>>> import certg
>>> certg.process(
    svg_source,
    result_prefix,
    result_distinct,
    replace_info,
    progress_cb=None,
    pdf_optimized=False)

… where all mandatory parameters have the same meaning that if you have them in the YAML config (see below), and progress_cb is a callback to be called after processing each item (useful to report progress).

Some usage examples

Get the code, and run:

bin/certg examples/certificate.yaml

The example_certificate.yaml is included in the project, with the other file it uses: example_certificate.svg.

After successful execution, you will get three .pdf files, the result of the generation.

Here’s other example that inserts different images in the outputs:

bin/certg examples/carnet.yaml

Finally, if you want to check a code that uses certg programatically, replacing several fields and multiple images in the SVG, see this real life code.

What do you need to have installed

The Python’s module yaml and Inkscape in your system. If you want to optimize the resulting PDF, also need Ghostscript installed (gs).

How to really use it, for your specific needs

You need to create two files: the configuration, and the source SVG. Here’s a deep explanation of how it all works, but remember you can get the examples provided and start tweaking them :)

The source SVG is the SVG you want to transform into PDFs, but with some indications for text to be replaced in. These indications are between curly brackets. For example, you may have:

Thanks {{name}} for all your {{type_of_doing}}!

Then, in the configuration file you have a replace_info variable: it’s a list of dictionaries. Each dictionary will produce a generated PDF with the info replaced, and the keys/values in that dictionary will be the info to replace.

Note that you need to provide in the config all the attributes to replace; for example:

name: Foo Bar
type_of_doing: support

Furthermore, in the config you have some mandatory variables you need to fill. Those are:

  • svg_source: the filename of the SVG you created

  • result_prefix: the prefix of the PDFs’ filenames that will be generated

  • result_distinct: the name of the variable in the replacing attributes used as a distinct string for the PDFs.

For example, if you put certs as the prefix and name as the distinct value, you’ll get as output a file named certs-foobar.pdf.

There are some optional variables for different configurations, currently:

  • pdf_optimized: it will run Ghoscript (gs, which you need to have installed in the system) to optimize the resulting PDF.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

certg-4.1.tar.gz (4.6 kB view details)

Uploaded Source

File details

Details for the file certg-4.1.tar.gz.

File metadata

  • Download URL: certg-4.1.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.7

File hashes

Hashes for certg-4.1.tar.gz
Algorithm Hash digest
SHA256 9bcd1344fb8701fa43c499deb3bc394b6d3687e8a5566ca3e0ab5981c125f4a0
MD5 244bec877ce8ffb26b5bb21282a17490
BLAKE2b-256 892e24d61524b9862d8e5ccee6667fcdb6d280fa14a631ad0ff71431f0146ee2

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page