Inkantan is a simple and lite Flask web app that allows users to upload PDFs and get them digitally signed with a custom-generated hanko (はんこ: seal) aesthetic element.
The name is a silly portmanteau of the Japanese words "inkan" (印鑑) which refers to the mark or impression made by affixing a seal, and the word "kantan" (簡単) meaning simple. Therefore, simple sealing.
The user only needs to fill out a short form, and upload the file before being prompted to drag and select the area on the signature page where the seal needs to be applied. Neither the document nor any of the personal information provided will be stored on the server, and the result PDF is instantly generated.
The resultant PDF document should contain the visual seal element on the page and embedded digital signature data that can be inspected by using software like Adobe® Reader, which ensures document integrity, validity and tamper-detectability.
"Mitome-in" (認印) is one of the three common types of seal that normally tends to be unregistered, off-the-shelf for ¥200, and is used for acknowledgement, uncomplicated or routine contracts, and low-to-medium-value dealings. They are used both in personal and corporate contexts.
This service creates self-signed root certificates and doesn't rely on CAs because, in line with the above, that would be disproportionate relative to the purpose. That does not mean, however, that such signatures are not capable of being legally recognized or binding (e.g. Article 2(1) of The Act on Electronic Signatures and Certification Business (Act No. 102 of 31 May 2000) in Japan).
Given how important a cultural role the seal plays in Japanese (and broadly East Asian) societies, and given the present need for caution in physical interaction, I thought this solution would offer a modern, progressive, and free-to-use compromise.
I hope this may be slightly better than totally useless, and that someone may gain some value out of it.
Try it live here.
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
The PDF-manipulation python library that the project makes use of (i.e. endesive
) requires the following package to be installed:
apt install swig
#or use the equivalent homebrew command for macOS
It is recommended to install all the dependencies and project files in a virtual environment so first:
python3 -m venv env
source env/bin/activate
Then clone the repository and cd
into the environment and run:
pip3 install -r requirements.txt
Once installation is complete, run the following command to start the Flask server on localhost. By default, it will run on port 8080 and in debug mode.
python3 main.py
- Flask - The web framework used
- Cryptography - For creating digital signatures, keys and certificates
- Endesive - For digitally signing PDFs
- Pillow - For Image data manipulation
- PDF.js - For web PDF rendering and interaction
- BeautifulSoup - For HTML web scraping
- Requests - For HTTP web requests and session management
- Cannot be used for PDFs with existing structural malformations/anomalies
PDFs with existing signatures will have those sigs invalidated due to manipulation of PDF data (a solution is currently being worked on becauseIssue has been resolved.PIL
withendesive
as an alternative is quite temperamental).- Hanko Generator has inconsistent treatment of CJK characters, which may not show up on the final seals (or possibly lead to 500 errors). I suspect this mainly pertains to simplified Chinese characters, but it is a fool's errand to try to validate CJK name input by way of Regex. Use with caution, I guess?
- Izaan Khan - Initial work - Arbitrage0
If something can be improved, it should be; and you should submit a PR for it! The contribution philosophy (for now, at least) is methodological anarchism. Anything goes...
This project is free to be used, remixed, copied, and shared, as it is open source and in the public domain, with none of the creator's © rights reserved, where applicable - see CC0 for details. Attribution would be nice.
- Major Hat tip to HankoGenerator, the web service that creates the signature aesthetics, without which this project would be impossible.