Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pheralb/slug
ð± An open-source URL shortener built with T3 Stack.
https://github.com/pheralb/slug
hacktoberfest next-auth nextjs prisma shadcn-ui sqlite t3 t3-stack tailwindcss turso typescript vercel
Last synced: 1 day ago
JSON representation
ð± An open-source URL shortener built with T3 Stack.
- Host: GitHub
- URL: https://github.com/pheralb/slug
- Owner: pheralb
- License: gpl-3.0
- Created: 2022-09-17T13:51:40.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-08-02T17:10:20.000Z (5 months ago)
- Last Synced: 2025-01-03T22:06:13.510Z (9 days ago)
- Topics: hacktoberfest, next-auth, nextjs, prisma, shadcn-ui, sqlite, t3, t3-stack, tailwindcss, turso, typescript, vercel
- Language: TypeScript
- Homepage: https://slug.vercel.app
- Size: 2.65 MB
- Stars: 630
- Watchers: 2
- Forks: 67
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome - pheralb/slug - ð± An open-source URL shortener built with T3 Stack. (TypeScript)
README
An open-source URL shortener built with T3 Stack.
Dashboard
  â Â
Roadmap
  â Â
Contribute
  â Â
Create issue
  â Â
X/Twitter![Next.js Badge](https://img.shields.io/badge/Next.js 14-000?logo=nextdotjs&logoColor=fff&style=flat)
![Turso Badge](https://img.shields.io/badge/Turso-4FF8D2?logo=turso&logoColor=000&style=flat)
![Check workflow](https://github.com/pheralb/slug/actions/workflows/ci.yml/badge.svg)
![GitHub stars](https://img.shields.io/github/stars/pheralb/slug)
![GitHub releases](https://img.shields.io/github/release/pheralb/slug)
![GitHub issues](https://img.shields.io/github/issues/pheralb/slug)
![GitHub license](https://img.shields.io/github/license/pheralb/slug)## ðšâð Introduction
[**Slug**](slug.vercel.app) is a service that offers to shorten urls in a simple, fast and secure way. It's built with [**T3 Stack**](https://create.t3.gg/), a web development stack made by [**Theo**](https://twitter.com/t3dotgg) focused on simplicity, modularity, and full-stack **typesafety**.
This project uses the following technologies:
- [**create-t3-app**](https://create.t3.gg) - The best way to start a full-stack, typesafe Next.js app.
- [**Next.js 14 App Router**](https://nextjs.org/) - The React Framework for the Web.
- [**Auth.js v5**](https://authjs.dev/) - Authentication for the Web.
- [**Prisma**](https://prisma.io) - A next-generation Node.js and TypeScript ORM.
- [**Turso**](https://turso.tech/) (SQLite) + [**libSQL**](https://github.com/tursodatabase/libsql) - SQLite for Production.
- [**Next.js Server Actions**](https://nextjs.org/docs/api-reference/server-actions) - Asynchronous functions that are executed on the server.
- [**TailwindCSS**](https://tailwindcss.com) + [**shadcn/ui**](https://ui.shadcn.com) & [**Radix Primitives**](https://www.radix-ui.com) - Design System.
- [**Prettier**](https://prettier.io) with [**prettier-plugin-tailwindcss**](https://github.com/tailwindlabs/prettier-plugin-tailwindcss) - Code Formatter.
- [**Lucide Icons**](https://lucide.dev) + [**svgl**](https://svgl.app) - Beautiful SVG icons & logos for the web.> â ïž This is a community project, not associated with [Vercel](https://vercel.com/).
## ð Getting Started
**Requirements:**
- [x] [Node.js](https://nodejs.org) (+v18.x) installed.
- [x] [pnpm](https://pnpm.io) (v8+) installed.
- [x] [Turso CLI](https://docs.turso.tech/cli/install) installed (for Windows users, it's necessary to [activate WSL 2](https://docs.microsoft.com/en-us/windows/wsl/install)).
- [x] [Visual Studio Code](https://code.visualstudio.com) with the recommended extensions installed (ESLint, Prettier, Tailwind CSS IntelliSense).**Steps:**
1. Fork this project:
- [Click here](https://github.com/pheralb/slug/fork).
2. Clone the repository:
```bash
git clone [email protected]:YOU_USER/slug.git
```3. Install dependencies:
```bash
# Install pnpm globally if you don't have it:
npm install -g pnpm# and install dependencies:
pnpm install
```4. Create a **.env** file with the following content:
> ð§ The environment variables must match the following [schema](https://github.com/pheralb/slug/blob/main/src/env/schema.mjs#L8).
```bash
# Database:
DATABASE_URL= # "file:./dev.db"
TURSO_DATABASE_URL=
TURSO_AUTH_TOKEN=# Auth.js =>
AUTH_SECRET=# Github Provider =>
GITHUB_ID=
GITHUB_CLIENT_SECRET=# Google Provider =>
GOOGLE_CLIENT_ID=
GOOGLE_CLIENT_SECRET=
```**Database:**
- [**Create** a new database with Turso](https://docs.turso.tech/cli/db/create).
- [Get Turso **Auth Token**](https://docs.turso.tech/cli/auth/token).
- [Get Turso **Database URL**](https://docs.turso.tech/cli/db/show).**Auth.js:**
- [Get Auth.js **Secret**](https://authjs.dev/getting-started/installation#setup-environment).
- ``AUTH_URL`` is the URL of your Auth.js API, for example, ``/api/auth``. You can change it in the [**``auth.ts`` file**](https://github.com/pheralb/slug/blob/next/src/auth.ts#L20).**Github Credentials:**
- [Create a new OAuth App](https://docs.github.com/en/apps/oauth-apps/building-oauth-apps/creating-an-oauth-app).
**Google Credentials:**
- [Create a new OAuth 2.0 App from Google API Console](https://developers.google.com/identity/protocols/oauth2#1.-obtain-oauth-2.0-credentials-from-the-dynamic_data.setvar.console_name-.).
5. Generate a new migration file with Prisma:
```bash
pnpm db:migrate
```6. Insert the migration data into the Turso database. To do this, go to ``package.json``, modify the ``db:push`` command with the name of the migration folder (2024***xxxxxxxxxx***_init) and run it in your terminal:
```bash
pnpm db:push
```7. Run:
- Development server:
```bash
pnpm dev
```and open [http://localhost:3000](http://localhost:3000) with your browser ð
- Prisma Studio:
```bash
pnpm db:studio
```and open [http://localhost:5555](http://localhost:5555) with your browser âš
## ð Roadmap
This is the roadmap I will be following for the complete migration to v3:
> - *â * = Stable, completed.
> - *ð* = Stable, but unexpected errors may appear.
> - *âïž* = In progress.â¬ïž **Known issues:**
- âïž Fix issue when logging in with different provider but with the same email. Redirect to an existing route in the app ([authjs error](https://authjs.dev/reference/core/errors#accountnotlinked)).
â¬ïž **Dependencies:**
- â Update `@prisma/adapter-libsql`, `@prisma/client` & `prisma` to the stable version when it's released.
- âïž Update `authjs` to the stable version (v5) when it's released.â¬ïž **Auth:**
- â Sign In with Github.
- ð Sign In with Google.ð Only for users who have not previously logged in with an existing email address in their Github account. This is an issue that will be worked on soon.
â¬ïž **Middleware:**
- â Redirect with `/*` and `/s/*`.
- â Separate public, protected & authentication routes.â¬ïž **Dashboard (main):**
- â Create a new short URL.
- â List all shorted URLs.
- â Delete a shorted URL.
- â Update a shorted URL.`â¬ïž **Dashboard (tags):**
- â Add search links by tags in the dashboard.
- ð Create a new tag.
- â Delete a tag.
- âïž Update the tags of a link.ð Add option to change tag color.
â¬ïž **Dashboard (settings):**
- â Change name.
- â Change email.
- â Delete account.
- â Download all links data.## âïž Contributing
## âïž Deploy on Vercel
- â [slug.vercel.app](https://slug.vercel.app/).
## ð License
- [GPL-3.0 license](https://github.com/pheralb/slug/blob/main/LICENSE).