MCPcopy
hub / github.com/paperless-ngx/paperless-ngx

github.com/paperless-ngx/paperless-ngx @v2.20.15 sqlite

repository ↗ · DeepWiki ↗ · release v2.20.15 ↗
5,188 symbols 20,677 edges 755 files 1,015 documented · 20%
README

ci Crowdin Documentation Status codecov Chat on Matrix demo

<img src="https://github.com/paperless-ngx/paperless-ngx/raw/main/resources/logo/web/png/Black%20logo%20-%20no%20background.png" width="50%">

Paperless-ngx

Paperless-ngx is a document management system that transforms your physical documents into a searchable online archive so you can keep, well, less paper.

Paperless-ngx is the official successor to the original Paperless & Paperless-ng projects and is designed to distribute the responsibility of advancing and supporting the project among a team of people. Consider joining us!

Thanks to the generous folks at DigitalOcean, a demo is available at demo.paperless-ngx.com using login demo / demo. Note: demo content is reset frequently and confidential information should not be uploaded.

This project is supported by:

  <img src="https://opensource.nyc3.cdn.digitaloceanspaces.com/attribution/assets/SVG/DO_Logo_horizontal_black_.svg" width="140px">

Features

A full list of features and screenshots are available in the documentation.

Getting started

The easiest way to deploy paperless is docker compose. The files in the /docker/compose directory are configured to pull the image from the GitHub container registry.

If you'd like to jump right in, you can configure a docker compose environment with our install script:

bash -c "$(curl -L https://raw.githubusercontent.com/paperless-ngx/paperless-ngx/main/install-paperless-ngx.sh)"

More details and step-by-step guides for alternative installation methods can be found in the documentation.

Migrating from Paperless-ng is easy, just drop in the new docker image! See the documentation on migrating for more details.

Documentation

The documentation for Paperless-ngx is available at https://docs.paperless-ngx.com.

Contributing

If you feel like contributing to the project, please do! Bug fixes, enhancements, visual fixes etc. are always welcome. If you want to implement something big: Please start a discussion about that! The documentation has some basic information on how to get started.

Community Support

People interested in continuing the work on paperless-ngx are encouraged to reach out here on github and in the Matrix Room. If you would like to contribute to the project on an ongoing basis there are multiple teams (frontend, ci/cd, etc) that could use your help so please reach out!

Translation

Paperless-ngx is available in many languages that are coordinated on Crowdin. If you want to help out by translating paperless-ngx into your language, please head over to https://crowdin.com/project/paperless-ngx, and thank you! More details can be found in CONTRIBUTING.md.

Feature Requests

Feature requests can be submitted via GitHub Discussions, you can search for existing ideas, add your own and vote for the ones you care about.

Bugs

For bugs please open an issue or start a discussion if you have questions.

Related Projects

Please see the wiki for a user-maintained list of related projects and software that is compatible with Paperless-ngx.

Important Note

Document scanners are typically used to scan sensitive documents like your social insurance number, tax records, invoices, etc. Paperless-ngx should never be run on an untrusted host because information is stored in clear text without encryption. No guarantees are made regarding security (but we do try!) and you use the app at your own risk. The safest way to run Paperless-ngx is on a local server in your own home with backups in place.

Extension points exported contracts — how you extend this code

ComponentCanDeactivate (Interface)
(no doc) [2 implementers]
src-ui/src/app/guards/dirty-doc.guard.ts
SortEvent (Interface)
(no doc)
src-ui/src/app/directives/sortable.directive.ts
ManagementListColumn (Interface)
(no doc)
src-ui/src/app/components/manage/management-list/management-list.component.ts
TriggerFilterDefinition (Interface)
(no doc)
src-ui/src/app/components/common/edit-dialog/workflow-edit-dialog/workflow-edit-dialog.component.ts
FilterHandler (Interface)
(no doc)
src-ui/src/app/components/common/edit-dialog/workflow-edit-dialog/workflow-edit-dialog.component.ts

Core symbols most depended-on inside this repo

create
called by 1242
src/documents/serialisers.py
get
called by 681
src/documents/views.py
filter
called by 505
src/documents/filters.py
get
called by 409
src-ui/src/app/components/common/filterable-dropdown/filterable-dropdown.component.ts
save
called by 301
src/documents/caching.py
post
called by 268
src/documents/views.py
open
called by 203
src/documents/tests/utils.py
patch
called by 182
src/paperless/views.py

Shape

Method 3,328
Class 1,094
Function 450
Route 199
Interface 63
Enum 54

Languages

Python66%
TypeScript34%

Modules by API surface

src/documents/serialisers.py180 symbols
src/documents/tests/test_api_documents.py117 symbols
src/documents/views.py113 symbols
src/documents/tests/test_workflows.py104 symbols
src/paperless_mail/tests/test_mail.py101 symbols
src/documents/tests/test_consumer.py98 symbols
src/documents/tests/test_api_bulk_edit.py84 symbols
src/documents/models.py79 symbols
src-ui/src/app/components/document-detail/document-detail.component.ts73 symbols
src/documents/tests/test_file_handling.py71 symbols
src-ui/src/app/components/common/filterable-dropdown/filterable-dropdown.component.ts68 symbols
src/documents/tests/test_bulk_edit.py61 symbols

Dependencies from manifests, versioned

@angular-builders/custom-webpack20.0.0 · 1×
@angular-devkit/core20.3.13 · 1×
@angular-devkit/schematics20.3.13 · 1×
@angular-eslint/builder20.6.0 · 1×
@angular-eslint/eslint-plugin20.6.0 · 1×
@angular-eslint/eslint-plugin-template20.6.0 · 1×
@angular-eslint/schematics20.6.0 · 1×
@angular-eslint/template-parser20.6.0 · 1×
@angular/build20.3.13 · 1×
@angular/cdk20.2.13 · 1×
@angular/cli20.3.13 · 1×

For agents

$ claude mcp add paperless-ngx \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact