1
Fork 0
mirror of https://github.com/Steffo99/festa.git synced 2025-01-03 12:34:20 +00:00
festa/CONTRIBUTING.md
2022-06-05 18:32:05 +02:00

3.3 KiB

Contributing

Run an instance

Due to how Telegram login works, setting up a development instance may be quite complicated.

Installing dependencies

Dependencies are managed using Yarn, and can be installed with:

$ yarn install

Setting up the environment

The environment is loaded by the .env.local file in the root directory:

$ cp .env.example .env.local
$ edit .env.local

Additional "global" environment files can be configured via the Next.js environment pipeline:

$ edit .env.production
$ edit .env.development

The following sections will detail which variables to change depending on your setup.

Configuring the database

A PostgreSQL 14.3 database is required by the Prisma to store data.

The address of the server to use is specified via the DATABASE_URL environment variable.

Since the project is in a prototyping phase, migrations have not been set up yet, therefore you can push the schema to the database using:

$ yarn run db:push

Additionally, the TypeScript client can be generated with the following command:

$ yarn run db:generate

Visual Studio Code tasks are included to perform these operation from the editor.

Configuring Telegram Login

To set up Telegram Login, you'll first need to create a bot on Telegram:

$ open https://t.me/BotFather

Since Telegram Login does not support non-standard ports, you'll need a domain where the development instance of the website will be accessible at:

local.steffo.eu.        0       IN      A       192.168.1.135

If you don't own a domain name, you can use your computer's hosts file to configure a HOSTNAME.localhost domain.

Your development server will also need to be reverse-proxied to be accessible at that domain, for example using Caddy.

local.steffo.eu:80 {
    reverse_proxy "http://127.0.0.1:3000"
}

Then, your Telegram bot needs to be configured to allow logins at your development domain, via the BotFather/mybots@yourbotBot SettingsDomain menu.

Finally, the details of your bot should be added to the environment:

  • TELEGRAM_TOKEN should be set to the Telegram API token of your bot
  • NEXT_PUBLIC_TELEGRAM_USERNAME should be set to the Telegram username of your bot, without the @

Starting the development services

You can start the development web server via the app:dev package script:

$ yarn app:dev
$ open http://local.steffo.eu/

Additionally, you can open the database explorer via the db:studio package script:

$ yarn db:studio
$ open http://127.0.0.1:5000/

Visual Studio Code launchers are included to launch the dev server, the debug browser, and the database explorer.