diff --git a/README.md b/README.md index 1b730980..7ad20717 100644 --- a/README.md +++ b/README.md @@ -122,6 +122,7 @@ This is the official repository for the Tipi App Store. It contains all the apps - [SimpleX SMP](https://github.com/simplex-chat/simplexmq) - A reference implementation of the SimpleX Messaging Protocol for simplex queues over public networks. - [Sonarr](https://github.com/Sonarr/Sonarr) - TV show manager for Usenet and BitTorrent - [Sshwifty](https://github.com/nirui/sshwifty/) - Web SSH & Telnet (WebSSH & WebTelnet client) +- [Stirling-PDF](https://github.com/Frooodle/Stirling-PDF) - Locally hosted web application that allows you to perform various operations on PDF files. - [Syncthing](https://github.com/syncthing/syncthing) - Continuous File Synchronization - [Tailscale](https://github.com/tailscale/tailscale) - The easiest, most secure way to use WireGuard and 2FA - [Tandoor](https://github.com/TandoorRecipes/recipes) - Drop your collection of links and notes. Get Tandoor and never look back onto a time without recipe management, storage, sharing and collaborative cooking! diff --git a/apps/bookstack/config.json b/apps/bookstack/config.json index d8274bb4..c3bd64a5 100644 --- a/apps/bookstack/config.json +++ b/apps/bookstack/config.json @@ -5,8 +5,8 @@ "exposable": true, "port": 8119, "id": "bookstack", - "tipi_version": 11, - "version": "23.06.20230703", + "tipi_version": 12, + "version": "23.08.20230830", "description": "BookStack is a simple, self-hosted, easy-to-use platform for organising and storing information. Default login: admin@admin.com password: password", "short_desc": "BookStack is a self-hosted platform for organising and storing information.", "author": "Dan Brown", diff --git a/apps/bookstack/docker-compose.yml b/apps/bookstack/docker-compose.yml index c2caaca6..917790df 100644 --- a/apps/bookstack/docker-compose.yml +++ b/apps/bookstack/docker-compose.yml @@ -1,7 +1,7 @@ version: "3.7" services: bookstack: - image: lscr.io/linuxserver/bookstack:23.06.20230703 + image: lscr.io/linuxserver/bookstack:23.08.20230830 container_name: bookstack environment: - APP_URL=${APP_PROTOCOL:-http}://${APP_DOMAIN} diff --git a/apps/filebrowser/docker-compose.yml b/apps/filebrowser/docker-compose.yml index 00cc0598..d3421d18 100644 --- a/apps/filebrowser/docker-compose.yml +++ b/apps/filebrowser/docker-compose.yml @@ -5,12 +5,10 @@ services: image: filebrowser/filebrowser:s6 ports: - ${APP_PORT}:80 - environment: - - PUID=1000 - - PGID=1000 volumes: - ${ROOT_FOLDER_HOST}/app-data:/srv/app-data - ${ROOT_FOLDER_HOST}/media:/srv/media + - ${APP_DATA_DIR}/data/general:/srv/general - ${APP_DATA_DIR}/data/db:/database - ${APP_DATA_DIR}/data/config:/config networks: diff --git a/apps/filebrowser/metadata/description.md b/apps/filebrowser/metadata/description.md index 3c7355e1..8160c31e 100644 --- a/apps/filebrowser/metadata/description.md +++ b/apps/filebrowser/metadata/description.md @@ -4,9 +4,9 @@ filebrowser provides a file managing interface within a specified directory and - **username**: admin - **password**: admin -
+ ## Features Please refer to our docs at [https://filebrowser.org/features](https://filebrowser.org/features) -![Preview](https://user-images.githubusercontent.com/5447088/50716739-ebd26700-107a-11e9-9817-14230c53efd2.gif) \ No newline at end of file +![Preview](https://user-images.githubusercontent.com/5447088/50716739-ebd26700-107a-11e9-9817-14230c53efd2.gif) diff --git a/apps/immich/config.json b/apps/immich/config.json index 392d9f1a..4de53fce 100644 --- a/apps/immich/config.json +++ b/apps/immich/config.json @@ -5,8 +5,8 @@ "exposable": true, "port": 8128, "id": "immich", - "tipi_version": 39, - "version": "1.76.0", + "tipi_version": 40, + "version": "1.76.1", "categories": [ "data", "photography" diff --git a/apps/immich/docker-compose.yml b/apps/immich/docker-compose.yml index 6454d427..57e03410 100644 --- a/apps/immich/docker-compose.yml +++ b/apps/immich/docker-compose.yml @@ -3,7 +3,7 @@ version: "3.7" services: immich: container_name: immich - image: altran1502/immich-proxy:v1.76.0 + image: altran1502/immich-proxy:v1.76.1 ports: - ${APP_PORT}:8080 depends_on: @@ -43,7 +43,7 @@ services: immich-server: container_name: immich-server - image: altran1502/immich-server:v1.75.2 + image: altran1502/immich-server:v1.76.1 command: ["start-server.sh"] volumes: - ${ROOT_FOLDER_HOST}/media/data/images/immich:/usr/src/app/upload @@ -68,7 +68,7 @@ services: immich-microservices: container_name: immich-microservices - image: altran1502/immich-server:v1.75.2 + image: altran1502/immich-server:v1.76.1 command: ["start-microservices.sh"] volumes: - ${ROOT_FOLDER_HOST}/media/data/images/immich:/usr/src/app/upload @@ -93,7 +93,7 @@ services: immich-machine-learning: container_name: immich-machine-learning - image: altran1502/immich-machine-learning:v1.76.0 + image: altran1502/immich-machine-learning:v1.76.1 volumes: - ${ROOT_FOLDER_HOST}/media/data/images/immich:/usr/src/app/upload - ${APP_DATA_DIR}/data/immich-ml-cache:/cache @@ -114,7 +114,7 @@ services: immich-web: container_name: immich-web - image: altran1502/immich-web:v1.75.2 + image: altran1502/immich-web:v1.76.1 restart: unless-stopped networks: - tipi_main_network diff --git a/apps/logto/config.json b/apps/logto/config.json index 96098e61..4aaf6f95 100644 --- a/apps/logto/config.json +++ b/apps/logto/config.json @@ -5,8 +5,8 @@ "available": true, "exposable": true, "id": "logto", - "tipi_version": 6, - "version": "1.7.0", + "tipi_version": 7, + "version": "1.8.0", "force_expose": true, "categories": [ "security" diff --git a/apps/logto/docker-compose.yml b/apps/logto/docker-compose.yml index 006f3a50..2ab4dac3 100644 --- a/apps/logto/docker-compose.yml +++ b/apps/logto/docker-compose.yml @@ -4,7 +4,7 @@ services: depends_on: logto-db: condition: service_healthy - image: svhd/logto:1.7.0 + image: svhd/logto:1.8.0 container_name: logto entrypoint: ["sh", "-c", "npm run cli db seed -- --swe && npm start"] ports: diff --git a/apps/stirling-pdf/config.json b/apps/stirling-pdf/config.json new file mode 100644 index 00000000..11db4928 --- /dev/null +++ b/apps/stirling-pdf/config.json @@ -0,0 +1,20 @@ +{ + "$schema": "../schema.json", + "name": "Stirling-PDF", + "port": 8234, + "available": true, + "exposable": true, + "id": "stirling-pdf", + "tipi_version": 1, + "version": "0.13.0", + "categories": [ + "data", + "utilities" + ], + "description": "Locally hosted web application that allows you to perform various operations on PDF files.", + "short_desc": "Powerful locally hosted web based PDF manipulation tool.", + "author": "Frooodle", + "source": "https://github.com/Frooodle/Stirling-PDF/", + "form_fields": [] + } + \ No newline at end of file diff --git a/apps/stirling-pdf/docker-compose.yml b/apps/stirling-pdf/docker-compose.yml new file mode 100644 index 00000000..ec57f2ff --- /dev/null +++ b/apps/stirling-pdf/docker-compose.yml @@ -0,0 +1,40 @@ +version: "3.7" +services: + stirling-pdf: + image: ghcr.io/frooodle/s-pdf:0.13.0 + restart: unless-stopped + container_name: stirling-pdf + privileged: true + ports: + - ${APP_PORT}:8080 + volumes: + - ${APP_DATA_DIR}/datatrainingData:/usr/share/tesseract-ocr/4.00/tessdata #Required for extra OCR languages + - ${APP_DATA_DIR}/dataextraConfigs:/configs + - ${APP_DATA_DIR}/datacustomFiles:/customFiles/ + networks: + - tipi_main_network + labels: + # Main + traefik.enable: true + traefik.http.middlewares.stirling-pdf-web-redirect.redirectscheme.scheme: https + traefik.http.services.stirling-pdf.loadbalancer.server.port: 8080 + # Web + traefik.http.routers.stirling-pdf-insecure.rule: Host(`${APP_DOMAIN}`) + traefik.http.routers.stirling-pdf-insecure.entrypoints: web + traefik.http.routers.stirling-pdf-insecure.service: stirling-pdf + traefik.http.routers.stirling-pdf-insecure.middlewares: stirling-pdf-web-redirect + # Websecure + traefik.http.routers.stirling-pdf.rule: Host(`${APP_DOMAIN}`) + traefik.http.routers.stirling-pdf.entrypoints: websecure + traefik.http.routers.stirling-pdf.service: stirling-pdf + traefik.http.routers.stirling-pdf.tls.certresolver: myresolver + # Local domain + traefik.http.routers.stirling-pdf-local-insecure.rule: Host(`stirling-pdf.${LOCAL_DOMAIN}`) + traefik.http.routers.stirling-pdf-local-insecure.entrypoints: web + traefik.http.routers.stirling-pdf-local-insecure.service: stirling-pdf + traefik.http.routers.stirling-pdf-local-insecure.middlewares: stirling-pdf-web-redirect + # Local domain secure + traefik.http.routers.stirling-pdf-local.rule: Host(`stirling-pdf.${LOCAL_DOMAIN}`) + traefik.http.routers.stirling-pdf-local.entrypoints: websecure + traefik.http.routers.stirling-pdf-local.service: stirling-pdf + traefik.http.routers.stirling-pdf-local.tls: true diff --git a/apps/stirling-pdf/metadata/description.md b/apps/stirling-pdf/metadata/description.md new file mode 100644 index 00000000..94a53866 --- /dev/null +++ b/apps/stirling-pdf/metadata/description.md @@ -0,0 +1,64 @@ +


Stirling-PDF

+

+ +This is a powerful locally hosted web based PDF manipulation tool using docker that allows you to perform various operations on PDF files, such as splitting merging, converting, reorganizing, adding images, rotating, compressing, and more. This locally hosted web application started as a 100% ChatGPT-made application and has evolved to include a wide range of features to handle all your PDF needs. + +Stirling PDF makes no outbound calls for any record keeping or tracking. + +All files and PDFs are either purely client side, in server memory only during the execution of the task or within a temporay file only for execution of the task. +Any file which has been downloaded by the user will have already been deleted from the server by that time. + +Feel free to request any features or bug fixes either in github issues or our [Discord](https://discord.gg/Cn8pWhQRxZ) + +## Features +- Full interactive GUI for merging/splitting/rotating/moving PDFs and their pages. +- Split PDFs into multiple files at specified page numbers or extract all pages as individual files. +- Merge multiple PDFs together into a single resultant file +- Convert PDFs to and from images +- Reorganize PDF pages into different orders. +- Add/Generate signatures +- Format PDFs into a multi-paged page +- Scale page contents size by set % +- Adjust Contrast +- Crop PDF +- Auto Split PDF (With physically scanned page dividers) +- Flatten PDFs +- Repair PDFs +- Detect and remove blank pages +- Compare 2 PDFs and show differences in text +- Add images to PDFs +- Rotating PDFs in 90 degree increments. +- Compressing PDFs to decrease their filesize. (Using OCRMyPDF) +- Add and remove passwords +- Set PDF Permissions +- Add watermark(s) +- Convert Any common file to PDF (using LibreOffice) +- Convert PDF to Word/Powerpoint/Others (using LibreOffice) +- Convert HTML to PDF +- URL to PDF +- Extract images from PDF +- Extract images from Scans +- Add page numbers +- Auto rename file by detecting PDF header text +- OCR on PDF (Using OCRMyPDF) +- PDF/A conversion (Using OCRMyPDF) +- Edit metadata +- Dark mode support. +- Custom download options (see [here](https://github.com/Frooodle/Stirling-PDF/blob/main/images/settings.png) for example) +- Parallel file processing and downloads +- API for integration with external scripts + +For a overview of the tasks and the technology each uses please view [groups.md](https://github.com/Frooodle/Stirling-PDF/blob/main/Groups.md) +Hosted instance/demo of the app can be seen [here](https://pdf.adminforge.de/) hosted by the team at adminforge.de + +## Technologies used +- Spring Boot + Thymeleaf +- PDFBox +- IText7 +- [LibreOffice](https://www.libreoffice.org/discover/libreoffice/) for advanced conversions +- [OcrMyPdf](https://github.com/ocrmypdf/OCRmyPDF) +- HTML, CSS, JavaScript +- Docker +- PDF.js +- PDF-LIB.js + diff --git a/apps/stirling-pdf/metadata/logo.jpg b/apps/stirling-pdf/metadata/logo.jpg new file mode 100644 index 00000000..5ee8682a Binary files /dev/null and b/apps/stirling-pdf/metadata/logo.jpg differ diff --git a/apps/transmission/config.json b/apps/transmission/config.json index f49923e7..90003e07 100644 --- a/apps/transmission/config.json +++ b/apps/transmission/config.json @@ -10,8 +10,8 @@ ] }, "id": "transmission", - "tipi_version": 7, - "version": "4.0.3", + "tipi_version": 8, + "version": "4.0.4", "categories": [ "utilities" ], diff --git a/apps/transmission/docker-compose.yml b/apps/transmission/docker-compose.yml index 5c058ed6..cff63cce 100644 --- a/apps/transmission/docker-compose.yml +++ b/apps/transmission/docker-compose.yml @@ -1,7 +1,7 @@ version: "3.7" services: transmission: - image: lscr.io/linuxserver/transmission:4.0.3 + image: lscr.io/linuxserver/transmission:4.0.4 container_name: transmission dns: - ${DNS_IP} diff --git a/apps/zipline/config.json b/apps/zipline/config.json index 57a5099c..8d0b8edd 100644 --- a/apps/zipline/config.json +++ b/apps/zipline/config.json @@ -5,8 +5,8 @@ "available": true, "exposable": true, "id": "zipline", - "tipi_version": 4, - "version": "3.7.3", + "tipi_version": 5, + "version": "3.7.4", "categories": [ "media" ], diff --git a/apps/zipline/docker-compose.yml b/apps/zipline/docker-compose.yml index 7383e75b..0ee0bdb7 100644 --- a/apps/zipline/docker-compose.yml +++ b/apps/zipline/docker-compose.yml @@ -3,7 +3,7 @@ version: '3.7' services: zipline: container_name: zipline - image: ghcr.io/diced/zipline:3.7.3 + image: ghcr.io/diced/zipline:3.7.4 ports: - '${APP_PORT}:3000' restart: unless-stopped