# [Colony Print Infra-structure](http://colony-print.hive.pt)
Small web app for printing Colony-based documents.
This project includes two main components:
* The Web App end-point that provides XML to Binie conversion `colony_print.controllers`
* The structure conversion infra-structure (Visitors, AST, etc.) `colony_print.printing`
## Features
* Cloud printing, with minimal configuration
* Multiple engine support (npcolony, gravo, text)
* XMPL to Binie conversion
* PDF generation with custom fonts and images
* [GDI](https://en.wikipedia.org/wiki/Graphics_Device_Interface) printing (Windows) via [Colony NPAPI (npcolony)](https://github.com/hivesolutions/colony-npapi)
* [CUPS](https://en.wikipedia.org/wiki/CUPS) printing (Linux) via [Colony NPAPI (npcolony)](https://github.com/hivesolutions/colony-npapi)
## Binie Specification
For a detailed understanding of the Binie file format used in this project, refer to the [Binie File Format Specification](doc/binie.md). This document outlines the structure and organization of the Binie file format, which is essential for developing compatible applications and tools.
## XMPL Specification
The XML Markup Language for Printing (XMPL) is integral to our document processing pipeline. For an in-depth understanding of the XMPL structure and its seamless convertibility to Binie, see the [XMPL File Format Specification](doc/xmpl.md).
## Installation
### Pre-requisites
```bash
apt-get install gcc python-dev
pip install --upgrade appier netius pillow reportlab
```
### Run Server
```bash
pip install colony_print
python -m colony_print.main
```
### Run Node
```bash
pip install colony_print
BASE_URL=$BASE_URL \
SECRET_KEY=$SECRET_KEY \
NODE_ID=$NODE_ID \
NODE_NAME=$NODE_NAME \
NODE_LOCATION=$NODE_LOCATION \
python -m colony_print.node
```
### Fonts
To be able to use new fonts (other than the ones provided by the system), one must install them
into the `/usr/share/fonts/truetype` directory so they are exposed and ready to
be used by the PDF generation infra-structure. For example, Calibri is one type of font that should
be exported to a UNIX machine as many colony-generated documents use it.
### Engines
There are currently three engines available for printing in Colony Print:
* `npcolony` - The [Colony NPAPI](https://github.com/hivesolutions/colony-npapi) engine, which is used for GDI printing on Windows and CUPS printing on Linux.
* `gravo` - Which allows engraving of text and signatures using [Gravo Pilot](https://github.com/hivesolutions/gravo-pilot).
* `text` - A simple virtual printer text engine that prints text to a simple plain text file and returns the file.
## Development
To run a localhost development server, use the following commands:
```bash
PORT=8686 \
PYTHONPATH=$BASE_PATH/colony_print/src python \
$BASE_PATH/colony_print/src/colony_print/main.py
```
## License
Colony Print Infra-structure is currently licensed under the [Apache License, Version 2.0](http://www.apache.org/licenses/).
## Build Automation
[![Build Status](https://github.com/hivesolutions/colony-print/workflows/Main%20Workflow/badge.svg)](https://github.com/hivesolutions/colony-print/actions)
[![Coverage Status](https://coveralls.io/repos/hivesolutions/colony-print/badge.svg?branch=master)](https://coveralls.io/r/hivesolutions/colony-print?branch=master)
[![PyPi Status](https://img.shields.io/pypi/v/colony-print.svg)](https://pypi.python.org/pypi/colony-print)
[![License](https://img.shields.io/badge/license-Apache%202.0-blue.svg)](https://www.apache.org/licenses/)
Raw data
{
"_id": null,
"home_page": "http://colony-print.hive.pt",
"name": "colony-print",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "colony print native",
"author": "Hive Solutions Lda.",
"author_email": "development@hive.pt",
"download_url": "https://files.pythonhosted.org/packages/ab/63/b0357ffff03118a67c8441d4e1335c6dbfcc7fd2a6a3556a7cfc2350c7ed/colony-print-0.4.6.tar.gz",
"platform": null,
"description": "# [Colony Print Infra-structure](http://colony-print.hive.pt)\n\nSmall web app for printing Colony-based documents.\n\nThis project includes two main components:\n\n* The Web App end-point that provides XML to Binie conversion `colony_print.controllers`\n* The structure conversion infra-structure (Visitors, AST, etc.) `colony_print.printing`\n\n## Features\n\n* Cloud printing, with minimal configuration\n* Multiple engine support (npcolony, gravo, text)\n* XMPL to Binie conversion\n* PDF generation with custom fonts and images\n* [GDI](https://en.wikipedia.org/wiki/Graphics_Device_Interface) printing (Windows) via [Colony NPAPI (npcolony)](https://github.com/hivesolutions/colony-npapi)\n* [CUPS](https://en.wikipedia.org/wiki/CUPS) printing (Linux) via [Colony NPAPI (npcolony)](https://github.com/hivesolutions/colony-npapi)\n\n## Binie Specification\n\nFor a detailed understanding of the Binie file format used in this project, refer to the [Binie File Format Specification](doc/binie.md). This document outlines the structure and organization of the Binie file format, which is essential for developing compatible applications and tools.\n\n## XMPL Specification\n\nThe XML Markup Language for Printing (XMPL) is integral to our document processing pipeline. For an in-depth understanding of the XMPL structure and its seamless convertibility to Binie, see the [XMPL File Format Specification](doc/xmpl.md).\n\n## Installation\n\n### Pre-requisites\n\n```bash\napt-get install gcc python-dev\npip install --upgrade appier netius pillow reportlab\n```\n\n### Run Server\n\n```bash\npip install colony_print\npython -m colony_print.main\n```\n\n### Run Node\n\n```bash\npip install colony_print\nBASE_URL=$BASE_URL \\\nSECRET_KEY=$SECRET_KEY \\\nNODE_ID=$NODE_ID \\\nNODE_NAME=$NODE_NAME \\\nNODE_LOCATION=$NODE_LOCATION \\\npython -m colony_print.node\n```\n\n### Fonts\n\nTo be able to use new fonts (other than the ones provided by the system), one must install them\ninto the `/usr/share/fonts/truetype` directory so they are exposed and ready to\nbe used by the PDF generation infra-structure. For example, Calibri is one type of font that should\nbe exported to a UNIX machine as many colony-generated documents use it.\n\n### Engines\n\nThere are currently three engines available for printing in Colony Print:\n\n* `npcolony` - The [Colony NPAPI](https://github.com/hivesolutions/colony-npapi) engine, which is used for GDI printing on Windows and CUPS printing on Linux.\n* `gravo` - Which allows engraving of text and signatures using [Gravo Pilot](https://github.com/hivesolutions/gravo-pilot).\n* `text` - A simple virtual printer text engine that prints text to a simple plain text file and returns the file.\n\n## Development\n\nTo run a localhost development server, use the following commands:\n\n```bash\nPORT=8686 \\\nPYTHONPATH=$BASE_PATH/colony_print/src python \\\n$BASE_PATH/colony_print/src/colony_print/main.py\n```\n\n## License\n\nColony Print Infra-structure is currently licensed under the [Apache License, Version 2.0](http://www.apache.org/licenses/).\n\n## Build Automation\n\n[![Build Status](https://github.com/hivesolutions/colony-print/workflows/Main%20Workflow/badge.svg)](https://github.com/hivesolutions/colony-print/actions)\n[![Coverage Status](https://coveralls.io/repos/hivesolutions/colony-print/badge.svg?branch=master)](https://coveralls.io/r/hivesolutions/colony-print?branch=master)\n[![PyPi Status](https://img.shields.io/pypi/v/colony-print.svg)](https://pypi.python.org/pypi/colony-print)\n[![License](https://img.shields.io/badge/license-Apache%202.0-blue.svg)](https://www.apache.org/licenses/)\n\n\n",
"bugtrack_url": null,
"license": "Apache License, Version 2.0",
"summary": "Colony Print Infra-structure",
"version": "0.4.6",
"project_urls": {
"Homepage": "http://colony-print.hive.pt"
},
"split_keywords": [
"colony",
"print",
"native"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "ae40dce61c2c28dcf598280f093defb019a80cd6c4025a10561720fcfb58c383",
"md5": "068ba1525fd90a5417d7a05e12b9598d",
"sha256": "26e34a2fd588bdac3d9f76f430eda836a50f67dc6ed4480f1943aded09801c69"
},
"downloads": -1,
"filename": "colony_print-0.4.6-py2.py3-none-any.whl",
"has_sig": false,
"md5_digest": "068ba1525fd90a5417d7a05e12b9598d",
"packagetype": "bdist_wheel",
"python_version": "py2.py3",
"requires_python": null,
"size": 55515,
"upload_time": "2025-01-19T01:56:45",
"upload_time_iso_8601": "2025-01-19T01:56:45.233440Z",
"url": "https://files.pythonhosted.org/packages/ae/40/dce61c2c28dcf598280f093defb019a80cd6c4025a10561720fcfb58c383/colony_print-0.4.6-py2.py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "ab63b0357ffff03118a67c8441d4e1335c6dbfcc7fd2a6a3556a7cfc2350c7ed",
"md5": "6d4567827e9121108aab911887c50193",
"sha256": "4d5403465541513d67ff29c7dbceed408c9c5ade29f9284ba19f32822a1ae207"
},
"downloads": -1,
"filename": "colony-print-0.4.6.tar.gz",
"has_sig": false,
"md5_digest": "6d4567827e9121108aab911887c50193",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 46740,
"upload_time": "2025-01-19T01:56:46",
"upload_time_iso_8601": "2025-01-19T01:56:46.963484Z",
"url": "https://files.pythonhosted.org/packages/ab/63/b0357ffff03118a67c8441d4e1335c6dbfcc7fd2a6a3556a7cfc2350c7ed/colony-print-0.4.6.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-19 01:56:46",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "colony-print"
}