Vendor cfssl and cfssljson
This commit is contained in:
28
vendor/github.com/cloudflare/cfssl/cli/bundle/BUILD
generated
vendored
Normal file
28
vendor/github.com/cloudflare/cfssl/cli/bundle/BUILD
generated
vendored
Normal file
@@ -0,0 +1,28 @@
|
||||
load("@io_bazel_rules_go//go:def.bzl", "go_library")
|
||||
|
||||
go_library(
|
||||
name = "go_default_library",
|
||||
srcs = ["bundle.go"],
|
||||
importmap = "k8s.io/kubernetes/vendor/github.com/cloudflare/cfssl/cli/bundle",
|
||||
importpath = "github.com/cloudflare/cfssl/cli/bundle",
|
||||
visibility = ["//visibility:public"],
|
||||
deps = [
|
||||
"//vendor/github.com/cloudflare/cfssl/bundler:go_default_library",
|
||||
"//vendor/github.com/cloudflare/cfssl/cli:go_default_library",
|
||||
"//vendor/github.com/cloudflare/cfssl/ubiquity:go_default_library",
|
||||
],
|
||||
)
|
||||
|
||||
filegroup(
|
||||
name = "package-srcs",
|
||||
srcs = glob(["**"]),
|
||||
tags = ["automanaged"],
|
||||
visibility = ["//visibility:private"],
|
||||
)
|
||||
|
||||
filegroup(
|
||||
name = "all-srcs",
|
||||
srcs = [":package-srcs"],
|
||||
tags = ["automanaged"],
|
||||
visibility = ["//visibility:public"],
|
||||
)
|
88
vendor/github.com/cloudflare/cfssl/cli/bundle/bundle.go
generated
vendored
Normal file
88
vendor/github.com/cloudflare/cfssl/cli/bundle/bundle.go
generated
vendored
Normal file
@@ -0,0 +1,88 @@
|
||||
// Package bundle implements the bundle command.
|
||||
package bundle
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
|
||||
"github.com/cloudflare/cfssl/bundler"
|
||||
"github.com/cloudflare/cfssl/cli"
|
||||
"github.com/cloudflare/cfssl/ubiquity"
|
||||
)
|
||||
|
||||
// Usage text of 'cfssl bundle'
|
||||
var bundlerUsageText = `cfssl bundle -- create a certificate bundle that contains the client cert
|
||||
|
||||
Usage of bundle:
|
||||
- Bundle local certificate files
|
||||
cfssl bundle -cert file [-ca-bundle file] [-int-bundle file] [-int-dir dir] [-metadata file] [-key keyfile] [-flavor optimal|ubiquitous|force] [-password password]
|
||||
- Bundle certificate from remote server.
|
||||
cfssl bundle -domain domain_name [-ip ip_address] [-ca-bundle file] [-int-bundle file] [-int-dir dir] [-metadata file]
|
||||
|
||||
Flags:
|
||||
`
|
||||
|
||||
// flags used by 'cfssl bundle'
|
||||
var bundlerFlags = []string{"cert", "key", "ca-bundle", "int-bundle", "flavor", "int-dir", "metadata", "domain", "ip", "password"}
|
||||
|
||||
// bundlerMain is the main CLI of bundler functionality.
|
||||
func bundlerMain(args []string, c cli.Config) (err error) {
|
||||
bundler.IntermediateStash = c.IntDir
|
||||
ubiquity.LoadPlatforms(c.Metadata)
|
||||
flavor := bundler.BundleFlavor(c.Flavor)
|
||||
var b *bundler.Bundler
|
||||
// If it is a force bundle, don't require ca bundle and intermediate bundle
|
||||
// Otherwise, initialize a bundler with CA bundle and intermediate bundle.
|
||||
if flavor == bundler.Force {
|
||||
b = &bundler.Bundler{}
|
||||
} else {
|
||||
b, err = bundler.NewBundler(c.CABundleFile, c.IntBundleFile)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
var bundle *bundler.Bundle
|
||||
if c.CertFile != "" {
|
||||
if c.CertFile == "-" {
|
||||
var certPEM, keyPEM []byte
|
||||
certPEM, err = cli.ReadStdin(c.CertFile)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
if c.KeyFile != "" {
|
||||
keyPEM, err = cli.ReadStdin(c.KeyFile)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
}
|
||||
bundle, err = b.BundleFromPEMorDER(certPEM, keyPEM, flavor, "")
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
} else {
|
||||
// Bundle the client cert
|
||||
bundle, err = b.BundleFromFile(c.CertFile, c.KeyFile, flavor, c.Password)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
}
|
||||
} else if c.Domain != "" {
|
||||
bundle, err = b.BundleFromRemote(c.Domain, c.IP, flavor)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
} else {
|
||||
return errors.New("Must specify bundle target through -cert or -domain")
|
||||
}
|
||||
|
||||
marshaled, err := bundle.MarshalJSON()
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
fmt.Printf("%s", marshaled)
|
||||
return
|
||||
}
|
||||
|
||||
// Command assembles the definition of Command 'bundle'
|
||||
var Command = &cli.Command{UsageText: bundlerUsageText, Flags: bundlerFlags, Main: bundlerMain}
|
Reference in New Issue
Block a user