To set up the repository, run:
$ ./scripts/bootstrap
$ ./scripts/build
This will install all the required dependencies and build the SDK.
You can also install go 1.18+ manually.
Most of the SDK is generated code. Modifications to code will be persisted between generations, but may
result in merge conflicts between manual patches and changes from the generator. The generator will never
modify the contents of the lib/
and examples/
directories.
All files in the examples/
directory are not modified by the generator and can be freely edited or added to.
# add an example to examples/<your-example>/main.go
package main
func main() {
// ...
}
$ go run ./examples/<your-example>
To use a local version of this library from source in another project, edit the go.mod
with a replace
directive. This can be done through the CLI with the following:
$ go mod edit -replace github.com/Modern-Treasury/modern-treasury-go/v2=/path/to/modern-treasury-go
Most tests require you to set up a mock server against the OpenAPI spec to run the tests.
# you will need npm installed
$ npx prism mock path/to/your/openapi.yml
$ ./scripts/test
This library uses the standard gofmt code formatter:
$ ./scripts/format