influxdb/pkger/doc.go

124 lines
4.7 KiB
Go

/*
Package pkger implements a means to create and consume reusable
templates for what will eventually come to support all influxdb
resources. As of writing this we have support for creating buckets,
dashboards, labels, and variables. All the resources can be cloned
to create a new pkg from existing resources as well.
The parser supports both JSON and YAML encodings as well as a number
of different ways to read the file/reader/string as it may.
As an example, you can use the following to parse and validate a YAML
file and see a summary of its contents:
newPkg, err := Parse(EncodingYAML, FromFile(PATH_TO_FILE))
if err != nil {
panic(err) // handle error as you see fit
}
sum := newPkg.Summary()
fmt.Println(sum) // do something with the summary
The parser will validate all contents of the package and provide any
and all fields/entries that failed validation.
If you wish to use the Pkg type in your transport layer and let the
the transport layer manage the decoding, then you can run the following
to validate the package after the raw decoding is done:
if err := pkg.Validate(); err != nil {
panic(err) // handle error as you see fit
}
If a validation error is encountered during the validation or parsing then
the error returned will be of type *parseErr. The parseErr provides a rich
set of validations failures. There can be numerous failures in a package
and we did our best to inform the caller about them all in a single run.
If you want to see the effects of a package before applying it to the
organization's influxdb platform, you have the flexibility to dry run the
package and see the outcome of what would happen after it were to be applied.
You may use the following to dry run a package within your organization:
svc := NewService(serviceOpts...)
summary, diff, err := svc.DryRun(ctx, orgID, pkg)
if err != nil {
panic(err) // handle error as you see fit
}
// explore the summary and diff
The diff provided here is a diff of the existing state of the platform for
your organization and the concluding the state after the application of a
package. All buckets, labels, and variables, when given a name that already
exists, will not create a new resource, but rather, will edit the existing
resource. If this is not a desired result, then rename your bucket to something
else to avoid the imposed changes applying this package would incur. The summary
provided is a summary of hte package itself. If a resource exists all IDs will
be populated for them, if they do not, then they will be zero values. Any zero
value ID is safe to assume is not populated. All influxdb.ID's must be non zero
to be valid.
If you would like to apply a package you may use the service to do so. The
following will apply the package in full to the provided organization.
svc := NewService(serviceOpts...)
summary, err := svc.Apply(ctx, orgID, pkg)
if err != nil {
panic(err) // handle error as you see fit
}
// explore the summary
The summary will be populated with valid IDs that were created during the
application of the package. If an error is encountered during the application
of a package, then all changes that had occurred will be rolled back. However, as
a warning for buckets, changes may have incurred destructive changes. The changes
are not applied inside a large transaction, for numerous reasons, but it is
something to be considered. If you have dry run the package before it is to be
applied, then the changes should have been made known to you. If not, then there is
potential loss of data if the changes to a bucket resulted in the retention period
being shortened in the package.
If you would like to export existing resources into the form of a package, then you
have the ability to do so using the following:
resourcesToClone := []ResourceToClone{
{
Kind: KindBucket,
ID: Existing_BUCKET_ID,
Name: "new bucket name"
},
{
Kind: KindDashboard,
ID: Existing_Dashboard_ID,
},
{
Kind: KindLabel,
ID: Existing_Label_ID,
},
{
Kind: KindVarible,
ID: Existing_Var_ID,
},
}
svc := NewService(serviceOpts...)
newPkg, err := svc.CreatePkg(ctx,
CreateWithMetadata(Metadata{
Name: "pkg name",
Description: "stand up desc",
Version: "v1.0.0",
}),
CreateWithExistingResources(resourcesToClone...),
)
if err != nil {
panic(err) // handle error as you see fit
}
// explore newly created and validated package
Things to note about the behavior of exporting existing resources. All label
associations with existing resources will be included in the new package.
However, the variables that are used within a dashboard query will not be added
automatically to the package. Variables will need to be passed in alongside
the dashboard to be added to the package.
*/
package pkger