Keep passwords and other sensitive information out of your inboxes and chat logs.
Note
Skip to Installation instructions.
A onetime secret is a link that can be viewed only once. A single-use URL.
Try it out on OnetimeSecret.com!
When you send people sensitive info like passwords and private links via email or chat, there are copies of that information stored in many places. If you use a Onetime link instead, the information persists for a single viewing which means it can't be read by someone else later. This allows you to send sensitive information in a safe way knowing it's seen by one person only. Think of it like a self-destructing message.
Get the Latest Release (Recommended)
This is the actively developed and maintained version with the most recent features and security updates.
Ruby 3 without Node.js: v0.15.0
- If you prefer a simpler setup with just Ruby dependencies (i.e. without Node.js dependencies) this is the most recent version.
- No security updates or bug fixes will be provided for this version.
Ruby 2.7, 2.6 (Legacy - Not Supported): v0.12.1
⚠️ Warning: This version is no longer maintained or supported.- Only use if you absolutely cannot run Ruby 3+.
- No security updates or bug fixes will be provided for this version.
We strongly recommend using the latest release with Ruby 3+ for the best performance, security, and feature set. Legacy Ruby 2.x versions are provided for reference only and should be avoided in production environments.
- Any recent linux distro (we use debian) or *BSD or MacOS
- System dependencies:
- Ruby 3.1+ (3.0 may work but is not officially supported)
- Redis server 5+
- Node.js 22+ (for front-end development)
- pnpm 9.0.0+
- Additional packages:
- build-essential
- libyaml-dev
- libffi-dev
- Minimum specs:
- 2 core CPU (or equivalent)
- 1GB memory
- 4GB disk
There are multiple ways to run OnetimeSecret using Docker. Choose the method that best suits your needs:
We offer pre-built images on both GitHub Container Registry and Docker Hub.
# Pull from GitHub Container Registry
docker pull ghcr.io/onetimesecret/onetimesecret:latest
# OR, pull from Docker Hub
docker pull onetimesecret/onetimesecret:latest
If you prefer to build the image yourself:
git clone https://github.com/onetimesecret/onetimesecret.git
cd onetimesecret
docker build -t onetimesecret .
For environments requiring multi-architecture support:
git clone https://github.com/onetimesecret/onetimesecret.git
cd onetimesecret
docker buildx build --platform=linux/amd64,linux/arm64 . -t onetimesecret
We also offer a "lite" version of the Docker image, which is optimized for quicker deployment and reduced resource usage. To use the lite version:
# Pull the lite image
docker pull ghcr.io/onetimesecret/onetimesecret:latest-lite
# OR, build it locally
docker build -f Dockerfile-lite -t onetimesecret:lite .
For more information on the lite Docker image, refer to the DOCKER-lite.md documentation.
Regardless of how you obtained or built the image, follow these steps to run OnetimeSecret:
-
Start a Redis container:
docker run -p 6379:6379 -d redis:bookworm
-
Set essential environment variables:
export HOST=localhost:3000 export SSL=false export COLONEL=admin@example.com export REDIS_URL=redis://host.docker.internal:6379/0 export RACK_ENV=production
Note: The
COLONEL
variable sets the admin account email. It's a playful combination of "colonel" (someone in charge) and "kernel" (as in Linux), representing the system administrator. -
Run the OnetimeSecret container:
docker run -p 3000:3000 -d --name onetimesecret \ -e REDIS_URL=$REDIS_URL \ -e COLONEL=$COLONEL \ -e HOST=$HOST \ -e SSL=$SSL \ -e RACK_ENV=$RACK_ENV \ onetimesecret/onetimesecret:latest
Note: Replace
onetimesecret/onetimesecret:latest
with your image name if you built it locally.
OnetimeSecret should now be running and accessible at http://localhost:3000
.
If you prefer to work with the source code directly, you can install OnetimeSecret manually. Follow these steps:
Choose one of these methods:
-
Download the latest release
-
Clone the repository:
git clone https://github.com/onetimesecret/onetimesecret.git
Follow these general steps to install the required system dependencies:
- Install Redis Server 5+
- Install Ruby 3.1+ and bundler 2.5*
- Install Node.js 20+ and pnpm 9.2+
- Install additional required packages: build-essential, libyaml-dev, libffi-dev
For Debian/Ubuntu systems, you can use the following commands:
# Update package list and install basic dependencies
sudo apt update
sudo apt install -y git redis-server build-essential libyaml-dev libffi-dev
# Install Ruby 3.1
sudo apt install -y ruby3.1 ruby3.1-dev
# Install Node.js and pnpm
curl -fsSL https://deb.nodesource.com/setup_22.x | sudo -E bash -
sudo apt install -y nodejs
sudo npm install -g pnpm@latest
Note: After installation, make sure Redis is running with service redis-server status
. Start it if needed with service redis-server start
.
For other operating systems, please refer to the official documentation for each dependency to install the correct versions.
cd onetimesecret
git rev-parse --short HEAD > .commit_hash.txt
cp --preserve --no-clobber ./etc/config.example.yaml ./etc/config.yaml
sudo gem install bundler
bundle config set --local without 'development test'
bundle update --bundler
bundle install
pnpm install --frozen-lockfile
pnpm run build
There are two main ways to run the application, depending on your development needs:
-
For production or simple development without frontend changes:
RACK_ENV=production bundle exec thin -R config.ru -p 3000 start
Or, for a development environment with a static frontend and Ruby live reloading:
RACK_ENV=development bundle exec thin -R config.ru -p 3000 start
Ensure
development.enabled
is set tofalse
inetc/config.yaml
::development: :enabled: false
This uses pre-built frontend assets in the
dist/assets
directory.
-
Set
development.enabled
totrue
inetc/config.yaml
::development: :enabled: true
-
Run the Thin server in development mode:
RACK_ENV=development bundle exec thin -R config.ru -p 3000 start
-
In a separate terminal, start the Vite dev server:
pnpm run dev
This enables live reloading of frontend assets.
The application determines whether to use development or production assets based on the development.enabled
setting. In development mode with the Vite server running, frontend assets are loaded dynamically:
{{#frontend_development}}
<script type="module" src="{{ frontend_host }}/dist/main.ts"></script>
<script type="module" src="{{ frontend_host }}/dist/@vite/client"></script>
{{/frontend_development}}
In production mode, it uses the built files in dist/assets
:
{{^frontend_development}}
{{{vite_assets}}}
{{/frontend_development}}
Choose the option that best fits your development workflow and needs.
OnetimeSecret requires a config.yaml
file for all installations. Environment variables can be used to override specific settings, but the config.yaml
file must always be present.
-
Create the configuration file:
cp --preserve --no-clobber ./etc/config.example.yaml ./etc/config.yaml
-
Review and edit
./etc/config.yaml
as needed. At minimum, update the secret key and back it up securely.
The ./etc/config.yaml
file is the primary configuration method. It uses ERB syntax to incorporate environment variables, allowing for flexible configuration:
---
:site:
:host: <%= ENV['HOST'] || 'localhost:7143' %>
:domains:
:enabled: <%= ENV['DOMAINS_ENABLED'] || false %>
In this format:
- If an environment variable (e.g.,
HOST
) is set, its value will be used. - If the environment variable is not set, the fallback value (e.g., 'localhost:7143') will be used.
- If you remove the ERB syntax and environment variable reference, only the literal value in the config will be used.
Key areas to configure in config.yaml
:
- SMTP or SendGrid for email
- Redis connection details
- Rate limits
- Enabled locales
For quick setups or container deployments, you can use environment variables to override config.yaml
settings:
export HOST=localhost:3000
export SSL=false
export COLONEL=admin@example.com
export REDIS_URL=redis://username:password@hostname:6379/0
export RACK_ENV=production
For various deployment scenarios, including Docker setups and local development, you can use a .env
file to set environment variables:
-
Create the .env file:
cp --preserve --no-clobber .env.example .env
-
Edit the
.env
file with your desired configuration. -
Usage depends on your setup:
-
For local development, load the variables before running the application:
set -a source .env set +a
-
For Docker deployments, you can use the
--env-file
option:docker run --env-file .env your-image-name
-
In docker-compose, you can specify the .env file in your docker-compose.yml:
services: your-service: env_file: - .env
-
The .env file is versatile and can be used in various deployment scenarios, offering flexibility in how you manage your environment variables.
- The
config.yaml
file is always required, even when using environment variables. - Choose either direct environment variables or the
.env
file method, but not both, to avoid confusion. - If you remove environment variable references from
config.yaml
, only the literal values in the config will be used.
Important
Use a secure value for the SECRET
key as an environment variable or as site.secret
in etc/config.yaml
. Once set, do not change this value. Create and store a backup in a secure offsite location. Changing the secret may prevent decryption of existing secrets.
For a full list of available configuration options, refer to the comments in the config.example.yaml
file.
To generate a secure, random 256-bit (32-byte) secret key, you can use the following command with OpenSSL:
openssl rand -hex 32
If OpenSSL is not installed, you can use the dd
command as a fallback:
dd if=/dev/urandom bs=32 count=1 2>/dev/null | xxd -p -c 32
Note: While the dd
command provides a reasonable alternative, using OpenSSL is recommended for cryptographic purposes.
If you encounter the error "The container name '/onetimesecret' is already in use":
# If the container already exists, you can simply start it again:
docker start onetimesecret
# OR, remove the existing container
docker rm onetimesecret
After removing the container, you can run the regular docker run
command again.
For Docker Compose setup, see the dedicated Docker Compose repo.
To run in debug mode:
ONETIME_DEBUG=true bundle exec thin -e dev start
When running the Vite server in development mode, it will automatically reload when files change. Ensure that RACK_ENV
is set to development
or development.enabled
in etc/config
is set to false
.
We use the pre-commit
framework to maintain code quality. To set it up:
-
Install pre-commit:
pip install pre-commit
-
Install the git hooks:
pre-commit install
This will ensure that the pre-commit hooks run before each commit, helping to maintain code quality and consistency.
To see the layers of an image and optimize your builds, use:
docker history <image_id>
When deploying to production, ensure you:
- Protect your Redis instance with authentication or Redis networks.
- Enable Redis persistence and save the data securely.
- Change the secret to a strong, unique value.
- Specify the correct domain it will be deployed on.
Example production deployment:
export HOST=example.com
export SSL=true
export COLONEL=admin@example.com
export REDIS_URL=redis://username:password@hostname:6379/0
export RACK_ENV=production
docker run -p 3000:3000 -d --name onetimesecret \
-e REDIS_URL=$REDIS_URL \
-e COLONEL=$COLONEL \
-e HOST=$HOST \
-e SSL=$SSL \
-e RACK_ENV=$RACK_ENV \
onetimesecret
Ensure all sensitive information is properly secured and not exposed in your deployment scripts or environment.
This section provides an overview of services similar to our project, highlighting their unique features and how they compare. These alternatives may be useful for users looking for specific functionalities or wanting to explore different options in the same domain. By presenting this information, we aim to give our users a comprehensive view of the available options in the secure information sharing space.
Note: Our in-house legal counsel (codium-pr-agent-pro bot) suggested adding this introduction and the disclaimer at the end.
URL | Service | Description | Distinctive Feature |
---|---|---|---|
https://pwpush.com/ | Password Pusher | A tool that uses browser cookies to help you share passwords and other sensitive information. | Temporary, self-destructing links for password sharing |
https://scrt.link/en | Share a Secret | A service that allows you to share sensitive information anonymously. Crucial for journalists, lawyers, politicians, whistleblowers, and oppressed individuals. | Anonymous, self-destructing message sharing |
https://cryptgeon.com/ | Cryptgeon | A service for sharing secrets and passwords securely. | Offers a secret generator, password generator, and secret vault |
https://www.vanish.so/ | Vanish | A service for sharing secrets and passwords securely. | Self-destructing messages with strong encryption |
https://password.link/en | Password.link | A service for securely sending and receiving sensitive information. | Secure link creation for sensitive information sharing |
https://sebsauvage.net/ | sebsauvage.net | A website offering various information and services. | Software to recover stolen computers |
https://www.sharesecret.co/ | ShareSecret | A service for securely sharing passwords in Slack and email. | Secure password sharing with Slack and email integration |
https://teampassword.com/ | TeamPassword | A password manager for teams. | Fast, easy-to-use, and secure team password management |
https://secretshare.io/ | Secret Share | A service for sharing passwords securely. | Strong encryption for data in transit and at rest |
https://retriever.corgea.io/ | Retriever | A service for requesting secrets securely. | Secure secret request and retrieval with encryption |
https://winden.app/s | Winden | A service for sharing secrets and passwords securely. | Securely transfers files with end-to-end encryption |
https://www.snote.app/ | SNote | A privacy-focused workspace with end-to-end encryption. | Secure collaboration on projects, to-dos, tasks, and shared files |
https://www.burnafterreading.me/ | Burn After Reading | A service for sharing various types of sensitive information. | Self-destructing messages with diceware passphrase encryption |
https://pvtnote.com/en/ | PvtNote | A service for sending private, self-destructing messages. | Clean design with self-destructing messages |
https://k9crypt.xyz/ | K9Crypt | A secure and anonymous messaging platform. | End-to-end encryption with 2-hour message deletion |
Summarized, fetched, and collated by Cohere Command R+, formatted by Claude 3.5 Sonnet, and proofread by GitHub Copilot.
The inclusion of these services in this list does not imply endorsement. Users are encouraged to conduct their own research and due diligence before using any of the listed services, especially when handling sensitive information.