Self-hosted Github Gist clone.
Deploy this app to Linode with a free $100 credit!
Note: This branch is where all work is being done to refactor to the Next.js 13 app directory and React Server Components.
Drift is a self-hostable Gist clone. It's in beta, but is completely functional.
You can try a demo at https://drift.lol. The demo is built on main but has no database, so files and accounts can be wiped at any time.
If you want to contribute, need support, or want to stay updated, you can join the IRC channel at #drift on irc.libera.chat or reach me on twitter. If you don't have an IRC client yet, you can use a webclient here.
Contents:
In the root directory, run pnpm i
. If you need pnpm
, you can download it here.
You can run pnpm dev
in client
for file watching and live reloading.
To work with prisma, you can use pnpm prisma
or pnpm exec prisma
to interact with the database.
pnpm build
will produce production code. pnpm start
will start the Next.js server.
You can change these to your liking.
.env
:
DRIFT_URL
: the URL of the drift instance.DATABASE_URL
: the URL to connect to your postgres instance. For example, postgresql://user:password@localhost:5432/drift
.WELCOME_CONTENT
: a markdown string that's rendered on the home pageWELCOME_TITLE
: the file title for the post on the homepage.ENABLE_ADMIN
: the first account created is an administrator accountREGISTRATION_PASSWORD
: the password required to register an account. If not set, no password is required.NODE_ENV
: defaults to development, can be production
Note: Only credential auth currently supports the registration password, so if you want to secure registration, you must use only credential auth.
GITHUB_CLIENT_ID
: the client ID for GitHub OAuth.GITHUB_CLIENT_SECRET
: the client secret for GitHub OAuth.NEXTAUTH_URL
: the URL of the drift instance. Not required if hosting on Vercel.CREDENTIAL_AUTH
: whether to allow username/password authentication. Defaults to true
.It's easy to start Drift using pm2.
First, add the .env
file with your values (see the above section for the required options).
Then, use the following command to start the server:
pnpm build && pm2 start pnpm --name drift --interpreter bash -- start
Refer to pm2's docs or pm2 help
for more information.
Drift is a work in progress. Below is a (rough) list of completed and envisioned features. If you want to help address any of them, please let me know regardless of your experience and I'll be happy to assist.
app
directoryPlease login to review this project.
No reviews for this project yet.
Advanced and beautiful pastebin.
A minimal file upload/pastebin service.
A one-time encrypted zero-knowledge password/secret sharing…
Comments (0)
Please login to join the discussion on this project.