30 lines
1.5 KiB
Markdown
30 lines
1.5 KiB
Markdown
# Managing dependencies
|
|
|
|
## Go modules
|
|
|
|
Dex uses [Go modules][go-modules] to manage its dependencies. Go 1.11 or higher is recommended. While Go 1.12 is expected to finalize the Go modules feature, with Go 1.11 you should [activate the Go modules feature][go-modules-activate] before interacting with Go modules.
|
|
|
|
Here is one way to activate the Go modules feature with Go 1.11.
|
|
|
|
```
|
|
export GO111MODULE=on # manually active module mode
|
|
```
|
|
|
|
You should become familiar with [module-aware `go get`][module-aware-go-get] as it can be used to add version-pinned dependencies out of band of the typical `go mod tidy -v` workflow.
|
|
|
|
## Adding dependencies
|
|
|
|
To add a new dependency to dex or update an existing one:
|
|
|
|
1. Make changes to dex's source code importing the new dependency.
|
|
2. You have at least three options as to how to update `go.mod` to reflect the new dependency:
|
|
* Run `go mod tidy -v`. This is a good option if you do not wish to immediately pin to a specific Semantic Version or commit.
|
|
* Run, for example, `go get <package-name>@<commit-hash>`. This is a good option when you want to immediately pin to a specific Semantic Version or commit.
|
|
* Manually update `go.mod`. If one of the two options above doesn't suit you, do this -- but very carefully.
|
|
3. Create a git commit to reflect your code changes.
|
|
|
|
|
|
[go-modules]: https://github.com/golang/go/wiki/Modules
|
|
[go-modules-activate]: https://github.com/golang/go/wiki/Modules#how-to-install-and-activate-module-support
|
|
[module-aware-go-get]: https://tip.golang.org/cmd/go/#hdr-Module_aware_go_get
|