https://github.com/sparkymat/archmark
archmark is a bookmark manager that archives bookmarks
https://github.com/sparkymat/archmark
Last synced: 3 months ago
JSON representation
archmark is a bookmark manager that archives bookmarks
- Host: GitHub
- URL: https://github.com/sparkymat/archmark
- Owner: sparkymat
- License: other
- Created: 2021-09-30T10:24:37.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-06-15T22:51:20.000Z (8 months ago)
- Last Synced: 2024-08-05T08:09:46.367Z (7 months ago)
- Language: TypeScript
- Homepage:
- Size: 7.36 MB
- Stars: 43
- Watchers: 3
- Forks: 1
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ArchMark [data:image/s3,"s3://crabby-images/f3864/f38645c99e81e9b8f834605ff1701d3a997a7abf" alt=".github/workflows/ci.yml"](https://github.com/sparkymat/archmark/actions/workflows/ci.yml)
ArchMark is a bookmark manager that archives the bookmarked page using [Monolith](https://github.com/Y2Z/monolith). It consists of the main web proccess as well as a worker that downloads the web page for archival.
## Features
- Allows links to be bookmarked and categorized
- Supports local (password-based) login and registration, and reverse-proxy-based authentication (with forwarded headers)
- Caches a local copy of the bookmarked page (available via the 'cached' link below the original)
- Keeps deleted bookmarks in the "deleted" section for a period of time before deleting it (defaults to 48 hours); they can be restored before the timer hits
- Allows searching across content in the bookmarked links (a copy of the linked page is cached for search indexing)## Installation
The simplest way to use ArchMark would be to use docker-compose. If you have [Docker](https://docs.docker.com/engine/install/) and [Docker Compose](https://docs.docker.com/compose/install/) installed, you can follow the steps below to get up and running:
1. `mkdir archmark`
2. `cd archmark`
3. `curl https://raw.githubusercontent.com/sparkymat/archmark/main/docker-compose.prod.yml -o docker-compose.yml`
4. `mkdir -p data/db`
5. `mkdir -p data/faktory`
6. `mkdir -p data/archive`
7. `docker-compose pull`
8. `docker-compose up`Alternatively, you can build and run from the code with:
1. `git clone https://github.com/sparkymat/archmark`
2. `cd archmark`
3. `docker-compose build`
4. `docker-compose up`P.S: Don't forget to edit the `docker-compose.yml` file, and update the value of `JWT_SECRET` and `SESSION_SECRET` to something more secure. You can generate secrets using openssl like this:
```
openssl rand -hex 32
```N.B: Everything in the download folder (configured using `DOWNLOAD_FOLDER`) will be served under `/uploads/` sub-path.
## Configuration
Both the app and the worker are configured using environment variables.
| Variable | Description |
| ------------------------------ | --------------------------------------------------------------------------------------------- |
| `DISABLE_REGISTRATION` | Set to 'true' if you want to disable registrations |
| `REVERSE_PROXY_AUTHENTICATION` | Enables reverse proxy authentication via forwarded headers |
| `PROXY_AUTH_USERNAME_HEADER` | The request header where proxy passes the usernamae. Default: `Remote-User` |
| `PROXY_AUTH_NAME_HEADER` | The request header where proxy passes the full name. Default: `Remote-Name` |
| `DELETE_TIMER_HOURS` | Time (in hours) before deleted items are flushed from the recycle bin (**default**: 48 hours) |## Screenshots
### Login page
data:image/s3,"s3://crabby-images/5acf0/5acf0b08ceb780af40991f99af15a2acb1e1b8ee" alt="login"
### Bookmarks
data:image/s3,"s3://crabby-images/f8c3b/f8c3be1438303fa4bf559c731e7691336426a602" alt="bookmarks"
### Options
data:image/s3,"s3://crabby-images/c4058/c4058a082cada494406b0139b5cc520aea8a036a" alt="options"
### New bookmark
data:image/s3,"s3://crabby-images/ba89f/ba89f3c153082af4fee83b9542e1a7b1823d6278" alt="new"
### Change category
data:image/s3,"s3://crabby-images/ed3bc/ed3bca169e46c856c8666de326bf3fedce599ff7" alt="change_category"
### Deleted
data:image/s3,"s3://crabby-images/e4c4e/e4c4e9b0f4d856d3c1d536fc99cd2ff1f2443f3a" alt="deleted"