ubercontroller

package module
v0.5.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 24, 2023 License: AGPL-3.0 Imports: 0 Imported by: 0

README

uberubercontroller

New ubercontroller

Development

Prerequisites
  • Go environment
  • Connection information for a pre-seeded Postgres database
TL;DR (quick start)

For local development:

  • copy config.example.yaml to config.yaml
  • configure the database connection in config.yaml
  • make run
Local development with remote Media Manager

You need to have kubectl configured with dev env and do port-forwarding to dev instance:

kubectl port-forward deploy/media-manager-deployment 4002:4000

In config.yaml add the following to common section:

render_internal_url: 'http://localhost:4002'

Swagger Documentation

  1. Install swag cli tool
  2. Run swag init -g universe/node/api.go to generate documentation
  3. Open in browser http://localhost:4000/swagger/index.html

Database migrations

Changes to the database are managed as SQL scripts in database/migrations with go-migrate. See its documentation for detailed instructions. The short version:

go install -tags 'postgres' github.com/golang-migrate/migrate/v4/cmd/migrate@latest
migrate create -ext sql -dir database/migrations/sql/ -seq <SHORT_NAME_FOR_MIGRATION>

Two empty .sql files will be created in database/migrations/sql. Implemented them and to test it:

migrate -source file://database/migrations/sql/ -database postgres://momentum:momentum@localhost:4321/momentum?sslmode=disable up

And to revert the change:

migrate -source file://database/migrations/sql/ -database postgres://momentum:momentum@localhost:4321/momentum?sslmode=disable down 1

If something goes wrong, it will leave the database in a 'dirty' state. To resolve you have to manually bring back the database to a known state (so use a single transaction in the SQL scripts to make this easier). After that edit the schema_migration table and set the version number back and flip the dirty boolean.

Documentation

Index

Constants

View Source
const (
	APIMajorVersion = 4
	APIMinorVersion = 0
	APIPatchVersion = 0

	ControllerMajorVersion = 1
	ControllerMinorVersion = 0
	ControllerPathVersion  = 0
	ControllerGitVersion   = ""
)

Variables

This section is empty.

Functions

This section is empty.

Types

This section is empty.

Directories

Path Synopsis
cmd
db
pkg
Package pkg can be used by third-parties
Package pkg can be used by third-parties
posbus
The posbus package implements the custom protocol for communication between the backend and frontends.
The posbus package implements the custom protocol for communication between the backend and frontends.
service
Package services allows running the controller service from go without going through the cli.
Package services allows running the controller service from go without going through the cli.
attributes
Package attributes provides functionality for handling/using the plugin attributes system.
Package attributes provides functionality for handling/using the plugin attributes system.
iot
logic/api/dto
TODO: deal with this mess
TODO: deal with this mess
streamchat
Text chat functionality backed by getstream.io chat service.
Text chat functionality backed by getstream.io chat service.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL