Simple Web-based Interface for Scanner
This is a simple web-based interface for scanners. It allows sharing the scanner via IP address, making it accessible by the web browser. The frontend interface allows users to crop the image and browse previously scanned images.
From a technical perspective, it is simply a SANE scanimage wrapper. There are quite many things to do to make it production (see TODO section).
Recently, printing and uploading features have been added. The uploading feature allows to upload documents to the server and then print them. This is useful when you want to print documents from your phone or other devices.
- Scanning to png, jpeg formats with provided DPI and color palette
- Cropping scanned images
- Creating PDF documents
- Browsing scanned documents
- Printing files
- Uploading
- Linux
- SANE (Scanner Access Now Easy) properly configured (
scanimage
tool) - OpenPrinting configured on server (
lp
tool) convert
tool for pdf creation- Python >= 3.8
- [Optionally] NPM (for frontend development purpose)
pip install swis
swis --ip localhost --port 5520
If successfully executed visit the http://localhost:5520 (Note: http
(without s
))
❗IMPORTANT❗ Change the IP (localhost
above) to a proper host IP address if you want to access the scanner from other computers (or other devices).
This process requires root privileges, and you need to have Python>=3.8 installed. If the root user does't have the the pip
installed, you will have to install it by running the below:
- Fedora (and similar):
sudo dnf install python3-pip
- Ubuntu (and similar):
sudo apt-get install python3-pip
sudo pip3 install swis
sudo swis --ip [HOST IP ADDRESS] --port 5520 -u [USER] -g [GROUP] service install
sudo swis service start
You can check the status by running: sudo swis service status
❗IMPORTANT❗ Change the IP ([HOST IP ADDRESS]
above) to a proper host IP address, and [USER]
and [GROUP]
to a proper system user (owner of scanned documents).
To upgrade swis to the new version following steps need to be performed (notice that config needs to be provided):
sudo swis service stop
sudo pip install -U swis
sudo swis --ip [HOST IP ADDRESS] --port 5520 -u [USER] -g [GROUP] service install
sudo swis service start
There is option to integrate SWIS with Cockpit. This feature is under early development.
Project is available at: https://github.com/rsusik/swis-cockpit