Newer
Older
AnthosCertManager / pkg / apis / anthoscertmanager / v1 / register.go
/*
Copyright 2022.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

// Package anthoscertmanager contains API Schema definitions for the  v1 API group
// +kubebuilder:object:generate=true
// +groupName=anthos-cert-manager.io
package v1

import (
	"gitbucket.jerxie.com/yangyangxie/AnthosCertManager/pkg/apis/anthoscertmanager"
	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"

	"k8s.io/apimachinery/pkg/runtime"
	"k8s.io/apimachinery/pkg/runtime/schema"
)

var (
	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes)
	localSchemeBuilder = &SchemeBuilder

	AddToScheme = localSchemeBuilder.AddToScheme
)

// GroupVersion is group version used to register these objects
var SchemeGroupVersion = schema.GroupVersion{Group: anthoscertmanager.GroupName, Version: "v1"}

// Resource takes an unqualified resource and returns a Group qualified GroupResource
func Resource(resource string) schema.GroupResource {
	return SchemeGroupVersion.WithResource(resource).GroupResource()
}

// Adds the list of known types to api.Scheme.
func addKnownTypes(scheme *runtime.Scheme) error {
	scheme.AddKnownTypes(SchemeGroupVersion,
		&Certificate{},
		&CertificateList{},
		// &Issuer{},
		// &IssuerList{},
		// &ClusterIssuer{},
		// &ClusterIssuerList{},
		&CertificateRequest{},
		&CertificateRequestList{},
	)
	metav1.AddToGroupVersion(scheme, SchemeGroupVersion)
	return nil
}

func init() {
	// We only register manually written functions here. The registration of the
	// generated functions takes place in the generated files. The separation
	// makes the code compile even when the generated files are missing.
	localSchemeBuilder.Register(addKnownTypes)
}