Drift is a self-hostable Gist and paste service. Built with Next.js 13 and React Server Components.
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Go to file
dependabot[bot] 27bf78f642
Bump semver from 5.7.1 to 5.7.2
Bumps [semver](https://github.com/npm/node-semver) from 5.7.1 to 5.7.2.
- [Release notes](https://github.com/npm/node-semver/releases)
- [Changelog](https://github.com/npm/node-semver/blob/v5.7.2/CHANGELOG.md)
- [Commits](https://github.com/npm/node-semver/compare/v5.7.1...v5.7.2)

---
updated-dependencies:
- dependency-name: semver
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>
2 years ago
.github chore(deps): update actions/checkout action to v3 (#92) 3 years ago
.vscode bump deps 2 years ago
public some file cleanup, add api/og function 2 years ago
src /new page responsiveness 2 years ago
tools Slight shell script improvements 2 years ago
types chore: linting 2 years ago
.env.default feat: add keycloak login (#139) 2 years ago
.eslintrc.json /new page responsiveness 2 years ago
.gitignore remove @vercel/og, use bundled package 2 years ago
.prettierrc Shadify (#150) 2 years ago
CONTRIBUTING.md Create CONTRIBUTING.md 3 years ago
LICENSE Create LICENSE 3 years ago
README.md Shadify (#150) 2 years ago
components.json Shadify (#150) 2 years ago
docker-compose.yml cleaned up multi-service compose (#75) 3 years ago
jest.config.js Add some (WIP) tests 2 years ago
next-env.d.ts Bump next.js and related deps 2 years ago
next.config.mjs Shadify (#150) 2 years ago
package.json Shadify (#150) 2 years ago
pnpm-lock.yaml Bump semver from 5.7.1 to 5.7.2 2 years ago
postcss.config.js Shadify (#150) 2 years ago
renovate.json server: lint, renovate: weekly updates 3 years ago
tailwind.config.js Shadify (#150) 2 years ago
tsconfig.json Add some (WIP) tests 2 years ago

README.md

Drift

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.

Drift is built with Next.js 13, React Server Components, shadcn/ui, and Prisma.


Contents:

Setup

Development

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.

Production

pnpm build will produce production code. pnpm start will start the Next.js server.

Environment Variables

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 page
  • WELCOME_TITLE: the file title for the post on the homepage.
  • ENABLE_ADMIN: the first account created is an administrator account
  • REGISTRATION_PASSWORD: the password required to register an account. If not set, no password is required.
  • NODE_ENV: defaults to development, can be production

Auth environment variables

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.

Running with pm2

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.

Running with Docker

Running with systemd

NOTE: We assume that you know how to enable user lingering if you don't want to use the systemd unit as root

  • As root

    • Place the following systemd unit in /etc/systemd/system and name it drift.service
    • Replace any occurrence of $USERNAME with the shell username of the user that will be running the Drift server
    ##########
    # Drift Systemd Unit (Global)
    ##########
    [Unit]
    Description=Drift Server (Global)
    After=default.target
    
    [Service]
    User=$USERNAME
    Group=$USERNAME
    Type=simple
    WorkingDirectory=/home/$USERNAME/Drift
    ExecStart=/usr/bin/pnpm start
    Restart=on-failure
    
    [Install]
    WantedBy=default.target
    
  • As a nomal user

    • Place the following systemd unit inside /home/user/.config/systemd/user and name it drift_user.service
    • Replace any occurrence of $USERNAME with the shell username of the user that will be running the Drift server
    ##########
    # Drift Systemd Unit (User)
    ##########
    [Unit]
    Description=Drift Server (User)
    After=default.target
    
    [Service]
    Type=simple
    WorkingDirectory=/home/$USERNAME/Drift
    ExecStart=/usr/bin/pnpm start
    Restart=on-failure
    
    [Install]
    WantedBy=default.target
    

Current status

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.

  • Next.js 13 app directory
  • creating and sharing private, public, password-protected, and unlisted posts
    • syntax highlighting
    • expiring posts
  • responsive UI
  • user auth
    • SSO via HTTP header (Issue: #11)
    • SSO via GitHub OAuth
  • downloading files (individually and entire posts)
  • password protected posts
  • postgres database
  • administrator account / settings
  • docker-compose (PRs: #13, #75)
    • publish docker builds
  • user settings
  • works enough with JavaScript disabled
  • in-depth documentation
  • customizable homepage, so the demo can exist as-is but other instances can be built from the same source. Environment variable for the file contents?
  • fleshed out API
  • Swappable database backends
  • More OAuth providers