Admin/settings panel for Maddy
Go to file
Lea 9940611d9b
Some checks failed
Docker Build / publish (push) Failing after 1s
Update .forgejo/workflows/docker-build.yml
2024-06-16 22:02:09 +00:00
.assets edit readme 2024-01-24 21:50:04 +01:00
.forgejo/workflows Update .forgejo/workflows/docker-build.yml 2024-06-16 22:02:09 +00:00
.vscode
public
src KITYYY!! 2024-06-16 23:44:32 +02:00
.dockerignore
.env Add audit log 2024-01-18 16:53:17 +01:00
.eslintrc.json
.gitignore
Dockerfile update docker image to node 20 2024-01-23 23:54:46 +01:00
LICENSE.md Add license 2024-05-03 19:45:18 +02:00
next.config.js
package.json forgot the packages woop 2024-01-23 23:45:33 +01:00
pnpm-lock.yaml forgot the packages woop 2024-01-23 23:45:33 +01:00
postcss.config.js
README.md [skip ci] fix typo in readme 2024-01-25 20:18:11 +01:00
tailwind.config.ts fix styles in production 2024-01-18 01:09:36 +01:00
tsconfig.json

Maddy Admin Panel

A front-end for Maddy, allowing users to manage their account and administrators to manage the server.

Screenshots

Self-Service account management

Administration

Aliases

Users

Audit Log

Features

  • Password management - Users can easily update their account password
  • Aliases - Users can create and manage their own aliases
    • Normal aliases allow the user to freely choose their alias address from a list of domains. An administrator needs to approve the alias before it can be used.
    • Temporary aliases are randomly generated and can be created by users without administrator approval. It's like a tempmail service, but cooler!
  • Administration - Admins can easily perform common tasks
    • Creating users, deleting users and resetting their password (todo)
    • Creating and deleting aliases for any user

Authentication is handled using the same database that Maddy uses, so users can use the same password to access their email and the Admin Panel.

notes to add later

CREATE TABLE aliases (id INTEGER PRIMARY KEY AUTOINCREMENT, address TEXT NOT NULL, alias TEXT NOT NULL, pending INTEGER DEFAULT 0, temporary INTEGER DEFAULT 0);
CREATE TABLE temp_alias_requests (key TEXT PRIMARY KEY, address TEXT NOT NULL, alias TEXT NOT NULL, expires INTEGER NOT NULL);

CREATE TABLE api_keys (id INTEGER PRIMARY KEY AUTOINCREMENT, address TEXT NOT NULL, label TEXT NOT NULL, token TEXT NOT NULL);