madebyraygun / pssst
A lightweight single-user application to securely submit and retrieve information via the web.
Installs: 4
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Type:project
pkg:composer/madebyraygun/pssst
Requires
- php: >=8.2.0
- bramus/router: ^1.6
- jiripudil/otp: ^1.0
- mailgun/mailgun-php: ^4.3
- nyholm/psr7: ^1.8
- picocss/pico: ^2.0
- symfony/http-client: ^7.1
- twig/twig: ^3.0
- vlucas/phpdotenv: ^5.6
README
A lightweight PHP-based application to securely submit and retrieve information such as passwords via the web. No database required. Keep your secrets out of email and Slack!
With the TOTP authentication and administrator email features enabled, this app functions as a single-user secret request form. (Meaning, only the administrator can get notified and retrieve secrets). By turning these features off, anyone can use the system to generate a secret, copy the generated link, and send via any secure channel.
Note This application is still in development, and, given the presumably sensitive nature of the message contents, should be used with caution.
Installation
Upload the source files to a web server running PHP 8.2 or later, or use a local web server such as DDEV (configuration included) to test the application. If you're using a web server other than DDEV, make sure you set the public folder as the html root.
From the terminal:
composer install
cp .env.example .env
Edit the .env file to update the app settings. Include your Cloudflare Turnstile site key and Mailgun credentials (recommended but optional).
Optional
If you want to use a time-based OTP to protect your secrets, set TOTP_ACTIVE to "true" and generate an OPT key with the following terminal command:
echo "TOTP_SECRET=\"$(LC_ALL=C tr -dc 'A-Z2-7' </dev/urandom | head -c 32)\"" >> .env
Other configuration options
Choose a color theme by setting the APP_THEME setting. See https://picocss.com/docs/version-picker for available themes.
Upload a logo.png file to the public\assets\ directory to set a custom logo. Use the filenames logo-light.png and logo-dark.png to set different logos for light and dark mode.
Disable the Github repo link by setting SHOW_GITHUB_LINK to false.
Usage
On first run, if you're using TOPT, generate your authenticator secret at /generate-totp. This is a unique secret that is based on your admin email address and the TOTP_SECRET value in your .env file. You will use the dynamically generated 6 digit code to retrieve and delete secrets. Save this URL to your authenticator program.
Extremly important note
The generate-totp endpoint is only available when the app is in "dev" mode. It is extremely important that you only run the publicly accessible site in "production" mode. Running a publicly accessible site in "dev" mode can expose your TOTP authentication credentials. If you make this mistake, be sure to regenerate your TOTP_SECRET key and update your authenticator.
Create a new secret using the form at the main URL of your application. The secret contents will be saved as a JSON file in the data folder, and the contents of the message will be encrypted wi a "key" that is included in the retrieve URL. The server administrator cannot view the contents of the secret without that key.
A URL will be generated to retrieve the secret. If you've set up Mailgun, the URL will be emailed to the administrator. Otherwise, the URL will be displayed on the /created/ page after the secret has been successfully saved.
The retrieve endpoint is protected by the TOTP authentication you set up earlier. Enter your code to view and delete your secrets.
Roadmap
- Add automatic time-based expiration of secrets
- Add "delete after view" for secrets
- Add translation support
- Security review