Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/steiza/docstore
For any civics-minded organization that needs a simple place to host documents publicly
https://github.com/steiza/docstore
Last synced: 3 months ago
JSON representation
For any civics-minded organization that needs a simple place to host documents publicly
- Host: GitHub
- URL: https://github.com/steiza/docstore
- Owner: steiza
- Created: 2016-02-05T04:36:56.000Z (almost 9 years ago)
- Default Branch: main
- Last Pushed: 2022-03-28T22:17:15.000Z (almost 3 years ago)
- Last Synced: 2023-03-11T11:47:14.191Z (almost 2 years ago)
- Language: Python
- Homepage: http://a2docs.org/
- Size: 564 KB
- Stars: 6
- Watchers: 5
- Forks: 4
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Doc Store
[![flake8 linting](https://github.com/steiza/docstore/actions/workflows/run_flake8.yml/badge.svg)](https://github.com/steiza/docstore/actions/workflows/run_flake8.yml)
[![integration tests](https://github.com/steiza/docstore/actions/workflows/integration_tests.yml/badge.svg)](https://github.com/steiza/docstore/actions/workflows/integration_tests.yml)
This project is meant for any civics-minded organization that needs a simple place to host documents publicly.
On the homepage you can see recently uploaded documents:
![Recently uploaded documents](https://raw.github.com/steiza/docstore/main/readme_images/home_page.png)
There's a search page that will search through the document metadata (but not the document contents):
![Search page](https://raw.github.com/steiza/docstore/main/readme_images/search.png)
Clicking on a document will take you to a page with document details and a download link:
![Document detail page](https://raw.github.com/steiza/docstore/main/readme_images/doc.png)
And there's a basic password protected management page to clean up details or delete documents if needed:
![Management page](https://raw.github.com/steiza/docstore/main/readme_images/edit.png)
Document metadata is stored in an on-disk sqlite database and the files themselves are stored on disk.
### Run the software
If you want to run your own version, after you check out the repository you'll need to create a basic `settings.yml` file::
```
region: 'My City'
password: '__make_your_own_management_password__'
cookie_secret: '__this_can_be_anything_it_is_just_for_the_server__'
google_analytics_id: '__optional_just_remove_this_line_if_not_needed__'
max_file_size: '__optional_maximum_upload_size_allowed__'
```Then run the server:
```
./docstore
```Note that this project uses HTTP Basic auth - if you host this project without HTTPS the management password will be sent over the network in the clear. Ideally, run this server behind a reverse proxy like nginx which performs TLS termination for you.
### Installing dependencies
Using pipenv:
```
pipenv install -r requirements.txt
```