Wei S. 85a526d1b6 User api key: JSON rate limiting message & status code (#87)
* feat(auth): Implement API key authentication

This commit enables API access with an API key system. This change provides a better experience for programmatic access and third-party integrations.

Key changes include:
- **API Key Management:** Users can now generate, manage, and revoke persistent API keys through a new "API Keys" section in the settings UI.
- **Authentication Middleware:** API requests are now authenticated via an `X-API-KEY` header instead of the previous `Authorization: Bearer` token.
- **Backend Implementation:** Adds a new `api_keys` database table, along with corresponding services, controllers, and routes to manage the key lifecycle securely.
- **Rate Limiting:** The API rate limiter now uses the API key to identify and track requests.
- **Documentation:** The API authentication documentation has been updated to reflect the new method.

* Add configurable API rate limiting

Two new variables are added to `.env.example`:
- `RATE_LIMIT_WINDOW_MS`: The time window in milliseconds for which requests are checked (defaults to 15 minutes).
- `RATE_LIMIT_MAX_REQUESTS`: The maximum number of requests allowed from an IP within the window (defaults to 100).

The installation documentation has been updated to reflect these new configuration options.

* Disable API operation in demo mode

* Exclude public API endpoints from rate limiting

* JSON rate limiting message & status code

---------

Co-authored-by: Wayne <5291640+ringoinca@users.noreply.github.com>
2025-09-04 17:32:43 +03:00
2025-08-24 15:05:15 +03:00
2025-08-01 19:54:23 +03:00
2025-07-24 23:43:38 +03:00
2025-07-27 21:28:51 +03:00
2025-08-15 14:14:01 +03:00
2025-08-15 14:14:01 +03:00
2025-08-15 13:45:58 +03:00
2025-09-01 12:44:22 +03:00
2025-07-15 00:48:40 +03:00
2025-08-15 14:18:23 +03:00
2025-08-15 14:18:23 +03:00
2025-08-15 14:18:23 +03:00
2025-08-15 14:18:23 +03:00
2025-08-15 14:18:23 +03:00

Open Archiver

Docker Compose PostgreSQL Meilisearch TypeScript Redis SvelteKit

A secure, sovereign, and open-source platform for email archiving and eDiscovery.

Open Archiver provides a robust, self-hosted solution for archiving, storing, indexing, and searching emails from major platforms, including Google Workspace (Gmail), Microsoft 365, PST files, as well as generic IMAP-enabled email inboxes. Use Open Archiver to keep a permanent, tamper-proof record of your communication history, free from vendor lock-in.

📸 Screenshots

Open Archiver Preview Dashboard

Open Archiver Preview Archived emails

Open Archiver Preview Full-text search across all your emails and attachments

👨‍👩‍👧‍👦 Join our community!

We are committed to build an engaging community around Open Archiver, and we are inviting all of you to join our community on Discord to get real-time support and connect with the team.

Discord

Bluesky

🚀 Live demo

Check out the live demo here: https://demo.openarchiver.com

Username: admin@local.com

Password: openarchiver_demo

Key Features

  • Universal Ingestion: Connect to any email provider to perform initial bulk imports and maintain continuous, real-time synchronization. Ingestion sources include:

    • IMAP connection
    • Google Workspace
    • Microsoft 365
    • PST files
    • Zipped .eml files
  • Secure & Efficient Storage: Emails are stored in the standard .eml format. The system uses deduplication and compression to minimize storage costs. All data is encrypted at rest.

  • Pluggable Storage Backends: Support both local filesystem storage and S3-compatible object storage (like AWS S3 or MinIO).

  • Powerful Search & eDiscovery: A high-performance search engine indexes the full text of emails and attachments (PDF, DOCX, etc.).

  • Thread discovery: The ability to discover if an email belongs to a thread/conversation and present the context.

  • Compliance & Retention: Define granular retention policies to automatically manage the lifecycle of your data. Place legal holds on communications to prevent deletion during litigation (TBD).

  • Comprehensive Auditing: An immutable audit trail logs all system activities, ensuring you have a clear record of who accessed what and when (TBD).

🛠️ Tech Stack

Open Archiver is built on a modern, scalable, and maintainable technology stack:

  • Frontend: SvelteKit with Svelte 5
  • Backend: Node.js with Express.js & TypeScript
  • Job Queue: BullMQ on Redis for robust, asynchronous processing. (We use Valkey as the Redis service in the Docker Compose deployment mode, but you can use Redis as well.)
  • Search Engine: Meilisearch for blazingly fast and resource-efficient search
  • Database: PostgreSQL for metadata, user management, and audit logs
  • Deployment: Docker Compose deployment

📦 Deployment

Prerequisites

  • Docker and Docker Compose
  • A server or local machine with at least 4GB of RAM (2GB of RAM if you use external Postgres, Redis (Valkey) and Meilisearch instances).

Installation

  1. Clone the repository:

    git clone https://github.com/LogicLabs-OU/OpenArchiver.git
    cd open-archiver
    
  2. Configure your environment: Copy the example environment file and customize it with your settings.

    cp .env.example .env
    

    You will need to edit the .env file to set your admin passwords, secret keys, and other essential configuration. Read the .env.example for how to set up.

  3. Run the application:

    docker compose up -d
    

    This command will pull the pre-built Docker images and start all the services (frontend, backend, database, etc.) in the background.

  4. Access the application: Once the services are running, you can access the Open Archiver web interface by navigating to http://localhost:3000 in your web browser.

⚙️ Data Source Configuration

After deploying the application, you will need to configure one or more ingestion sources to begin archiving emails. Follow our detailed guides to connect to your email provider:

🤝 Contributing

We welcome contributions from the community!

  • Reporting Bugs: If you find a bug, please open an issue on our GitHub repository.
  • Suggesting Enhancements: Have an idea for a new feature? We'd love to hear it. Open an issue to start the discussion.
  • Code Contributions: If you'd like to contribute code, please fork the repository and submit a pull request.

Please read our CONTRIBUTING.md file for more details on our code of conduct and the process for submitting pull requests.

📈 Star History

Star History Chart

Description
No description provided
Readme AGPL-3.0 14 MiB
Languages
TypeScript 55.6%
Svelte 40.9%
JavaScript 2.6%
CSS 0.6%
Dockerfile 0.2%