Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for photoprism #667

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ If you have a spare domain name you can configure applications to be accessible
* [Organizr](https://organizr.app/) - ORGANIZR aims to be your one stop shop for your Servers Frontend.
* [overseerr](https://docs.overseerr.dev) - open source software application for managing requests for your media library
* [Paperless_ng](https://github.com/jonaswinkler/paperless-ng) - Scan, index and archive all your physical documents
* [Photoprism](https://photoprism.app) - AI-Powered Photos App for the Decentralized Web. Tag and find pictures automatically.
* [Piwigo](https://piwigo.org/) - Photo Gallery Software
* [Plex](https://www.plex.tv/) - Plex Media Server
* [Portainer](https://portainer.io/) - for managing Docker and running custom images
Expand Down
4 changes: 4 additions & 0 deletions nas.yml
Original file line number Diff line number Diff line change
Expand Up @@ -297,6 +297,10 @@
- role: paperless_ng
tags:
- paperless_ng

- role: photoprism
tags:
- photoprism

- role: piwigo
tags:
Expand Down
30 changes: 30 additions & 0 deletions roles/photoprism/defaults/main.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
---
# Basic options
photoprism_enabled: false
photoprism_site_caption: "AI-Powered Photos App"

# Directories
photoprism_data_directory: "{{ docker_home }}/photoprism"
photoprism_photos_directory: "{{ photos_root }}"

# External configuration
photoprism_available_externally: false
photoprism_hostname: photoprism
photoprism_port: 2342

# Admin configs
photoprism_admin_user: admin
photoprism_admin_password: insecure

# Database configs
# You must have the database already running.
# If you don't know how to do it, just leave as it is.
photoprism_database_driver: sqlite
photoprism_database_server: ""
photoprism_database_name: ""
photoprism_database_user: ""
photoprism_database_password: ""

# Specs
photoprism_memory: 4g
photoprism_container_name: photoprism
30 changes: 30 additions & 0 deletions roles/photoprism/docs/photoprism.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
# Photoprism

Homepage: <https://photoprism.app>

PhotoPrism® is an AI-Powered Photos App for the Decentralized Web.

It makes use of the latest technologies to tag and find pictures automatically without getting in your way. You can run it at home, on a private server, or in the cloud.

## Usage

Set `photoprism_enabled: true` in your `inventories/<your_inventory>/nas.yml` file.

The Photoprism web interface can be found at <http://ansible_nas_host_or_ip:2342>.

## Specific Configuration

> Usually Photoprism has some spikes of memory when you are uploading a lot of pictures at the same time. Take that in consideration before deplying it.

Make sure you change photoprism username and password in your nas.yml config file!

* photoprism_admin_user: admin
* photoprism_admin_password: insecure

To run together with a database instead of SQLite, which is recommended by Photoprism, you can change this setup. To do it, you must already have a database running and also specify the following variables in your own nas.yml file:

* photoprism_database_driver: mariadb/mysql
* photoprism_database_server: "ip/sqlserver"
* photoprism_database_name: "photoprism_db"
* photoprism_database_user: "mydbuser"
* photoprism_database_password: "insecure"
6 changes: 6 additions & 0 deletions roles/photoprism/molecule/default/molecule.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
provisioner:
inventory:
group_vars:
all:
photoprism_enabled: true
10 changes: 10 additions & 0 deletions roles/photoprism/molecule/default/side_effect.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
---
- name: Stop
hosts: all
become: true
tasks:
- name: "Include {{ lookup('env', 'MOLECULE_PROJECT_DIRECTORY') | basename }} role"
ansible.builtin.include_role:
name: "{{ lookup('env', 'MOLECULE_PROJECT_DIRECTORY') | basename }}"
vars:
photoprism_enabled: false
18 changes: 18 additions & 0 deletions roles/photoprism/molecule/default/verify.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
---
- name: Verify
hosts: all
gather_facts: false
tasks:
- ansible.builtin.include_vars:
file: ../../defaults/main.yml

- name: Get container state
community.docker.docker_container_info:
name: "{{ photoprism_container_name }}"
register: result

- name: Check photoprism is running
ansible.builtin.assert:
that:
- result.container['State']['Status'] == "running"
- result.container['State']['Restarting'] == false
18 changes: 18 additions & 0 deletions roles/photoprism/molecule/default/verify_stopped.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
---
- name: Verify
hosts: all
gather_facts: false
tasks:
- ansible.builtin.include_vars:
file: ../../defaults/main.yml

- name: Try and stop and remove photoprism
community.docker.docker_container:
name: "{{ photoprism_container_name }}"
state: absent
register: result

- name: Check photoprism is stopped
ansible.builtin.assert:
that:
- not result.changed
50 changes: 50 additions & 0 deletions roles/photoprism/tasks/main.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
---
- name: Start Photoprism
block:
- name: Create Photoprism Directories
ansible.builtin.file:
path: "{{ item }}"
state: directory
with_items:
- "{{ photoprism_data_directory }}"

- name: Photoprism Docker Container
community.docker.docker_container:
name: "{{ photoprism_container_name }}"
image: photoprism/photoprism
pull: true
volumes:
- "/etc/localtime:/etc/localtime:ro"
- "{{ photoprism_data_directory }}/storage:/photoprism/storage:rw"
- "{{ photoprism_photos_directory }}:/photoprism/originals:rw"
env:
PHOTOPRISM_SITE_CAPTION: "{{ photoprism_site_caption }}"
PHOTOPRISM_ADMIN_USER: "{{ photoprism_admin_user }}"
PHOTOPRISM_ADMIN_PASSWORD: "{{ photoprism_admin_password }}"
PHOTOPRISM_SITE_URL: "https://{{ photoprism_hostname }}.{{ ansible_nas_domain }}"
PHOTOPRISM_DATABASE_DRIVER: "{{ photoprism_database_driver }}"
PHOTOPRISM_DATABASE_SERVER: "{{ photoprism_database_server }}"
PHOTOPRISM_DATABASE_NAME: "{{ photoprism_database_name }}"
PHOTOPRISM_DATABASE_USER: "{{ photoprism_database_user }}"
PHOTOPRISM_DATABASE_PASSWORD: "{{ photoprism_database_password }}"
ports:
- "{{ photoprism_port }}:2342"
restart_policy: unless-stopped
memory: "{{ photoprism_memory }}"
labels:
traefik.enable: "{{ photoprism_available_externally | string }}"
traefik.http.routers.photoprism.rule: "Host(`{{ photoprism_hostname }}.{{ ansible_nas_domain }}`)"
traefik.http.routers.photoprism.tls.certresolver: "letsencrypt"
traefik.http.routers.photoprism.tls.domains[0].main: "{{ ansible_nas_domain }}"
traefik.http.routers.photoprism.tls.domains[0].sans: "*.{{ ansible_nas_domain }}"
traefik.http.routers.photoprism.service: "photoprism"
traefik.http.services.photoprism.loadbalancer.server.port: "{{ photoprism_port | string }}"
when: photoprism_enabled is true

- name: Stop Photoprism
block:
- name: Stop Photoprism
community.docker.docker_container:
name: "{{ photoprism_container_name }}"
state: absent
when: photoprism_enabled is false