2023-03-28 23:48:58 +01:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-11 09:12:13 -04:00
|
|
|
// SPDX-License-Identifier: BUSL-1.1
|
2023-03-28 23:48:58 +01:00
|
|
|
|
2016-11-02 17:27:49 -07:00
|
|
|
package version
|
2013-12-19 11:22:08 -08:00
|
|
|
|
2016-07-19 15:06:32 -07:00
|
|
|
import (
|
2023-01-05 14:16:47 -06:00
|
|
|
_ "embed"
|
2022-05-05 20:41:18 -07:00
|
|
|
"fmt"
|
2016-07-19 15:06:32 -07:00
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
2015-07-08 23:22:12 +01:00
|
|
|
var (
|
2016-11-02 17:27:49 -07:00
|
|
|
// The git commit that was compiled. These will be filled in by the
|
|
|
|
// compiler.
|
2020-07-14 15:17:45 -04:00
|
|
|
GitCommit string
|
2013-12-19 11:22:08 -08:00
|
|
|
|
2023-01-05 14:16:47 -06:00
|
|
|
// The next version number that will be released. This will be updated after every release
|
2017-08-28 12:20:21 +02:00
|
|
|
// Version must conform to the format expected by github.com/hashicorp/go-version
|
2017-08-30 13:25:14 +02:00
|
|
|
// for tests to work.
|
2023-01-05 14:16:47 -06:00
|
|
|
// A pre-release marker for the version can also be specified (e.g -dev). If this is omitted
|
|
|
|
// then it means that it is a final release. Otherwise, this is a pre-release
|
|
|
|
// such as "dev" (in development), "beta", "rc1", etc.
|
|
|
|
//go:embed VERSION
|
|
|
|
fullVersion string
|
|
|
|
|
2023-02-28 14:37:52 -06:00
|
|
|
Version, VersionPrerelease, _ = strings.Cut(strings.TrimSpace(fullVersion), "-")
|
2017-08-30 13:25:14 +02:00
|
|
|
|
2022-05-05 20:41:18 -07:00
|
|
|
// https://semver.org/#spec-item-10
|
|
|
|
VersionMetadata = ""
|
|
|
|
|
2022-06-02 12:46:18 -07:00
|
|
|
// The date/time of the build (actually the HEAD commit in git, to preserve stability)
|
2022-06-09 15:55:11 -07:00
|
|
|
// This isn't just informational, but is also used by the licensing system. Default is chosen to be flagantly wrong.
|
|
|
|
BuildDate string = "1970-01-01T00:00:01Z"
|
2016-11-02 17:27:49 -07:00
|
|
|
)
|
2016-07-19 15:06:32 -07:00
|
|
|
|
2023-05-30 17:25:48 -05:00
|
|
|
// BuildInfo includes all available version info for this build
|
|
|
|
type BuildInfo struct {
|
|
|
|
SHA string
|
|
|
|
BuildDate string
|
|
|
|
HumanVersion string
|
|
|
|
FIPS string
|
|
|
|
}
|
|
|
|
|
2016-07-19 18:38:15 -07:00
|
|
|
// GetHumanVersion composes the parts of the version in a way that's suitable
|
|
|
|
// for displaying to humans.
|
|
|
|
func GetHumanVersion() string {
|
2016-07-19 15:06:32 -07:00
|
|
|
version := Version
|
|
|
|
release := VersionPrerelease
|
2022-05-05 20:41:18 -07:00
|
|
|
metadata := VersionMetadata
|
2018-06-20 15:44:19 -04:00
|
|
|
|
2016-07-19 15:06:32 -07:00
|
|
|
if release != "" {
|
2022-05-05 20:41:18 -07:00
|
|
|
version += fmt.Sprintf("-%s", release)
|
|
|
|
}
|
|
|
|
|
2023-06-07 10:57:56 -05:00
|
|
|
if IsFIPS() {
|
|
|
|
version += ".fips1402"
|
|
|
|
}
|
|
|
|
|
2022-05-05 20:41:18 -07:00
|
|
|
if metadata != "" {
|
|
|
|
version += fmt.Sprintf("+%s", metadata)
|
2016-07-19 15:06:32 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Strip off any single quotes added by the git information.
|
2021-04-25 20:22:55 +03:00
|
|
|
return strings.ReplaceAll(version, "'", "")
|
2016-07-19 15:06:32 -07:00
|
|
|
}
|
2023-05-30 17:25:48 -05:00
|
|
|
|
|
|
|
// GetBuildInfo returns all available version information for this build.
|
|
|
|
func GetBuildInfo() *BuildInfo {
|
|
|
|
return &BuildInfo{
|
|
|
|
SHA: GitCommit,
|
|
|
|
BuildDate: BuildDate,
|
|
|
|
HumanVersion: GetHumanVersion(),
|
|
|
|
FIPS: GetFIPSInfo(),
|
|
|
|
}
|
|
|
|
}
|