Nyx Main
You can use the main Nyx library to embed it into your project and use all or some of its features. The github.com/mooltiverse/nyx/src/go/nyx/nyx
package brings the Nyx
structure that is the entry point for all the available commands and features.
Get the library
To install the module locally run:
go get github.com/mooltiverse/nyx/src/go/nyx/nyx
To import it in your source code:
import "github.com/mooltiverse/nyx/src/go/nyx/nyx"
API docs
Thanks to Go docs you can browse the API docs at this URL.
Using the library
Using the library is simple. You just need to create a Nyx
instance and run the publish
command. It takes just one line of code, like:
package main
import nyx "github.com/mooltiverse/nyx/src/go/nyx/nyx"
func main() {
n := nyx.NewNyx()
err := n.Publish() // This is it!
}
In this example Nyx loads the configuration from the files it optionally finds at their default locations and runs the publish
command, which also implies infer
, mark
and make
.
You can get more control on the behavior by injecting some configuration programmatically and running tasks one by one. You can also start Nyx in a specific directory, get access to the internal Git repository object and even the internal state, like in this example:
package main
import (
"fmt"
nyx "github.com/mooltiverse/nyx/src/go/nyx/nyx"
cnf "github.com/mooltiverse/nyx/src/go/nyx/configuration"
)
func main() {
n := nyx.NewNyxIn("~/project") // Nyx now runs on the '~/project' directory
// Create a new configuration layer, set some options, and add it on top
// of other layers at the 'command line' layer level
configurationLayer := cnf.NewSimpleConfigurationLayer()
dryRun := true
prefix := "rel"
configurationLayer.SetDryRun(&dryRun) // make it run dry
configurationLayer.SetReleasePrefix(&prefix) // make it use 'rel' as the prefix for generated versions
var cl cnf.ConfigurationLayer = configurationLayer // this is for casting, but you can use reflections
n.Configuration().WithCommandLineConfiguration(&cl) // inject the configuration
err := n.Infer() // let Nyx infer values from the Git repository
// now we have plenty of values in the State, let's read some...
branch, _ := n.State().GetBranch()
version, _ := n.State().GetVersion()
fmt.Println(*branch)
fmt.Println(*version)
// it might be a good place to run some custom tasks of yours, i.e. using the Git Repository
// let's say you create a RELEASE_NOTES.md file and want to commit it
n.Repository().Commit("Adding RELEASE_NOTES.md")
// then run the remaining tasks one by one
n.Make()
n.Mark()
n.Publish()
}
Logging
Nyx uses Logrus for logging.
You can control verbosity by setting configuration parameters using one of the available means or programmatically by injecting a configuration layer like:
package main
import (
"fmt"
nyx "github.com/mooltiverse/nyx/src/go/nyx/nyx"
cnf "github.com/mooltiverse/nyx/src/go/nyx/configuration"
ent "github.com/mooltiverse/nyx/src/go/nyx/entities"
)
func main() {
n := nyx.NewNyxIn("~/project") // Nyx now runs on the '~/project' directory
// Create a new configuration layer, set some options, and add it on top
// of other layers at the 'command line' layer level
configurationLayer := cnf.NewSimpleConfigurationLayer()
verbosity := ent.INFO
configurationLayer.SetVerbosity(&verbosity) // set logging to INFO
var cl cnf.ConfigurationLayer = configurationLayer // this is for casting, but you can use reflections
n.Configuration().WithRuntimeConfiguration(&cl) // inject the configuration
}