f33fa149fc
It is unclear whether these are actually significantly improving performance and they add non-trivial complexity to the codebase, especially when under heavy frontend development. Removing most of them for now until it can be shown they are actually worthwhile. |
||
---|---|---|
backend | ||
frontend | ||
proto | ||
.dockerignore | ||
.drone.yml | ||
.gitignore | ||
Dockerfile | ||
LICENSE | ||
README.md | ||
deploy.sh | ||
protogen.sh |
README.md
Clipper
Clipper is a Youtube audio clipper developed using modern web technologies.
- Go
- protobuf, grpc-web
- Typescript
- React
It is currently in early development.
Development
Dependencies
It is required that an ffmpeg binary is available in the current path.
Running the app
The backend requires configuration via environment variables - see backend/.env.example
. All variables must be set unless they are marked as optional.
Then, the server can be started with:
cd backend/
go run cmd/clipper/main.go
The frontend can be launched on localhost:3000 with:
cd frontend/
yarn start
Code generation
To regenerate protobuf code and GRPC stubs, first install protoc and the GRPC dependencies:
go install google.golang.org/protobuf/cmd/protoc-gen-go@latest
go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@latest
Then generate the code with:
./protogen.sh
To regenerate the database access layer, first install sqlc. New queries can be added to backend/sql/queries.sql
, and code regenerated with:
cd backend/
sqlc generate
Mocks require mockery to be installed, and can be regenerated with:
go generate ./...
Migrations
Database migrations require golang-migrate.
go install -tags 'postgres' github.com/golang-migrate/migrate/v4/cmd/migrate@latest
Migrations then can be run with:
cd backend/
migrate -path sql/migrations -database $DATABASE_URL up