Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/afcms/devpet_backend
https://github.com/afcms/devpet_backend
commanderjs embedded github-api graphql serial typescript
Last synced: 13 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/afcms/devpet_backend
- Owner: AFCMS
- License: gpl-3.0
- Created: 2024-04-06T15:24:28.000Z (9 months ago)
- Default Branch: master
- Last Pushed: 2024-05-18T14:56:34.000Z (8 months ago)
- Last Synced: 2024-05-19T14:36:18.741Z (8 months ago)
- Topics: commanderjs, embedded, github-api, graphql, serial, typescript
- Language: TypeScript
- Homepage:
- Size: 284 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Citation: CITATION.cff
Awesome Lists containing this project
README
# DevPet Backend
[![NodeJS](https://github.com/AFCMS/devpet_backend/actions/workflows/nodejs.yml/badge.svg)](https://github.com/AFCMS/devpet_backend/actions/workflows/nodejs.yml)
## Run the project
### Install NodeJS
The required version of [NodeJS](https://nodejs.org) is LTS/Iron (v20) with the [PNPM](https://pnpm.io) package manager.
You can use [NVM](https://github.com/nvm-sh/nvm) to install it.
### Install dependencies
```bash
pnpm install --include=dev
```### Connect the ESP32 serial port (Linux instructions)
Now we need to connect the DevPet Bluetooth as a serial port to the computer.
You can pair the ESP32 using the normal bluetooth pairing flow.
Using the `rfcomm` you can connect the device to the `/dev/rfcomm0` port.
Install `rfcomm` under Fedora:
```shell
sudo dnf install bluez-deprecated
``````shell
sudo rfcomm connect /dev/rfcomm0 1
```> [!NOTE]
>
> The `rfcomm` utility is deprecated and doesn't have a clear replacement.
>
> Ideally there should be a driver automatically connecting the device as a serial device using BlueZ DBus API### Setup environment variables
You can copy the `.env.example` file and fill out the values with the following instructions
#### Serial Port
Set `DEVPET_SERIAL_PORT` to the serial port where the ESP32 is connected, typically the `/dev/rfcomm0` if you used
rfcomm as above.#### GitHub
Go to your GitHub user account settings in the developper tab, create a
new [personal access token](https://github.com/settings/tokens) with the `read:user` and `repo` scopes.Set `DEVPET_GITHUB_TOKEN` to the given token.
#### Spotify
Spotify doens't have PATs, so we have to rely on a OAuth2 application (APIs from litteraly all music providers are
ridiculeously bad).First you need to create a new OAuth2 app on
the [Spotify Developer Dashboard](https://developer.spotify.com/dashboard), set the redirect URL
to `http://localhost:9600/spotify/callback`.Set `DEVPET_SPOTIFY_CLIENT_ID` and `DEVPET_SPOTIFY_CLIENT_SECRET` to the given values.
Then you can login to your own OAuth2 app by running the following command and clicking the displayed link:
```shell
pnpm start spotify-login
```### Start the backend
```shell
pnpm start run
```