diff --git a/Dockerfile b/Dockerfile index 8d03b21..09264c6 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,49 +1,63 @@ -#FROM ubuntu:16.04 -FROM ubuntu:22.04 +FROM debian:bookworm-slim AS builder -RUN DEBIAN_FRONTEND=noninteractive TZ=Etc/UTC apt-get update && apt-get -y install tzdata && apt-get -y clean +ARG DEBIAN_FRONTEND=noninteractive -RUN apt-get update && apt-get install -y --no-install-recommends apt-utils && apt-get -y clean +RUN apt-get update && apt-get -y --no-install-recommends install \ + wget \ + ca-certificates + +RUN cd /tmp && \ + wget https://download.brother.com/welcome/dlf105200/brscan4-0.4.11-1.amd64.deb + +RUN cd /tmp && \ + wget https://download.brother.com/welcome/dlf006652/brscan-skey-0.3.1-2.amd64.deb + +FROM debian:bookworm-slim -RUN apt-get -y update && apt-get -y upgrade && apt-get -y clean -RUN apt-get -y install \ +ARG DEBIAN_FRONTEND=noninteractive + +RUN apt-get update && apt-get -y --no-install-recommends install \ sane \ sane-utils \ + netbase \ ghostscript \ netpbm \ - x11-common \ - wget \ graphicsmagick \ curl \ ssh \ sshpass \ lighttpd \ php-cgi \ - php-curl \ - sudo \ iproute2 \ + iputils-ping \ && apt-get -y clean +COPY --from=builder /tmp/brscan4-0.4.11-1.amd64.deb /tmp/brscan4-0.4.11-1.amd64.deb RUN cd /tmp && \ - wget https://download.brother.com/welcome/dlf105200/brscan4-0.4.11-1.amd64.deb && \ dpkg -i /tmp/brscan4-0.4.11-1.amd64.deb && \ rm /tmp/brscan4-0.4.11-1.amd64.deb +COPY --from=builder /tmp/brscan-skey-0.3.1-2.amd64.deb /tmp/brscan-skey-0.3.1-2.amd64.deb RUN cd /tmp && \ - wget https://download.brother.com/welcome/dlf006652/brscan-skey-0.3.1-2.amd64.deb && \ dpkg -i /tmp/brscan-skey-0.3.1-2.amd64.deb && \ rm /tmp/brscan-skey-0.3.1-2.amd64.deb -ADD files/runScanner.sh /opt/brother/runScanner.sh -COPY script /opt/brother/scanner/brscan-skey/script +RUN lighty-enable-mod auth || true; \ + lighty-enable-mod fastcgi || true; \ + lighty-enable-mod fastcgi-php || true; \ + lighty-enable-mod access || true + +RUN cat <> /etc/lighttpd/lighttpd.conf +\$HTTP["url"] =~ "^/lib" { + url.access-deny = ("") +} +EOF -RUN cp /etc/lighttpd/conf-available/05-auth.conf /etc/lighttpd/conf-enabled/ -RUN cp /etc/lighttpd/conf-available/15-fastcgi-php.conf /etc/lighttpd/conf-enabled/ -RUN cp /etc/lighttpd/conf-available/10-fastcgi.conf /etc/lighttpd/conf-enabled/ RUN mkdir -p /var/run/lighttpd RUN touch /var/run/lighttpd/php-fastcgi.socket RUN chown -R www-data /var/run/lighttpd -RUN echo 'www-data ALL=(NAS) NOPASSWD:ALL' >> /etc/sudoers + +ENV TZ=Etc/UTC ENV NAME="Scanner" ENV MODEL="MFC-L2700DW" @@ -63,21 +77,16 @@ ENV FTP_HOST="" # Make sure this ends in a slash. ENV FTP_PATH="/scans/" -EXPOSE 54925 -EXPOSE 54921 -EXPOSE 80 -ADD files/gui/index.php /var/www/html -ADD files/gui/main.css /var/www/html -ADD files/api/scan.php /var/www/html -ADD files/api/active.php /var/www/html -ADD files/api/list.php /var/www/html -ADD files/api/download.php /var/www/html +COPY files/gui/ /var/www/html +COPY files/api/ /var/www/html + +COPY files/runScanner.sh /opt/brother/runScanner.sh +COPY script /opt/brother/scanner/brscan-skey/script + RUN chown -R www-data /var/www/ #directory for scans: VOLUME /scans -CMD /opt/brother/runScanner.sh - - +CMD /opt/brother/runScanner.sh \ No newline at end of file diff --git a/README.md b/README.md index 230ddcc..b6c23e0 100644 --- a/README.md +++ b/README.md @@ -86,7 +86,8 @@ You can configure the tool via environment variables: | Variable | Type | Description | | ------------- | ------------- | ------------- | -| NAME | mandatory | Arbitrary name to give your scanner. Displayed on scanner, if multiple servers are running. | +| NAME | mandatory | Arbitrary name to give your scanner. | +| USERNAME | optional | Displayed on scanner, if multiple servers are running. | | MODEL | mandatory | Model of your scanner (e.g., MFC-L2700DW) | | IPADDRESS | mandatory | IP Address of your scanner | | RESOLUTION | optional | DPI resolution of scan, refer to capabilities of printer on startup | @@ -101,17 +102,25 @@ You can configure the tool via environment variables: | OCR_SERVER | optional | Hostname of an OCR server (see below) | | OCR_PORT | optional | Port of an OCR server (see below) | | OCR_PATH | optional | Path of an OCR server (see below) | -| WEBSERVER | optional | activates GUI & API (default:false) (see below) | -| PORT | optional | sets port for webserver (default: 80) | -| DISABLE_GUI_SCANTOFILE | optional | deactivates button "Scan to file" (default: false) | -| DISABLE_GUI_SCANTOEMAIL | optional | deactivates button "Scan to e-mail" | -| DISABLE_GUI_SCANTOIMAGE | optional | deactivates button "Scan to image" | -| DISABLE_GUI_SCANTOOCR | optional | deactivates button "Scan to OCR" | -| RENAME_GUI_SCANTOFILE="Scan front pages" | optional | renames GUI button "Scan to file" to "Scan front pages" | -| RENAME_GUI_SCANTOEMAIL="Scan rear pages" | optional | renames GUI button "Scan to email" to "Scan rear pages" | -| RENAME_GUI_SCANTOIMAGE="Scan photo" | optional | renames GUI button "Scan to image" to "Scan photo" | -| RENAME_GUI_SCANTOOCR="Scan High-Res" | optional | renames GUI button "Scan to OCR" to "Scan High-Res" | +| WEBSERVER_ENABLE | optional | activates GUI & API (default:true) (see below) | +| WEBSERVER_PING_ENABLE | optional | activates ping service to check if scanner offline | +| WEBSERVER_PING_INTERVAL | optional | sets interval how often to ping the scanner | +| WEBSERVER_PORT | optional | sets port for webserver (default: 80) | +| WEBSERVER_LABEL_SCANTOFILE | optional | empty to hide button (default: "Scan to file") | +| WEBSERVER_LABEL_SCANTOEMAIL | optional | empty to hide button (default: "Scan to email") | +| WEBSERVER_LABEL_SCANTOIMAGE | optional | empty to hide button (default: "Scan to image") | +| WEBSERVER_LABEL_SCANTOOCR | optional | empty to hide button (default: "Scan to OCR") | | USE_JPEG_COMPRESSION | optional | use JPEG compression when creating PDFs | +| ~~WEBSERVER~~ | deprecated | replaced by WEBSERVER_ENABLE | +| ~~PORT~~ | deprecated | replaced by WEBSERVER_PORT | +| ~~DISABLE_GUI_SCANTOFILE~~ | deprecated | use WEBSERVER_LABEL_SCANTOFILE instead | +| ~~DISABLE_GUI_SCANTOEMAIL~~ | deprecated | use WEBSERVER_LABEL_SCANTOEMAIL instead | +| ~~DISABLE_GUI_SCANTOIMAGE~~ | deprecated | use WEBSERVER_LABEL_SCANTOIMAGE instead | +| ~~DISABLE_GUI_SCANTOOCR~~ | deprecated | use WEBSERVER_LABEL_SCANTOOCR instead | +| ~~RENAME_GUI_SCANTOFILE="Scan front pages"~~ | deprecated | use WEBSERVER_LABEL_SCANTOFILE instead | +| ~~RENAME_GUI_SCANTOEMAIL="Scan rear pages"~~ | deprecated | use WEBSERVER_LABEL_SCANTOEMAIL instead | +| ~~RENAME_GUI_SCANTOIMAGE="Scan photo"~~ | deprecated | use WEBSERVER_LABEL_SCANTOIMAGE instead | +| ~~RENAME_GUI_SCANTOOCR="Scan High-Res"~~ | deprecated | use WEBSERVER_LABEL_SCANTOOCR instead | ### FTPS upload In addition to the storage in the mounted volume, you can use FTPS (Secure FTP) Upload. @@ -161,12 +170,13 @@ By default, the image uses port 80, but you may configure that. Additionally, for the GUI, you can rename and hide individual functions. here is an example of the environment: ``` -- WEBSERVER=true # optional, activates GUI & API -- PORT=33355 # optional, sets port for webserver (default: 80) -- DISABLE_GUI_SCANTOIMAGE=true # optional, deactivates button "Scan to image" -- DISABLE_GUI_SCANTOOCR=true # optional, deactivates button "Scan to OCR" -- RENAME_GUI_SCANTOFILE="Scan front pages" # optional, renames button "Scan to file" to "Scan front pages" -- RENAME_GUI_SCANTOEMAIL="Scan rear pages" # optional, renames button "Scan to email" to "Scan rear pages" +- WEBSERVER_ENABLE= # optional, activates GUI & API +- WEBSERVER_PING_ENABLE= # optional, if enabled scanner status is `online`, `offline`, `scanning` (see status.php) +- WEBSERVER_PORT=33355 # optional, sets port for webserver (default: 80) +- WEBSERVER_LABEL_SCANTOIMAGE= # optional, hides button "Scan to image" +- WEBSERVER_LABEL_SCANTOOCR= # optional, hides button "Scan to OCR" +- WEBSERVER_LABEL_SCANTOFILE="Scan front pages" # optional, renames button "Scan to file" to "Scan front pages" +- WEBSERVER_LABEL_SCANTOEMAIL="Scan rear pages" # optional, renames button "Scan to email" to "Scan rear pages" ``` #### GUI @@ -180,7 +190,7 @@ Thus, make sure to wait for your scan to complete, before pressing another butto #### API The GUI uses a minimal "API" at the backend, which you can also use from other tooling (e.g., Home Assistant or a control panel near your printer). To scan, simply call `http://:/scan.php?target=` -Also check out the endpoints `list.php`, `download.php`, `active.php`. +Also check out the endpoints `list.php`, `listfiles.php`, `download.php`, `active.php` and `status.php`. Maybe one day an OpenAPI Spec will be included. ## Full Docker Compose Example @@ -195,10 +205,8 @@ services: volumes: - /path/on/host:/scans ports: - - 33355:33355 + - 33355:33355 # example webserver port - 54925:54925/udp # mandatory, for scanner tools - - 54921:54921 # mandatory, for scanner tools - - 161:161/udp # mandatory, for scanner tools environment: - NAME=Scanner - MODEL=MFC-L2700DW @@ -210,12 +218,13 @@ services: - UID=1000 # optional, for /scans permissions - GID=1000 # optional, for /scans permissions - TZ=Europe/Berlin # optional, for correct time in scanned filenames - - WEBSERVER=true # optional, activates GUI & API + - WEBSERVER_ENABLE= # optional, activates GUI & API + - WEBSERVER_PING_ENABLE= # optional, activates ping service to check if scanner offline - PORT=33355 # optional, sets port for webserver (default: 80) - - DISABLE_GUI_SCANTOIMAGE=true # optional, deactivates button "Scan to image" - - DISABLE_GUI_SCANTOOCR=true # optional, deactivates button "Scan to OCR" - - RENAME_GUI_SCANTOFILE="Scan front pages" # optional, renames button "Scan to file" to "Scan front pages" - - RENAME_GUI_SCANTOEMAIL="Scan rear pages" # optional, renames button "Scan to email" to "Scan rear pages" + - WEBSERVER_LABEL_SCANTOIMAGE= # optional, deactivates button "Scan to image" + - WEBSERVER_LABEL_SCANTOOCR=true # optional, deactivates button "Scan to OCR" + - WEBSERVER_LABEL_SCANTOFILE="Scan front pages" # optional, renames button "Scan to file" to "Scan front pages" + - WEBSERVER_LABEL_SCANTOEMAIL="Scan rear pages" # optional, renames button "Scan to email" to "Scan rear pages" restart: unless-stopped # optional, for OCR diff --git a/files/api/download.php b/files/api/download.php index 1ced9b7..da3b390 100644 --- a/files/api/download.php +++ b/files/api/download.php @@ -1,23 +1,25 @@ \ No newline at end of file diff --git a/files/api/lib/lib.php b/files/api/lib/lib.php new file mode 100644 index 0000000..863d21a --- /dev/null +++ b/files/api/lib/lib.php @@ -0,0 +1,8 @@ + \ No newline at end of file diff --git a/files/api/lib/listfiles.php b/files/api/lib/listfiles.php new file mode 100644 index 0000000..ebbb075 --- /dev/null +++ b/files/api/lib/listfiles.php @@ -0,0 +1,68 @@ + \ No newline at end of file diff --git a/files/api/lib/subdircheck.php b/files/api/lib/subdircheck.php new file mode 100644 index 0000000..766bcc9 --- /dev/null +++ b/files/api/lib/subdircheck.php @@ -0,0 +1,13 @@ + \ No newline at end of file diff --git a/files/api/list.php b/files/api/list.php index 13369ff..82c65b8 100644 --- a/files/api/list.php +++ b/files/api/list.php @@ -1,13 +1,14 @@ "; + echo str_replace($SCANS_DIR."/", "", $files[$i])."
"; } +} else { + http_response_code(405); + die("Error: Method not allowed!"); } -?> \ No newline at end of file +?> diff --git a/files/api/listfiles.php b/files/api/listfiles.php new file mode 100644 index 0000000..90e641b --- /dev/null +++ b/files/api/listfiles.php @@ -0,0 +1,16 @@ +" . $replaced . "
"; + } +} +else { + http_response_code(405); + die("Error: Method not allowed!"); +} +?> \ No newline at end of file diff --git a/files/api/scan.php b/files/api/scan.php index ddfa94e..d11ff84 100644 --- a/files/api/scan.php +++ b/files/api/scan.php @@ -3,31 +3,39 @@ ini_set('display_startup_errors', 1); error_reporting(E_ALL); -include 'config.php'; +include_once(__DIR__."/lib/config.php"); +include_once(__DIR__."/lib/lib.php"); -if ($_SERVER['REQUEST_METHOD'] == 'POST') { - $target = $_POST["target"]; -} else if ($_SERVER['REQUEST_METHOD'] == 'GET') { - $target = $_GET["target"]; +function exit_error() { + http_response_code(400); + die("Error: Thou shalt not inject unknown script names!"); } + +$target = $_POST["target"] ?? ($_GET["target"] ?? ''); + if (empty($target)) { - header($_SERVER["SERVER_PROTOCOL"] . " 400 OK"); + http_response_code(400); die("Error: No scanning function selected (try append: ?target=)"); } if (in_array($target, array('file','email','image','ocr'))) { + + $script = $SCRIPTS_DIR . "/scanto" . $target . ".sh"; + + if(!is_sub_path($script, $SCRIPTS_DIR)) { + exit_error(); + } if ($_SERVER['REQUEST_METHOD'] == 'POST') { //return immediately - $handle = popen('sudo -b -u \#'.$UID.' /opt/brother/scanner/brscan-skey/script/scanto'.$target.'.sh', 'r'); + $handle = popen($script, 'r'); } else if ($_SERVER['REQUEST_METHOD'] == 'GET') { //wait for completion - $output=shell_exec('sudo -u \#'.$UID.' /opt/brother/scanner/brscan-skey/script/scanto'.$target.'.sh'); + $output=shell_exec($script); } } else { - header($_SERVER["SERVER_PROTOCOL"] . " 400 OK"); - die("Error: Thou shalt not inject unknown script names!"); + exit_error(); } //TODO: Fix serving of file on get diff --git a/files/api/status.php b/files/api/status.php new file mode 100644 index 0000000..89785cd --- /dev/null +++ b/files/api/status.php @@ -0,0 +1,20 @@ + \ No newline at end of file diff --git a/files/gui/index.php b/files/gui/index.php index bb8f3fd..f609e4f 100644 --- a/files/gui/index.php +++ b/files/gui/index.php @@ -1,62 +1,85 @@ + - Brother <?php echo($MODEL); ?> - + - +
Brother
+
Status: Loading...
+
-
'.$button_file.''); - } - if (!isset($DISABLE_GUI_SCANTOEMAIL) || $DISABLE_GUI_SCANTOEMAIL != true) { - echo(''); - } - if (!isset($DISABLE_GUI_SCANTOIMAGE) || $DISABLE_GUI_SCANTOIMAGE != true) { - echo(''); - } - if (!isset($DISABLE_GUI_SCANTOOCR) || $DISABLE_GUI_SCANTOOCR != true) { - echo(''); - } + $labels = array( + 'file' => $WEBSERVER_LABEL_SCANTOFILE, + 'email' => $WEBSERVER_LABEL_SCANTOEMAIL, + 'image' => $WEBSERVER_LABEL_SCANTOIMAGE, + 'ocr' => $WEBSERVER_LABEL_SCANTOOCR + ); + $labels = array_filter($labels, function($v) { return $v !== null && strlen($v) !== 0; }); + foreach ($labels as $func => $label) { + echo(''); + } ?> -
-
Last scanned:
- ".$files[$i]."
"; - } - ?> +
+
- - + \ No newline at end of file diff --git a/files/gui/main.css b/files/gui/main.css index 2b75f44..c304f64 100644 --- a/files/gui/main.css +++ b/files/gui/main.css @@ -1,21 +1,21 @@ -#based on https://codepen.io/ainalem/pen/GRqPwoz +/*based on https://codepen.io/ainalem/pen/GRqPwoz */ body { align-items: center; background-color: #000; display: flex; justify-content: center; - height: 100vh; + height: 100dvh; } .form { background-color: #15172b; border-radius: 20px; box-sizing: border-box; -# height: 550px; -# height: 100%; + /* height: 550px; */ + /* height: 100%; */ padding: 20px; -# width: 320px; + /* width: 320px; */ } .title { @@ -134,11 +134,88 @@ body { font-size: 18px; height: 50px; margin-top: 30px; - // outline: 0; + /* outline: 0; */ text-align: center; width: 100%; + justify-content: space-evenly; + flex-direction: row; + align-items: center; + transition: all 0.5s; } .submit:active { background-color: #06b; } +.submit:disabled { + cursor: unset; + background-color: #00558a!important; +} + +@media (prefers-color-scheme: dark) { + body { + background-color: #07070e; + } +} +.scanner-wrapper { + margin-top: 1rem; + --scanner-height: 65px; + --scanner-width: 40px; + height: var(--scanner-height); + width: 100%; +} +.scanner { + position: relative; + height: 100%; + width: var(--scanner-width); + border: 2px solid white; + background-image: repeating-linear-gradient(0deg, #b6b6b6, #b6b6b6 1px, transparent 1px, transparent); + background-size: 6px 6px; +} +.scanner::after { + --scanner-line-width: calc(var(--scanner-width) * 1.4); + content: ' '; + position: absolute; + width: var(--scanner-line-width); + top: 0; + left: calc((var(--scanner-width) - var(--scanner-line-width)) / 2); + height: 3px; + background-color: red; + animation: scanning 0.8s linear infinite; +} +@keyframes scanning { + 50% { + transform: translate(0, var(--scanner-height)); + } +} +.hidden { + display: none; +} + +.submit::after { + content: ''; + display: inline-block; + width: 0px; + height: 0px; + border-radius: 50%; + transition: all 0.5s; + +} +.loading { + display: flex; +} +.loading::after { + width: 20px; + height: 20px; + border: 2px solid #808097; + border-top-color: white; + animation: rotating 1s linear infinite; +} + +@keyframes rotating { + 0% { + transform: rotate(0deg); + } + 100% { + transform: rotate(360deg); + } +} \ No newline at end of file diff --git a/files/runScanner.sh b/files/runScanner.sh index bffb90a..bfc6d73 100755 --- a/files/runScanner.sh +++ b/files/runScanner.sh @@ -1,18 +1,31 @@ #!/bin/bash -echo "setting up user & logfile:" -if [[ -z ${UID} ]]; then - UID=1000 -fi -if [[ -z ${GID} ]]; then - GID=1000 + +WEBSERVER_DEFAULT="true" +WEBSERVER_PING_DEFAULT="true" +WEBSERVER_PING_INTERVAL_DEFAULT=60 +PORT_DEFAULT=80 + +mandatory_vars=(NAME MODEL IPADDRESS) +missing=0 +for var in "${mandatory_vars[@]}" +do + if [[ -z "${!var}" ]]; then + echo "missing mandatory variable: $var" + missing=1 + fi +done +if [[ $missing -eq 1 ]]; then + echo "exiting" + exit 1 fi -groupadd --gid $GID NAS -adduser $USERNAME --uid $UID --gid $GID --disabled-password --force-badname --gecos "" + +echo "setting up logfile" + mkdir -p /scans chmod 777 /scans touch /var/log/scanner.log -chown $USERNAME /var/log/scanner.log -env > /opt/brother/scanner/env.txt +chmod 777 /var/log/scanner.log +export > /opt/brother/scanner/shell_env.txt chmod -R 777 /opt/brother echo "-----" @@ -34,59 +47,98 @@ sed -i 's/^ip_address=.*//' /opt/brother/scanner/brscan-skey/brscan-skey.config if [[ -z "$HOST_IPADDRESS" ]]; then echo "no host IP configured, using default discovery" else + echo "using host IP: $HOST_IPADDRESS" echo "ip_address=$HOST_IPADDRESS" >> /opt/brother/scanner/brscan-skey/brscan-skey.config fi echo "-----" +echo "setting up username:" +sed -i 's/^user=.*//' /opt/brother/scanner/brscan-skey/brscan-skey.config +echo "user=${USERNAME:-docker}" >> /opt/brother/scanner/brscan-skey/brscan-skey.config +echo "using username: ${USERNAME:-docker}" +echo "-----" + echo "whole config:" cat /opt/brother/scanner/brscan-skey/brscan-skey.config echo "-----" echo "starting scanner drivers..." -su - $USERNAME -c "/usr/bin/brsaneconfig4 -a name=$NAME model=$MODEL ip=$IPADDRESS" -su - $USERNAME -c "/usr/bin/brscan-skey" +driver_cmds=("/usr/bin/brsaneconfig4 -a name=$NAME model=$MODEL ip=$IPADDRESS" /usr/bin/brscan-skey) +for cmd in "${driver_cmds[@]}" +do + #check if failed + $cmd + if [ $? -ne 0 ]; then + echo "failed to start: `$cmd`" + exit 1 + fi +done +echo "-----" + +echo "setting up script permissions..." +#change ownership of scripts to root and setuid +chown root /opt/brother/scanner/brscan-skey/script/*.sh +chmod u+s /opt/brother/scanner/brscan-skey/script/*.sh +chmod o+x /opt/brother/scanner/brscan-skey/script/*.sh + echo "-----" echo "setting up webserver:" -if [ "$WEBSERVER" == "true" ]; then + +#-------------------------------------------------------- +#backwards compatibility +WEBSERVER_ENABLE="${WEBSERVER_ENABLE:-$WEBSERVER}" +WEBSERVER_PORT="${WEBSERVER_PORT:-$PORT}" +WEBSERVER_LABEL_SCANTOFILE="${WEBSERVER_LABEL_SCANTOFILE:-$RENAME_GUI_SCANTOFILE}" +WEBSERVER_LABEL_SCANTOEMAIL="${WEBSERVER_LABEL_SCANTOEMAIL:-$RENAME_GUI_SCANTOEMAIL}" +WEBSERVER_LABEL_SCANTOIMAGE="${WEBSERVER_LABEL_SCANTOIMAGE:-$RENAME_GUI_SCANTOIMAGE}" +WEBSERVER_LABEL_SCANTOOCR="${WEBSERVER_LABEL_SCANTOOCR:-$RENAME_GUI_SCANTOOCR}" +if [ "${DISABLE_GUI_SCANTOFILE:-false}" = "true" ]; then + WEBSERVER_LABEL_SCANTOFILE="" +fi +if [ "${DISABLE_GUI_SCANTOEMAIL:-false}" = "true" ]; then + WEBSERVER_LABEL_SCANTOEMAIL="" +fi +if [ "${DISABLE_GUI_SCANTOIMAGE:-false}" = "true" ]; then + WEBSERVER_LABEL_SCANTOIMAGE="" +fi +if [ "${DISABLE_GUI_SCANTOOCR:-false}" = "true" ]; then + WEBSERVER_LABEL_SCANTOOCR="" +fi +#-------------------------------------------------------- + +if [ "${WEBSERVER_ENABLE:-$WEBSERVER_DEFAULT}" = "true" ]; then + WEBSERVER_PING_ENABLE="${WEBSERVER_PING_ENABLE:-$WEBSERVER_PING_DEFAULT}" + if [ "${WEBSERVER_PING_ENABLE:-$WEBSERVER_PING_DEFAULT}" = "true" ]; then + echo "enabling ping status" + ( + while true; do + if /usr/bin/ping -c 1 $IPADDRESS > /dev/null; then + echo "1" > /var/www/html/reachable.txt + else + echo "0" > /var/www/html/reachable.txt + fi + sleep "${WEBSERVER_PING_INTERVAL:-$WEBSERVER_PING_INTERVAL_DEFAULT}" + done + ) & + + fi + echo "starting webserver for API & GUI..." { echo "" - } > /var/www/html/config.php - chown www-data /var/www/html/config.php - if [[ -z ${PORT} ]]; then - PORT=80 - fi - echo "running on port $PORT" - sed -i "s/server.port\W*= 80/server.port = $PORT/" /etc/lighttpd/lighttpd.conf + } > /var/www/html/lib/config.php + chown www-data /var/www/html/lib/config.php + echo "running on port ${WEBSERVER_PORT:-$PORT_DEFAULT}" + sed -i "s/server.port\W*= 80/server.port = ${WEBSERVER_PORT:-$PORT_DEFAULT}/" /etc/lighttpd/lighttpd.conf /usr/sbin/lighttpd -f /etc/lighttpd/lighttpd.conf echo "webserver started" else @@ -98,8 +150,5 @@ echo "capabilities:" scanimage -A echo "startup successful" -while true; -do - tail -f /var/log/scanner.log -done +tail -f /var/log/scanner.log exit 0 diff --git a/script/scanRear.sh b/script/scanRear.sh index 4533ed6..777f07f 100755 --- a/script/scanRear.sh +++ b/script/scanRear.sh @@ -3,7 +3,8 @@ # $2 = friendly name #override environment, as brscan is screwing it up: -export $(grep -v '^#' /opt/brother/scanner/env.txt | xargs) +#export $(grep -v '^#' /opt/brother/scanner/env.txt | xargs) +source /opt/brother/scanner/shell_env.txt if [[ $RESOLUTION ]]; then resolution=$RESOLUTION @@ -32,20 +33,11 @@ rm scan_pid #sthg is wrong with device name, probably escaping, use default printer: #scan_cmd="scanimage -l 0 -t 0 -x 215 -y 297 --device-name=$device --resolution=$resolution --batch=$output_file" scan_cmd="scanimage -l 0 -t 0 -x 215 -y 297 --resolution=$resolution --batch=$output_file" - -if [ "`which usleep 2>/dev/null `" != '' ];then - usleep 100000 -else - sleep 0.1 -fi +sleep 0.1 $($scan_cmd) if [ ! -s $filename_base"0001.pnm" ];then - if [ "`which usleep 2>/dev/null `" != '' ];then - usleep 1000000 - else - sleep 1 - fi - $($scan_cmd) + sleep 1 + $($scan_cmd) fi ( @@ -73,7 +65,9 @@ fi ( echo "converting to PDF for $date..." - gm convert -page A4+0+0 $compression_flag *.pnm /scans/$date.pdf + gm convert -page A4+0+0 $compression_flag *.pnm /scans/$date.pdf + #change ownership to target user/group + chown $UID:$GID /scans/$date.pdf /opt/brother/scanner/brscan-skey/script/trigger_inotify.sh "${SSH_USER}" "${SSH_PASSWORD}" "${SSH_HOST}" "${SSH_PATH}" $date.pdf echo "cleaning up for $date..." @@ -85,7 +79,9 @@ fi else echo "starting OCR for $date..." ( - curl -F "userfile=@/scans/$date.pdf" -H "Expect:" -o /scans/$date-ocr.pdf ${OCR_SERVER}:${OCR_PORT}/${OCR_PATH} + curl -F "userfile=@/scans/$date.pdf" -H "Expect:" -o /scans/$date-ocr.pdf ${OCR_SERVER}:${OCR_PORT}/${OCR_PATH} + #change ownership to target user/group + chown $UID:$GID /scans/$date-ocr.pdf /opt/brother/scanner/brscan-skey/script/trigger_inotify.sh "${SSH_USER}" "${SSH_PASSWORD}" "${SSH_HOST}" "${SSH_PATH}" $date-ocr.pdf /opt/brother/scanner/brscan-skey/script/sendtoftps.sh \ diff --git a/script/scantoemail-0.2.4-1.sh b/script/scantoemail-0.2.4-1.sh index 360d370..357cbad 100644 --- a/script/scantoemail-0.2.4-1.sh +++ b/script/scantoemail-0.2.4-1.sh @@ -4,8 +4,8 @@ { #override environment, as brscan is screwing it up: -export $(grep -v '^#' /opt/brother/scanner/env.txt | xargs) - +#export $(grep -v '^#' /opt/brother/scanner/env.txt | xargs) +source /opt/brother/scanner/shell_env.txt SCRIPTPATH="$( cd "$(dirname "$0")" ; pwd -P )" /bin/bash $SCRIPTPATH/scanRear.sh $@ diff --git a/script/scantofile-0.2.4-1.sh b/script/scantofile-0.2.4-1.sh index 49994b1..86eb869 100755 --- a/script/scantofile-0.2.4-1.sh +++ b/script/scantofile-0.2.4-1.sh @@ -4,7 +4,8 @@ { #override environment, as brscan is screwing it up: -export $(grep -v '^#' /opt/brother/scanner/env.txt | xargs) +#export $(grep -v '^#' /opt/brother/scanner/env.txt | xargs) +source /opt/brother/scanner/shell_env.txt if [[ $RESOLUTION ]]; then resolution=$RESOLUTION @@ -30,33 +31,22 @@ echo "filename: "$output_file #sthg is wrong with device name, probably escaping, use default printer: #scan_cmd="scanimage -l 0 -t 0 -x 215 -y 297 --device-name=$device --resolution=$resolution --batch=$output_file" scan_cmd="scanimage -l 0 -t 0 -x 215 -y 297 --resolution=$resolution --batch=$output_file" - -if [ "`which usleep 2>/dev/null `" != '' ];then - usleep 100000 -else - sleep 0.1 -fi +sleep 0.1 $($scan_cmd) if [ ! -s $filename_base"0001.pnm" ];then - if [ "`which usleep 2>/dev/null `" != '' ];then - usleep 1000000 - else - sleep 1 - fi + sleep 1 $($scan_cmd) fi #only convert when no back pages are being scanned: ( - if [ "`which usleep 2>/dev/null `" != '' ];then - usleep 120000000 - else - sleep 120 - fi + sleep 120 ( echo "converting to PDF for $date..." gm convert -page A4+0+0 $compression_flag $filename_base*.pnm /scans/$date.pdf + #change ownership to target user/group + chown $UID:$GID /scans/$date.pdf /opt/brother/scanner/brscan-skey/script/trigger_inotify.sh "${SSH_USER}" "${SSH_PASSWORD}" "${SSH_HOST}" "${SSH_PATH}" $date.pdf echo "cleaning up for $date..." @@ -69,6 +59,8 @@ fi echo "starting OCR for $date..." ( curl -F "userfile=@/scans/$date.pdf" -H "Expect:" -o /scans/$date-ocr.pdf ${OCR_SERVER}:${OCR_PORT}/${OCR_PATH} + #change ownership to target user/group + chown $UID:$GID /scans/$date-ocr.pdf /opt/brother/scanner/brscan-skey/script/trigger_inotify.sh "${SSH_USER}" "${SSH_PASSWORD}" "${SSH_HOST}" "${SSH_PATH}" $date-ocr.pdf /opt/brother/scanner/brscan-skey/script/sendtoftps.sh \ "${FTP_USER}" \