mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
Merge branch 'master' into dev
This commit is contained in:
commit
da60fc8150
9
.github/workflows/ansible.yml
vendored
9
.github/workflows/ansible.yml
vendored
@ -26,10 +26,15 @@ jobs:
|
|||||||
docker --version
|
docker --version
|
||||||
molecule --version
|
molecule --version
|
||||||
python --version
|
python --version
|
||||||
- name: Test with molecule
|
- name: Test fresh installation with molecule
|
||||||
run: |
|
run: |
|
||||||
cd ansible
|
cd ansible
|
||||||
molecule test
|
molecule test -s fresh
|
||||||
|
working-directory: "${{ github.repository }}"
|
||||||
|
- name: Test release update with molecule
|
||||||
|
run: |
|
||||||
|
cd ansible
|
||||||
|
molecule test -s update
|
||||||
working-directory: "${{ github.repository }}"
|
working-directory: "${{ github.repository }}"
|
||||||
# # https://galaxy.ansible.com/docs/contributing/importing.html
|
# # https://galaxy.ansible.com/docs/contributing/importing.html
|
||||||
# release:
|
# release:
|
||||||
|
18
README.md
18
README.md
@ -10,8 +10,6 @@
|
|||||||
|
|
||||||
Paperless-ng is a fork of the original project, adding a new interface and many other changes under the hood. For a detailed list of changes, have a look at the changelog in the documentation.
|
Paperless-ng is a fork of the original project, adding a new interface and many other changes under the hood. For a detailed list of changes, have a look at the changelog in the documentation.
|
||||||
|
|
||||||
This project is still in development and some things may not work as expected.
|
|
||||||
|
|
||||||
# How it Works
|
# How it Works
|
||||||
|
|
||||||
Paperless does not control your scanner, it only helps you deal with what your scanner produces.
|
Paperless does not control your scanner, it only helps you deal with what your scanner produces.
|
||||||
@ -48,7 +46,7 @@ Here's what you get:
|
|||||||
* Paperless learns from your documents and will be able to automatically assign tags, correspondents and types to documents once you've stored a few documents in paperless.
|
* Paperless learns from your documents and will be able to automatically assign tags, correspondents and types to documents once you've stored a few documents in paperless.
|
||||||
* A task processor that processes documents in parallel and also tells you when something goes wrong. On modern multi core systems, consumption is blazing fast.
|
* A task processor that processes documents in parallel and also tells you when something goes wrong. On modern multi core systems, consumption is blazing fast.
|
||||||
|
|
||||||
If you want to see some screenshots of paperless-ng in action, [some are available in the documentation](https://paperless-ng.readthedocs.io/en/latest/screenshots.html).
|
If you want to see some screenshots of paperless-ng in action, [some are available in the documentation](https://paperless-ng.readthedocs.io/en/latest/screenshots.html). However, some parts of the UI have changed since I took these.
|
||||||
|
|
||||||
For a complete list of changes from paperless, check out the [changelog](https://paperless-ng.readthedocs.io/en/latest/changelog.html)
|
For a complete list of changes from paperless, check out the [changelog](https://paperless-ng.readthedocs.io/en/latest/changelog.html)
|
||||||
|
|
||||||
@ -58,20 +56,6 @@ For a complete list of changes from paperless, check out the [changelog](https:/
|
|||||||
- Fix whatever bugs I and you find.
|
- Fix whatever bugs I and you find.
|
||||||
- Make the documentation nice.
|
- Make the documentation nice.
|
||||||
|
|
||||||
## Roadmap for versions beyond 1.0
|
|
||||||
|
|
||||||
These are things that I want to add to paperless eventually. They are sorted by priority.
|
|
||||||
|
|
||||||
- **More search.** The search backend is incredibly versatile and customizable. Searching is the most important feature of this project and thus, I want to implement things like:
|
|
||||||
- Group and limit search results by correspondent, show “more from this” links in the results.
|
|
||||||
- **Nested tags**. Organize tags in a hierarchical structure. This will combine the benefits of folders and tags in one coherent system.
|
|
||||||
- **An interactive consumer** that shows its progress for documents it processes on the web page.
|
|
||||||
- With live updates and websockets. This already works on a dev branch, but requires a lot of new dependencies, which I'm not particularly happy about.
|
|
||||||
- Notifications when a document was added with buttons to open the new document right away.
|
|
||||||
- **Arbitrary tag colors**. Allow the selection of any color with a color picker.
|
|
||||||
|
|
||||||
Apart from that, paperless is pretty much feature complete.
|
|
||||||
|
|
||||||
## On the chopping block.
|
## On the chopping block.
|
||||||
|
|
||||||
- **GnuPG encrypion.** [Here's a note about encryption in paperless](https://paperless-ng.readthedocs.io/en/latest/administration.html#managing-encryption). The gist of it is that I don't see which attacks this implementation protects against. It gives a false sense of security to users who don't care about how it works.
|
- **GnuPG encrypion.** [Here's a note about encryption in paperless](https://paperless-ng.readthedocs.io/en/latest/administration.html#managing-encryption). The gist of it is that I don't see which attacks this implementation protects against. It gives a false sense of security to users who don't care about how it works.
|
||||||
|
@ -1,7 +0,0 @@
|
|||||||
---
|
|
||||||
- name: Converge
|
|
||||||
hosts: all
|
|
||||||
tasks:
|
|
||||||
- name: "Include ansible"
|
|
||||||
include_role:
|
|
||||||
name: "ansible"
|
|
@ -1,14 +0,0 @@
|
|||||||
---
|
|
||||||
# This is an example playbook to execute Ansible tests.
|
|
||||||
|
|
||||||
- name: Verify
|
|
||||||
hosts: all
|
|
||||||
gather_facts: false
|
|
||||||
tasks:
|
|
||||||
- name: check if webserver is up
|
|
||||||
uri:
|
|
||||||
url: http://localhost:8000
|
|
||||||
status_code: [200, 302]
|
|
||||||
return_content: yes
|
|
||||||
register: landingpage
|
|
||||||
failed_when: "'Sign in</button>' not in landingpage.content"
|
|
7
ansible/molecule/fresh/converge.yml
Normal file
7
ansible/molecule/fresh/converge.yml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
---
|
||||||
|
- name: fresh installation
|
||||||
|
hosts: all
|
||||||
|
tasks:
|
||||||
|
- name: install paperless-ng with default parameters
|
||||||
|
include_role:
|
||||||
|
name: ansible
|
60
ansible/molecule/fresh/verify.yml
Normal file
60
ansible/molecule/fresh/verify.yml
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
---
|
||||||
|
- name: Verify
|
||||||
|
hosts: all
|
||||||
|
gather_facts: false
|
||||||
|
|
||||||
|
vars_files:
|
||||||
|
- ../../defaults/main.yml
|
||||||
|
|
||||||
|
tasks:
|
||||||
|
- name: check if webserver is up
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000
|
||||||
|
status_code: [200, 302]
|
||||||
|
return_content: yes
|
||||||
|
register: landingpage
|
||||||
|
failed_when: "'Sign in</button>' not in landingpage.content"
|
||||||
|
|
||||||
|
- name: check if document posting works
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000/api/documents/post_document/
|
||||||
|
method: POST
|
||||||
|
body_format: form-multipart
|
||||||
|
body:
|
||||||
|
document:
|
||||||
|
content: FOO
|
||||||
|
filename: document.txt
|
||||||
|
mime_type: text/plain
|
||||||
|
headers:
|
||||||
|
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
||||||
|
return_content: yes
|
||||||
|
register: post_document
|
||||||
|
failed_when: "'OK' not in post_document.content"
|
||||||
|
|
||||||
|
- name: verify uploaded document has been accepted
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000/api/logs/
|
||||||
|
headers:
|
||||||
|
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
||||||
|
return_content: yes
|
||||||
|
register: logs
|
||||||
|
failed_when: "'Consuming document.txt' not in logs.content"
|
||||||
|
|
||||||
|
# assumes txt consumption finished by now, might have to sleep a bit
|
||||||
|
- name: verify uploaded document has been consumed
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000/api/logs/
|
||||||
|
headers:
|
||||||
|
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
||||||
|
return_content: yes
|
||||||
|
register: logs
|
||||||
|
failed_when: "'document consumption finished' not in logs.content"
|
||||||
|
|
||||||
|
- name: verify uploaded document is avaiable
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000/api/documents/1/
|
||||||
|
headers:
|
||||||
|
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
||||||
|
return_content: yes
|
||||||
|
register: document
|
||||||
|
failed_when: "'Not found.' in document.content or 'FOO' not in document.content"
|
11
ansible/molecule/update/converge.yml
Normal file
11
ansible/molecule/update/converge.yml
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
---
|
||||||
|
- name: update previous release to newest release
|
||||||
|
hosts: all
|
||||||
|
tasks:
|
||||||
|
- name: set current version as installation target
|
||||||
|
set_fact:
|
||||||
|
paperlessng_version: 0.9.14
|
||||||
|
|
||||||
|
- name: update to newest paperless-ng release
|
||||||
|
include_role:
|
||||||
|
name: ansible
|
35
ansible/molecule/update/molecule.yml
Normal file
35
ansible/molecule/update/molecule.yml
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
---
|
||||||
|
dependency:
|
||||||
|
name: galaxy
|
||||||
|
driver:
|
||||||
|
name: docker
|
||||||
|
platforms:
|
||||||
|
- name: ubuntu_focal
|
||||||
|
image: jrei/systemd-ubuntu:20.04
|
||||||
|
privileged: true
|
||||||
|
volumes:
|
||||||
|
- /sys/fs/cgroup:/sys/fs/cgroup:ro
|
||||||
|
tmpfs:
|
||||||
|
- /tmp
|
||||||
|
- /run
|
||||||
|
- /run/lock
|
||||||
|
override_command: False
|
||||||
|
# ubuntu 18.04 bionic works except that
|
||||||
|
# the default redis configuration expects IPv6 which is not enabled in docker by default
|
||||||
|
# the default Python environment is configured for ASCII instead of UTF-8
|
||||||
|
# ubuntu 16.04 xenial only has Python 3.5 which is EOL and breaks multiple dependencies
|
||||||
|
- name: debian_buster
|
||||||
|
image: jrei/systemd-debian:10
|
||||||
|
privileged: true
|
||||||
|
volumes:
|
||||||
|
- /sys/fs/cgroup:/sys/fs/cgroup:ro
|
||||||
|
tmpfs:
|
||||||
|
- /tmp
|
||||||
|
- /run
|
||||||
|
- /run/lock
|
||||||
|
override_command: False
|
||||||
|
# debian 9 stretch only has Python 3.5 which is EOL and breaks multiple dependencies
|
||||||
|
provisioner:
|
||||||
|
name: ansible
|
||||||
|
verifier:
|
||||||
|
name: ansible
|
10
ansible/molecule/update/prepare.yml
Normal file
10
ansible/molecule/update/prepare.yml
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
- name: install previous release
|
||||||
|
hosts: all
|
||||||
|
tasks:
|
||||||
|
- name: set previous version as installation target
|
||||||
|
set_fact:
|
||||||
|
paperlessng_version: 0.9.13
|
||||||
|
|
||||||
|
- name: install previous paperless-ng release
|
||||||
|
include_role:
|
||||||
|
name: ansible
|
60
ansible/molecule/update/verify.yml
Normal file
60
ansible/molecule/update/verify.yml
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
---
|
||||||
|
- name: Verify
|
||||||
|
hosts: all
|
||||||
|
gather_facts: false
|
||||||
|
|
||||||
|
vars_files:
|
||||||
|
- ../../defaults/main.yml
|
||||||
|
|
||||||
|
tasks:
|
||||||
|
- name: check if webserver is up
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000
|
||||||
|
status_code: [200, 302]
|
||||||
|
return_content: yes
|
||||||
|
register: landingpage
|
||||||
|
failed_when: "'Sign in</button>' not in landingpage.content"
|
||||||
|
|
||||||
|
- name: check if document posting works
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000/api/documents/post_document/
|
||||||
|
method: POST
|
||||||
|
body_format: form-multipart
|
||||||
|
body:
|
||||||
|
document:
|
||||||
|
content: FOO
|
||||||
|
filename: document.txt
|
||||||
|
mime_type: text/plain
|
||||||
|
headers:
|
||||||
|
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
||||||
|
return_content: yes
|
||||||
|
register: post_document
|
||||||
|
failed_when: "'OK' not in post_document.content"
|
||||||
|
|
||||||
|
- name: verify uploaded document has been accepted
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000/api/logs/
|
||||||
|
headers:
|
||||||
|
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
||||||
|
return_content: yes
|
||||||
|
register: logs
|
||||||
|
failed_when: "'Consuming document.txt' not in logs.content"
|
||||||
|
|
||||||
|
# assumes txt consumption finished by now, might have to sleep a bit
|
||||||
|
- name: verify uploaded document has been consumed
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000/api/logs/
|
||||||
|
headers:
|
||||||
|
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
||||||
|
return_content: yes
|
||||||
|
register: logs
|
||||||
|
failed_when: "'document consumption finished' not in logs.content"
|
||||||
|
|
||||||
|
- name: verify uploaded document is avaiable
|
||||||
|
uri:
|
||||||
|
url: http://localhost:8000/api/documents/1/
|
||||||
|
headers:
|
||||||
|
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
||||||
|
return_content: yes
|
||||||
|
register: document
|
||||||
|
failed_when: "'Not found.' in document.content or 'FOO' not in document.content"
|
@ -105,46 +105,64 @@
|
|||||||
ignore_errors: yes
|
ignore_errors: yes
|
||||||
register: paperlessng_current_version
|
register: paperlessng_current_version
|
||||||
|
|
||||||
|
- name: register current state
|
||||||
|
set_fact:
|
||||||
|
fresh_installation: '{{ "No such file or directory" in paperlessng_current_version.stderr }}'
|
||||||
|
update_installation: '{{ "No such file or directory" not in paperlessng_current_version.stderr and paperlessng_current_version.stdout != paperlessng_version | string }}'
|
||||||
|
reconfigure_only: '{{ paperlessng_current_version.stdout == paperlessng_version | string }}'
|
||||||
|
|
||||||
- name: backup current paperless-ng installation
|
- name: backup current paperless-ng installation
|
||||||
copy:
|
copy:
|
||||||
src: "{{ paperlessng_directory }}"
|
src: "{{ paperlessng_directory }}"
|
||||||
remote_src: yes
|
remote_src: yes
|
||||||
dest: "{{ paperlessng_directory }}-{{ ansible_date_time.iso8601 }}/"
|
dest: "{{ paperlessng_directory }}-{{ ansible_date_time.iso8601 }}/"
|
||||||
when: '"No such file or directory" not in paperlessng_current_version.stderr and paperlessng_current_version.stdout != paperlessng_version | string'
|
when: update_installation
|
||||||
|
|
||||||
|
- name: remove current paperless sources
|
||||||
|
file:
|
||||||
|
path: "{{ paperlessng_directory }}/{{ item }}"
|
||||||
|
state: absent
|
||||||
|
with_items:
|
||||||
|
- docker
|
||||||
|
- docs
|
||||||
|
- scripts
|
||||||
|
- src
|
||||||
|
- static
|
||||||
|
when: update_installation
|
||||||
|
|
||||||
- name: create temporary directory
|
- name: create temporary directory
|
||||||
tempfile:
|
tempfile:
|
||||||
state: directory
|
state: directory
|
||||||
register: tempdir
|
register: tempdir
|
||||||
when: '"No such file or directory" in paperlessng_current_version.stderr or paperlessng_current_version.stdout != paperlessng_version | string'
|
when: not reconfigure_only
|
||||||
|
|
||||||
- name: extract paperless-ng
|
- name: extract paperless-ng
|
||||||
unarchive:
|
unarchive:
|
||||||
src: "https://github.com/jonaswinkler/paperless-ng/releases/download/ng-{{ paperlessng_version }}/paperless-ng-{{ paperlessng_version }}.tar.xz"
|
src: "https://github.com/jonaswinkler/paperless-ng/releases/download/ng-{{ paperlessng_version }}/paperless-ng-{{ paperlessng_version }}.tar.xz"
|
||||||
remote_src: yes
|
remote_src: yes
|
||||||
dest: "{{ tempdir.path }}"
|
dest: "{{ tempdir.path }}"
|
||||||
when: '"No such file or directory" in paperlessng_current_version.stderr or paperlessng_current_version.stdout != paperlessng_version | string'
|
when: not reconfigure_only
|
||||||
|
|
||||||
- name: change owner and permissions of paperless-ng
|
- name: change owner and permissions of paperless-ng
|
||||||
command:
|
command:
|
||||||
cmd: "{{ item }}"
|
cmd: "{{ item }}"
|
||||||
warn: false
|
warn: false
|
||||||
with_items:
|
with_items:
|
||||||
- "chown -R {{ paperlessng_system_user }}:{{ paperlessng_system_group }} {{ tempdir.path }}"
|
- "chown -R {{ paperlessng_system_user }}:{{ paperlessng_system_group }} {{ tempdir.path }}"
|
||||||
- "find {{ tempdir.path }} -type d -exec chmod 0750 {} ;"
|
- "find {{ tempdir.path }} -type d -exec chmod 0750 {} ;"
|
||||||
- "find {{ tempdir.path }} -type f -exec chmod 0640 {} ;"
|
- "find {{ tempdir.path }} -type f -exec chmod 0640 {} ;"
|
||||||
when: '"No such file or directory" in paperlessng_current_version.stderr or paperlessng_current_version.stdout != paperlessng_version | string'
|
when: not reconfigure_only
|
||||||
|
|
||||||
- name: move paperless-ng
|
- name: move paperless-ng
|
||||||
command:
|
command:
|
||||||
cmd: "cp -a {{ tempdir.path }}/paperless-ng/ {{ paperlessng_directory }}"
|
cmd: "cp -a {{ tempdir.path }}/paperless-ng/. {{ paperlessng_directory }}"
|
||||||
when: '"No such file or directory" in paperlessng_current_version.stderr or paperlessng_current_version.stdout != paperlessng_version | string'
|
when: not reconfigure_only
|
||||||
|
|
||||||
- name: remove temporary directory
|
- name: remove temporary directory
|
||||||
file:
|
file:
|
||||||
path: "{{ tempdir.path }}"
|
path: "{{ tempdir.path }}"
|
||||||
state: absent
|
state: absent
|
||||||
when: '"No such file or directory" in paperlessng_current_version.stderr or paperlessng_current_version.stdout != paperlessng_version | string'
|
when: not reconfigure_only
|
||||||
|
|
||||||
- name: create paperless-ng directories and set permissions
|
- name: create paperless-ng directories and set permissions
|
||||||
file:
|
file:
|
||||||
@ -281,7 +299,7 @@
|
|||||||
dest: /etc/paperless.conf
|
dest: /etc/paperless.conf
|
||||||
owner: root
|
owner: root
|
||||||
group: root
|
group: root
|
||||||
mode: '0644'
|
mode: "0644"
|
||||||
register: configuration
|
register: configuration
|
||||||
|
|
||||||
- name: create paperlessng venv
|
- name: create paperlessng venv
|
||||||
@ -299,15 +317,15 @@
|
|||||||
requirements: "{{ paperlessng_directory }}/requirements.txt"
|
requirements: "{{ paperlessng_directory }}/requirements.txt"
|
||||||
executable: "{{ paperlessng_virtualenv }}/bin/pip3"
|
executable: "{{ paperlessng_virtualenv }}/bin/pip3"
|
||||||
extra_args: --upgrade
|
extra_args: --upgrade
|
||||||
when: paperlessng_current_version.stdout != paperlessng_version | string
|
when: not reconfigure_only
|
||||||
|
|
||||||
- name: migrate database schema
|
- name: migrate database schema
|
||||||
become: yes
|
become: yes
|
||||||
become_user: "{{ paperlessng_system_user }}"
|
become_user: "{{ paperlessng_system_user }}"
|
||||||
command: "{{ paperlessng_virtualenv }}/bin/python3 {{ paperlessng_directory }}/src/manage.py migrate"
|
command: "{{ paperlessng_virtualenv }}/bin/python3 {{ paperlessng_directory }}/src/manage.py migrate"
|
||||||
when: paperlessng_current_version.stdout != paperlessng_version | string
|
|
||||||
register: database_schema
|
register: database_schema
|
||||||
changed_when: '"No migrations to apply." not in database_schema.stdout'
|
changed_when: '"No migrations to apply." not in database_schema.stdout'
|
||||||
|
when: not reconfigure_only
|
||||||
|
|
||||||
- name: configure paperless superuser
|
- name: configure paperless superuser
|
||||||
become: yes
|
become: yes
|
||||||
@ -336,7 +354,7 @@
|
|||||||
else:
|
else:
|
||||||
User.objects.create_superuser('{{ paperlessng_superuser_name }}', '{{ paperlessng_superuser_email }}', '{{ paperlessng_superuser_password }}')
|
User.objects.create_superuser('{{ paperlessng_superuser_name }}', '{{ paperlessng_superuser_email }}', '{{ paperlessng_superuser_password }}')
|
||||||
print('changed')
|
print('changed')
|
||||||
command: "{{ paperlessng_virtualenv }}/bin/python3 {{ paperlessng_directory }}/src/manage.py shell -c \"{{ creation_script }}\""
|
command: '{{ paperlessng_virtualenv }}/bin/python3 {{ paperlessng_directory }}/src/manage.py shell -c "{{ creation_script }}"'
|
||||||
register: superuser
|
register: superuser
|
||||||
changed_when: superuser.stdout == 'changed'
|
changed_when: superuser.stdout == 'changed'
|
||||||
no_log: yes
|
no_log: yes
|
||||||
@ -349,7 +367,7 @@
|
|||||||
owner: "{{ paperlessng_system_user }}"
|
owner: "{{ paperlessng_system_user }}"
|
||||||
group: "{{ paperlessng_system_group }}"
|
group: "{{ paperlessng_system_group }}"
|
||||||
mode: g-w,o-rwx
|
mode: g-w,o-rwx
|
||||||
when: venv.changed or paperlessng_current_version.stdout != paperlessng_version | string
|
when: venv.changed or not reconfigure_only
|
||||||
|
|
||||||
- name: configure ghostscript for PDF
|
- name: configure ghostscript for PDF
|
||||||
lineinfile:
|
lineinfile:
|
||||||
@ -372,34 +390,13 @@
|
|||||||
]
|
]
|
||||||
- [
|
- [
|
||||||
# https://www.freedesktop.org/software/systemd/man/systemd.exec.html
|
# https://www.freedesktop.org/software/systemd/man/systemd.exec.html
|
||||||
{
|
{ option: "User", value: "{{ paperlessng_system_user }}" },
|
||||||
option: "User",
|
{ option: "Group", value: "{{ paperlessng_system_group }}" },
|
||||||
value: "{{ paperlessng_system_user }}",
|
{ option: "WorkingDirectory", value: "{{ paperlessng_directory }}/src", },
|
||||||
},
|
{ option: "ProtectSystem", value: "full" },
|
||||||
{
|
{ option: "NoNewPrivileges", value: "true" },
|
||||||
option: "Group",
|
{ option: "PrivateUsers", value: "true" },
|
||||||
value: "{{ paperlessng_system_group }}",
|
{ option: "PrivateDevices", value: "true" },
|
||||||
},
|
|
||||||
{
|
|
||||||
option: "WorkingDirectory",
|
|
||||||
value: "{{ paperlessng_directory }}/src",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
option: "ProtectSystem",
|
|
||||||
value: "full",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
option: "NoNewPrivileges",
|
|
||||||
value: "true",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
option: "PrivateUsers",
|
|
||||||
value: "true",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
option: "PrivateDevices",
|
|
||||||
value: "true",
|
|
||||||
}
|
|
||||||
]
|
]
|
||||||
|
|
||||||
- name: configure paperless-consumer service
|
- name: configure paperless-consumer service
|
||||||
|
@ -55,6 +55,9 @@ Restoring
|
|||||||
Updating Paperless
|
Updating Paperless
|
||||||
##################
|
##################
|
||||||
|
|
||||||
|
Docker Route
|
||||||
|
============
|
||||||
|
|
||||||
If a new release of paperless-ng is available, upgrading depends on how you
|
If a new release of paperless-ng is available, upgrading depends on how you
|
||||||
installed paperless-ng in the first place. The releases are available at the
|
installed paperless-ng in the first place. The releases are available at the
|
||||||
`release page <https://github.com/jonaswinkler/paperless-ng/releases>`_.
|
`release page <https://github.com/jonaswinkler/paperless-ng/releases>`_.
|
||||||
@ -74,10 +77,10 @@ A. If you pull the image from the docker hub, all you need to do is:
|
|||||||
|
|
||||||
$ docker-compose pull
|
$ docker-compose pull
|
||||||
$ docker-compose up
|
$ docker-compose up
|
||||||
|
|
||||||
The docker-compose files refer to the ``latest`` version, which is always the latest
|
The docker-compose files refer to the ``latest`` version, which is always the latest
|
||||||
stable release.
|
stable release.
|
||||||
|
|
||||||
B. If you built the image yourself, do the following:
|
B. If you built the image yourself, do the following:
|
||||||
|
|
||||||
.. code:: shell-session
|
.. code:: shell-session
|
||||||
@ -91,13 +94,13 @@ Running `docker-compose up` will also apply any new database migrations.
|
|||||||
If you see everything working, press CTRL+C once to gracefully stop paperless.
|
If you see everything working, press CTRL+C once to gracefully stop paperless.
|
||||||
Then you can start paperless-ng with ``-d`` to have it run in the background.
|
Then you can start paperless-ng with ``-d`` to have it run in the background.
|
||||||
|
|
||||||
Updating paperless without docker
|
Bare Metal Route
|
||||||
=================================
|
================
|
||||||
|
|
||||||
After grabbing the new release and unpacking the contents, do the following:
|
After grabbing the new release and unpacking the contents, do the following:
|
||||||
|
|
||||||
1. Update dependencies. New paperless version may require additional
|
1. Update dependencies. New paperless version may require additional
|
||||||
dependencies. The dependencies required are listed in the section about
|
dependencies. The dependencies required are listed in the section about
|
||||||
:ref:`bare metal installations <setup-bare_metal>`.
|
:ref:`bare metal installations <setup-bare_metal>`.
|
||||||
|
|
||||||
2. Update python requirements. If you use Pipenv, this is done with the following steps.
|
2. Update python requirements. If you use Pipenv, this is done with the following steps.
|
||||||
@ -114,18 +117,50 @@ After grabbing the new release and unpacking the contents, do the following:
|
|||||||
|
|
||||||
You can also use the included ``requirements.txt`` file instead and create the virtual
|
You can also use the included ``requirements.txt`` file instead and create the virtual
|
||||||
environment yourself. This file includes exactly the same dependencies.
|
environment yourself. This file includes exactly the same dependencies.
|
||||||
|
|
||||||
3. Migrate the database.
|
3. Migrate the database.
|
||||||
|
|
||||||
.. code:: shell-session
|
.. code:: shell-session
|
||||||
|
|
||||||
$ cd src
|
$ cd src
|
||||||
$ pipenv run python3 manage.py migrate
|
$ pipenv run python3 manage.py migrate
|
||||||
|
|
||||||
This might not actually do anything. Not every new paperless version comes with new
|
This might not actually do anything. Not every new paperless version comes with new
|
||||||
database migrations.
|
database migrations.
|
||||||
|
|
||||||
|
Ansible Route
|
||||||
|
=============
|
||||||
|
|
||||||
|
Most of the update process is automated when using the ansible role.
|
||||||
|
|
||||||
|
1. Backup your defined role variables file outside the paperless source-tree:
|
||||||
|
|
||||||
|
.. code:: shell-session
|
||||||
|
|
||||||
|
$ cp ansible/vars.yml ~/vars.yml.old
|
||||||
|
|
||||||
|
2. Pull the release tag you want to update to:
|
||||||
|
|
||||||
|
.. code:: shell-session
|
||||||
|
|
||||||
|
$ git fetch --all
|
||||||
|
$ git checkout ng-0.9.14
|
||||||
|
|
||||||
|
3. Update the role variable definitions ``ansible/vars.yml`` (where appropriate).
|
||||||
|
|
||||||
|
4. Run the ansible playbook you created created during :ref:`installation <setup-ansible>` again:
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
When ansible detects that an update run is in progress, it backs up the entire ``paperlessng_directory`` to ``paperlessng_directory-TIMESTAMP``.
|
||||||
|
Updates can be rolled back by simply moving the timestamped folder back to the original location.
|
||||||
|
If the update succeeds and you want to continue using the new release, please don't forget to delete the backup folder.
|
||||||
|
|
||||||
|
.. code:: shell-session
|
||||||
|
|
||||||
|
$ ansible-playbook playbook.yml
|
||||||
|
|
||||||
|
|
||||||
Management utilities
|
Management utilities
|
||||||
####################
|
####################
|
||||||
|
|
||||||
@ -386,7 +421,7 @@ Documents can be stored in Paperless using GnuPG encryption.
|
|||||||
Furthermore, the entire text content of the documents is stored plain in the
|
Furthermore, the entire text content of the documents is stored plain in the
|
||||||
database, even if your documents are encrypted. Filenames are not encrypted as
|
database, even if your documents are encrypted. Filenames are not encrypted as
|
||||||
well.
|
well.
|
||||||
|
|
||||||
Also, the web server provides transparent access to your encrypted documents.
|
Also, the web server provides transparent access to your encrypted documents.
|
||||||
|
|
||||||
Consider running paperless on an encrypted filesystem instead, which will then
|
Consider running paperless on an encrypted filesystem instead, which will then
|
||||||
@ -411,4 +446,4 @@ Basic usage to disable encryption of your document store:
|
|||||||
decrypt_documents [--passphrase SECR3TP4SSPHRA$E]
|
decrypt_documents [--passphrase SECR3TP4SSPHRA$E]
|
||||||
|
|
||||||
|
|
||||||
.. _Pipenv: https://pipenv.pypa.io/en/latest/
|
.. _Pipenv: https://pipenv.pypa.io/en/latest/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user