Andrey Smirnov 753a82188f
refactor: move pkg/resources to machinery
Fixes #4420

No functional changes, just moving packages around.

Signed-off-by: Andrey Smirnov <andrey.smirnov@talos-systems.com>
2021-11-15 19:50:35 +03:00

98 lines
2.5 KiB
Go

// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
package kubespan
import (
"fmt"
"github.com/cosi-project/runtime/pkg/resource"
"github.com/cosi-project/runtime/pkg/resource/meta"
"inet.af/netaddr"
)
// IdentityType is type of Identity resource.
const IdentityType = resource.Type("KubeSpanIdentities.kubespan.talos.dev")
// LocalIdentity is the resource ID for the local node KubeSpan identity.
const LocalIdentity = resource.ID("local")
// Identity resource holds node identity (as a member of the cluster).
type Identity struct {
md resource.Metadata
spec IdentitySpec
}
// IdentitySpec describes KubeSpan keys and address.
//
// Note: IdentitySpec is persisted on disk in the STATE partition,
// so YAML serialization should be kept backwards compatible.
type IdentitySpec struct {
// Address of the node on the Wireguard network.
Address netaddr.IPPrefix `yaml:"address"`
Subnet netaddr.IPPrefix `yaml:"subnet"`
// Public and private Wireguard keys.
PrivateKey string `yaml:"privateKey"`
PublicKey string `yaml:"publicKey"`
}
// NewIdentity initializes a Identity resource.
func NewIdentity(namespace resource.Namespace, id resource.ID) *Identity {
r := &Identity{
md: resource.NewMetadata(namespace, IdentityType, id, resource.VersionUndefined),
spec: IdentitySpec{},
}
r.md.BumpVersion()
return r
}
// Metadata implements resource.Resource.
func (r *Identity) Metadata() *resource.Metadata {
return &r.md
}
// Spec implements resource.Resource.
func (r *Identity) Spec() interface{} {
return r.spec
}
func (r *Identity) String() string {
return fmt.Sprintf("kubespan.Identity(%q)", r.md.ID())
}
// DeepCopy implements resource.Resource.
func (r *Identity) DeepCopy() resource.Resource {
return &Identity{
md: r.md,
spec: r.spec,
}
}
// ResourceDefinition implements meta.ResourceDefinitionProvider interface.
func (r *Identity) ResourceDefinition() meta.ResourceDefinitionSpec {
return meta.ResourceDefinitionSpec{
Type: IdentityType,
Aliases: []resource.Type{},
DefaultNamespace: NamespaceName,
PrintColumns: []meta.PrintColumn{
{
Name: "Address",
JSONPath: `{.address}`,
},
{
Name: "PublicKey",
JSONPath: `{.publicKey}`,
},
},
Sensitivity: meta.Sensitive,
}
}
// TypedSpec allows to access the Spec with the proper type.
func (r *Identity) TypedSpec() *IdentitySpec {
return &r.spec
}