|
||
---|---|---|
.githooks | ||
.github/workflows | ||
.vscode | ||
cache | ||
cli | ||
client | ||
cmd/gitness | ||
contrib | ||
encrypt | ||
events | ||
githook | ||
gitrpc | ||
http | ||
internal | ||
livelog | ||
lock | ||
mocks | ||
profiler | ||
pubsub | ||
resources | ||
scripts | ||
store | ||
stream | ||
types | ||
version | ||
web | ||
.dockerignore | ||
.gitignore | ||
.golangci.yml | ||
.local.env | ||
.npmrc | ||
CHANGELOG.md | ||
Dockerfile | ||
LICENSE.md | ||
Makefile | ||
README.md | ||
Taskfile.yml | ||
go.mod | ||
go.sum | ||
wait-for-gitness.sh | ||
yarn.lock |
README.md
Pre-Requisites
Install the latest stable version of Node and Go version 1.19 or higher, and then install the below Go programs. Ensure the GOPATH bin directory is added to your PATH.
Install protobuf
- Check if you've already installed protobuf
protoc --version
- If your version is different than v3.21.11, run
brew unlink protobuf
- Get v3.21.11
curl -s https://raw.githubusercontent.com/Homebrew/homebrew-core/9de8de7a533609ebfded833480c1f7c05a3448cb/Formula/protobuf.rb > /tmp/protobuf.rb
- Install it
brew install /tmp/protobuf.rb
- Check out your version
protoc --version
Install protoc-gen-go and protoc-gen-go-rpc:
-
Install protoc-gen-go v1.28.1
go install google.golang.org/protobuf/cmd/protoc-gen-go@v1.28.1
(Note that this will install a binary in $GOBIN so make sure $GOBIN is in your $PATH) -
Install protoc-gen-go-grpc v1.2.0
go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@v1.2.0
$ make all
Setup github access token required for UI dependencies:
$ yarn setup-github-registry
Build
Build the user interface:
$ pushd web
$ yarn install
$ yarn run build
$ popd
Build the server and command line tools:
# STANDALONE
$ make build
Test
Execute the unit tests:
$ make test
Run
This project supports all operating systems and architectures supported by Go. This means you can build and run the system on your machine; docker containers are not required for local development and testing.
Start the server at localhost:3000
# STANDALONE
./gitness server .local.env
User Interface
This project includes a simple user interface for interacting with the system. When you run the application, you can access the user interface by navigating to http://localhost:3000
in your browser.
Swagger
This project includes a swagger specification. When you run the application, you can access the swagger specification by navigating to http://localhost:3000/swagger
in your browser (for raw yaml see http://localhost:3000/openapi.yaml
).
Auto-Generate Gitness API Client used by UI using Swagger
Please make sure to update the autogenerated client code used by the UI when adding new rest APIs.
To regenerate the code, please execute the following steps:
- Run local gitness instance with latest changes
- Get latest OpenAPI specs from
http://localhost:3000/openapi.yaml
and store it inweb/src/services/code/swagger.yaml
Simply copy the whole content of the web response and store it in the
swagger.yaml
file
- Regenerate client code by running
yarn services
in theweb
directory
The latest API changes should now be reflected in web/src/services/code/index.tsx
CLI
This project includes simple command line tools for interacting with the system. Please remember that you must start the server before you can execute commands.
Register a new user:
$ ./gitness register
NOTE: A user
admin
(pw:changeit
) gets created by default.
Login to the application:
$ ./gitness login
Logout from the application:
$ ./gitness logout
View your account details:
$ ./gitness user self
Generate a personal access token:
$ ./gitness user pat $UID $LIFETIME_IN_S
Debug and output http responses from the server:
$ DEBUG=true ./gitness user self
View all commands:
$ ./gitness --help
REST API
Please refer to the swagger for the specification of our rest API.
For testing, it's simplest to execute operations as the default user admin
using a PAT:
# LOGIN (user: admin, pw: changeit)
$ ./gitness login
# GENERATE PAT (1 YEAR VALIDITY)
$ ./gitness user pat mypat 2592000
The command outputs a valid PAT that has been granted full access as the user.
The token can then be send as part of the Authorization
header with Postman or curl:
$ curl http://localhost:3000/api/v1/user \
-H "Authorization: Bearer $TOKEN"