Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Backend readme #1470

Merged
merged 3 commits into from
Jan 29, 2024
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
236 changes: 73 additions & 163 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,212 +1,122 @@
# sphinx-tribes

![Tribes](https://github.com/stakwork/sphinx-tribes/raw/master/img/sphinx-tribes.png)

Decentralized message broker for public groups in Sphinx. Anyone can run a **sphinx-tribes** server, to route group messages.

**sphinx-tribes** clients can be **sphinx-relay** nodes, apps, websites, or IoT devices.

### How

**sphinx-tribes** is an MQTT broker that any node can subscribe to. Message topics always have two parts: `{receiverPubKey}/{groupUUID}`. Only the owner of the group is allowed to publish to it: all messages from group members must be submitted to the owner as an Lightning keysend payment. The group `uuid` is a timestamp signed by the owner.

![Tribes](https://github.com/stakwork/sphinx-tribes/raw/master/img/tribes.jpg)

### Authentication

Authentication is handled by [sphinx-auth](https://github.com/stakwork/sphinx-auth)

### build

docker build --no-cache -t sphinx-tribes .

docker tag sphinx-tribes sphinxlightning/sphinx-tribes:x
# Sphinx-Tribes Backend

docker push sphinxlightning/sphinx-tribes:x

### run against sphinx-stack

To run tribes frontend locally, use these ports:

- tribes: `yarn start:tribes:docker` (localhost:23000)
- people: `yarn start:people:docker` (localhost:23007)

### Run frontend locally against people.sphinx.chat

If you would like to run just the frontend do the following
![Tribes](https://github.com/stakwork/sphinx-tribes/raw/master/img/sphinx-tribes.png)

line 10 in `frontend/app/src/config/ModeDispatcher.tsx` change `'localhost:3000': Mode.TRIBES` -> `'localhost:3000': Mode.COMMUNITY`
Sphinx-Tribes is a decentralized message broker for public groups within the Sphinx ecosystem. This README covers the setup and configuration of the Sphinx-Tribes backend.

line 5 in `frontend/app/src/config/host.ts` return `"people.sphinx.chat"`
## Table of Contents

### Run Golang backend
- [Prerequisites](#prerequisites)
- [Setup](#setup)
- [Cloning the Repository](#cloning-the-repository)
- [Building the Docker Image](#building-the-docker-image)
- [Environment Configuration](#environment-configuration)
- [Database Setup](#database-setup)
- [Running the Backend](#running-the-backend)
- [Optional Features](#optional-features)
- [Redis for Caching](#redis-for-caching)
- [Relay Integration](#relay-integration)
- [Meme Image Upload](#meme-image-upload)
- [SuperAdmin Dashboard Access](#superadmin-dashboard-access)
- [Stakwork YouTube Integration](#stakwork-youtube-integration)
- [Testing and Mocking](#testing-and-mocking)
- [Unit Testing](#unit-testing)
- [Mocking Interfaces](#mocking-interfaces)
- [API Data Validations](#api-data-validations)
- [Contributing](#contributing)
- [License](#license)

- Create a .env file and populate the env file with thgitese variables
## Prerequisites

```
TEST_MODE=true
PORT= // Server PORT
DATABASE_URL= // Database URL
TEST_ASSET_URL= // Test asset URL
```
- Docker
- Go language environment
- PostgreSQL database
- Redis instance (optional)
- Relay server access (optional)

- Build the application by running `go build .`
- Run the application with `./sphinx-tribes`
## Setup

### Run Golang backend with local database
### Cloning the Repository

- Create a Postgres database
- Copy the table creation queries from tribes.sql file, and create the tables in the database created
- Create a .env file and populate the .env files with these variables
Clone the Sphinx-Tribes repository:

```sh
git clone https://github.com/Vayras/sphinx-tribes.git
```
RDS_HOSTNAME =
RDS_PORT =
RDS_DB_NAME =
RDS_USERNAME =
RDS_PASSWORD =
```

- Build and run the Golang server

### Building the Docker Image

### Mocking interfaces for unit testing golang backend
We are using [mockery](https://vektra.github.io/mockery/latest/) to autogenerate mocks of an interface in our unit tests.
Navigate to the cloned directory and build the Docker image:

#### Installing mockery
There are multiple options to install mockery. Use any one of the following to download.
##### Download the mockery binary
Use the release page link [mockery releases](https://github.com/vektra/mockery/releases/tag/v2.39.1) to download the artifact for your respective device.
##### Using go install
If you have go already installed on your device you can use the go install command to download mockery.
```sh
go install github.com/vektra/mockery/[email protected]
docker build --no-cache -t sphinx-tribes .
docker tag sphinx-tribes sphinxlightning/sphinx-tribes:x
docker push sphinxlightning/sphinx-tribes:x
```

##### Using homebrew
If you are on mac you can use homebrew to download mockery
```zsh
brew install mockery
brew upgrade mockery
```
### Environment Configuration

#### When adding a new function to the interface which is already mocked follow the below steps:
1. Update the corresponding interface with the function signature, for example if you are adding new function to the ```database``` structure make sure the interface file ```db/interface.go``` is updated with the function signature.
2. run the command ```mockery``` to update the mocks.


#### To create mocks for a new interface make follow the steps below:

1. Add the new entry in the ```.mockery.yml``` file like this
```yml
with-expecter: true
dir: "mocks"
packages:
github.com/stakwork/sphinx-tribes/db:
interfaces:
Database:
github.com/stakwork/sphinx-tribes/*your-package-name*:
interfaces:
*your-interface-1*:
*your-interface-2*:
```
2. run the command ```mockery``` to update the mocks.
Create a `.env` file in the project root with the required environment variables.

### Database Setup

### Run Test
Set up a PostgreSQL database and execute the provided SQL scripts to create necessary tables.

```
// you may need to install cover with this command first
// go get golang.org/x/tools/cmd/cover
go test ./... -tags mock -race -v -coverprofile=coverage.out && ./cover-check.sh coverage.out <min coverage amount>
// To get code coverage in html format do the following after running the code above
go tool cover -html="coverage.out"
```
### Running the Backend

### Enable Relay
Build and run the Golang backend:

If you would like to enable Relay for invoice creation and keysend payment add the relay env key and values to the .env file

```
RELAY_URL=
RELAY_AUTH_KEY=
```sh
go build .
./sphinx-tribes
```

### Enable Meme Image Upload
## Optional Features

If you would like to enable Meme image upload for organization's add the meme env key and value to the .env file,
Meme image upload works with Relay enabled, so a running Relay is required for Meme to work.
### Redis for Caching

```
MEME_URL=
```
Configure Redis by adding the `REDIS_URL` or other relevant variables to your `.env` file.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you specify the other relevant variables?

REDIS_HOST=
REDIS_USER=
REDIS_PASS=
REDIS_DB=

To make it easier for developers.


### Add REDIS for cache
### Relay Integration

- Create a Redis instance
- Create a .env file and populate the .env files with these variables
For invoice creation and keysend payment, add `RELAY_URL` and `RELAY_AUTH_KEY`.

If you have a Redis url add the REDIS_URL variable to .env
### Meme Image Upload

```REDIS_URL = ```
Requires a running Relay. Enable it with `MEME_URL`.

else add these variables to the env to enable Redis
### SuperAdmin Dashboard Access

```
REDIS_HOST =
REDIS_DB =
REDIS_USER =
REDIS_PASS =
```

### Add SuperAdmins to access admin dashboard

Add comma separated public keys to the SUPER_ADMINS env var in the .env file,
any user public key added to this comaa separated strings will have access to the admin dashboard
e.g '{pubkey}, {pubkey}, {pubkey}'
Add public keys to `SUPER_ADMINS` in your `.env` file.

```
ADMINS
```
### Stakwork YouTube Integration

### For Contributions
Add `STAKWORK_KEY` for YouTube video downloads.

Read the contribution doc [here](./docs/Contribution.md)
## Testing and Mocking

### Stakwork Youtube vidoes download for tribes feed
### Unit Testing

If you would like to enable Stakwork jobs for Youtube videos download add the Stakwork env key and values to the .env file
Run unit tests with coverage:

```sh
go test ./... -tags mock -race -v -coverprofile=coverage.out
go tool cover -html="coverage.out"
```
STAKWORK_KEY=
```

### Backend API Data Validations

We are currently using `gopkg.in/go-playground/validator.v9` for validation, to validate a struct add the `validate` property to it
### Mocking Interfaces

e.g
Use [mockery](https://vektra.github.io/mockery/latest/) for interface mocking.

```
type Organization struct {
Name string `gorm:"unique;not null" json:"name" validate:"required"`
Website string `json:"website" validate:"omitempty,uri"`
Github string `json:"github" validate:"omitempty,uri"`
Description string `json:"description" validate:"omitempty,lte=200"`
}
```
## API Data Validations

Then handle the validation errors in the request handler
Implement validations using `gopkg.in/go-playground/validator.v9`.

```
err = db.Validate.Struct(org)
if err != nil {
w.WriteHeader(http.StatusBadRequest)
msg := fmt.Sprintf("Error: did not pass validation test : %s", err)
json.NewEncoder(w).Encode(msg)
return
}
## Contributing

```
Please read [CONTRIBUTING.md](./CONTRIBUTING.md) for details on our code of conduct, and the process for submitting pull requests.

## License

This project is licensed under the [LICENSE NAME] - see the [LICENSE.md](LICENSE.md) file for details.