This repository has been archived on 2024-10-29. You can view files and clone it, but cannot push or open issues or pull requests.
2023-07-22 14:31:14 +00:00
2023-01-11 18:02:38 +01:00
2021-10-24 04:06:16 +02:00
2023-07-22 16:26:27 +02:00
2021-10-24 04:06:16 +02:00
2022-02-07 16:18:11 +00:00
2022-08-29 16:10:17 +00:00
2022-08-23 21:53:07 +00:00
2021-10-24 04:06:16 +02:00
2023-07-22 16:26:27 +02:00
2021-10-24 04:06:16 +02:00
2023-07-22 14:31:14 +00:00
2023-07-22 16:26:27 +02:00

Thream/api

Licence MIT Contributor Covenant

Conventional Commits semantic-release

📜 About

Thream's Application Programming Interface (API) to stay close with your friends and communities.

It uses Thream/file-uploads-api v1.1.6.

⚙️ Getting Started

Prerequisites

Installation

# Clone the repository
git clone git@github.com:Thream/api.git

# Go to the project root
cd api

# Install dependencies
npm clean-install

# Configure environment variables
cp .env.example .env

# Generate Prisma client types
npm run prisma:generate

Database Setup

# Create a new user and database
psql
CREATE DATABASE thream;
CREATE USER thream_user with encrypted password 'password';
ALTER USER thream_user WITH SUPERUSER;

Database Production migration

npm run prisma:migrate:deploy

Local Development environment

Recommended to use VSCode: Remote development in Containers.

Database Development migration

# Run Prisma migrations
npm run prisma:migrate:dev

# Reset the database (WARNING: This will delete all data)
npm run prisma:migrate:reset

Usage

npm run dev
Services started
Commands
# Build, Lint and Test
npm run build
npm run build:typescript
npm run lint:editorconfig
npm run lint:markdown
npm run lint:eslint
npm run lint:prettier
npm run test

Production environment (with Docker)

docker compose up --build

💡 Contributing

Anyone can help to improve the project, submit a Feature Request, a bug report or even correct a simple spelling mistake.

The steps to contribute can be found in CONTRIBUTING.md.

📄 License

MIT

Description
Thream's Application Programming Interface (API) to stay close with your friends and communities.
https://api.thream.divlo.fr/documentation Readme 2.7 MiB
Languages
TypeScript 95.9%
EJS 2.2%
Handlebars 1%
JavaScript 0.5%
Dockerfile 0.3%