Skip to content

Commit

Permalink
Draft implementation, wip
Browse files Browse the repository at this point in the history
  • Loading branch information
mmorhun committed Aug 15, 2023
1 parent a5bd04a commit fe6ea2f
Show file tree
Hide file tree
Showing 24 changed files with 1,963 additions and 31 deletions.
8 changes: 4 additions & 4 deletions PROJECT
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,12 @@ projectName: image-controller
repo: github.com/redhat-appstudio/image-controller
resources:
- api:
crdVersion: v1
crdVersion: v1beta1
namespaced: true
controller: true
domain: appstudio.redhat.com
group: appstudio.redhat.com
kind: Controller
path: github.com/redhat-appstudio/image-controller/api/v1alpha1
version: v1alpha1
kind: ImageRepository
path: github.com/redhat-appstudio/image-controller/api/v1beta1
version: v1beta1
version: "3"
36 changes: 36 additions & 0 deletions api/v1beta1/groupversion_info.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
/*
Copyright 2023.
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 v1beta1 contains API Schema definitions for the appstudio.redhat.com v1beta1 API group
// +kubebuilder:object:generate=true
// +groupName=appstudio.redhat.com.appstudio.redhat.com
package v1beta1

import (
"k8s.io/apimachinery/pkg/runtime/schema"
"sigs.k8s.io/controller-runtime/pkg/scheme"
)

var (
// GroupVersion is group version used to register these objects
GroupVersion = schema.GroupVersion{Group: "appstudio.redhat.com.appstudio.redhat.com", Version: "v1beta1"}

// SchemeBuilder is used to add go types to the GroupVersionKind scheme
SchemeBuilder = &scheme.Builder{GroupVersion: GroupVersion}

// AddToScheme adds the types in this group-version to the given scheme.
AddToScheme = SchemeBuilder.AddToScheme
)
146 changes: 146 additions & 0 deletions api/v1beta1/imagerepository_types.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,146 @@
/*
Copyright 2023 Red Hat, Inc.
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 v1beta1

import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)

// / ImageRepositorySpec defines the desired state of ImageRepository
type ImageRepositorySpec struct {
// Requested image repository configuration.
// +optional
Image ImageParameters `json:"image,omitempty"`

// Credentials management.
// +optional
Credentials ImageCredentials `json:"credentials,omitempty"`
}

// ImageParameters describes requested image repository configuration.
type ImageParameters struct {
// Name of the image within configured Quay organization.
// If ommited, then defaults to "cr-namespace/cr-name".
// This field cannot be changed after the resource creation.
// +optional
// +kubebuilder:validation:Pattern="[a-z0-9][.a-z0-9_-]*(/[a-z0-9][.a-z0-9_-]*)*"
Name string `json:"name,omitempty"`

// Visibility defines whether the image is publicly visible.
// Allowed values are public and private.
// "public" is the default.
// +optional
Visibility ImageVisibility `json:"visibility,omitempty"`
}

// +kubebuilder:validation:Enum=public;private
type ImageVisibility string

const (
ImageVisibilityPublic ImageVisibility = "public"
ImageVisibilityPrivate ImageVisibility = "private"
)

type ImageCredentials struct {
// RegenerateToken defines a request to refresh image accessing credentials.
// Refreshes both, push and pull tokens.
// The field gets cleared after the refresh.
RegenerateToken *bool `json:"regenerate-token,omitempty"`
}

// ImageRepositoryStatus defines the observed state of ImageRepository
type ImageRepositoryStatus struct {
// State shows if image repository could be used.
// "ready" means repository was created and usable,
// "failed" means that the image repository creation request failed.
State ImageRepositoryState `json:"state,omitempty"`

// Message shows error information for the request.
// It could contain non critical error, like failed to change image visibility,
// while the state is ready and image resitory could be used.
Message string `json:"message,omitempty"`

// Image describes actual state of the image repository.
Image ImageStatus `json:"image,omitempty"`

// Credentials contain information related to image repository credentials.
Credentials CredentialsStatus `json:"credentials,omitempty"`
}

type ImageRepositoryState string

const (
ImageRepositoryStateReady ImageRepositoryState = "ready"
ImageRepositoryStateFailed ImageRepositoryState = "failed"
)

// ImageStatus shows actual generated image repository parameters.
type ImageStatus struct {
// URL is the full image repository url to push into / pull from.
URL string `json:"url,omitempty"`

// Visibility shows actual generated image repository visibility.
Visibility ImageVisibility `json:"visibility,omitempty"`
}

// CredentialsStatus shows information about generated image repository credentials.
type CredentialsStatus struct {
// GenerationTime shows timestamp when the current credentials were generated.
GenerationTimestamp *metav1.Time `json:"generationTimestamp,omitempty"`

// PushSecretName holds name of the dockerconfig secret with credentials to push (and pull) into the generated repository.
PushSecretName string `json:"push-secret,omitempty"`

// PullSecretName is present only if ImageRepository has labels that connect it to Application and Component.
// Holds name of the dockerconfig secret with credentials to pull only from the generated repository.
// The secret is not present in the same namespace as ImageRepository, but created in
PullSecretName string `json:"pull-secret,omitempty"`

// PushRobotAccountName holds name of the quay robot account with write (push and pull) permissions into the generated repository.
PushRobotAccountName string `json:"push-robot-account,omitempty"`

// PullRobotAccountName is present only if ImageRepository has labels that connect it to Application and Component.
// Holds name of the quay robot account with real (pull only) permissions from the generated repository.
PullRobotAccountName string `json:"pull-robot-account,omitempty"`
}

//+kubebuilder:object:root=true
//+kubebuilder:subresource:status

// ImageRepository is the Schema for the imagerepositories API
// +kubebuilder:printcolumn:name="Image",type="string",JSONPath=".status.image.url"
// +kubebuilder:printcolumn:name="Visibility",type="string",JSONPath=".status.image.visibility"
type ImageRepository struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`

Spec ImageRepositorySpec `json:"spec,omitempty"`
Status ImageRepositoryStatus `json:"status,omitempty"`
}

//+kubebuilder:object:root=true

// ImageRepositoryList contains a list of ImageRepository
type ImageRepositoryList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []ImageRepository `json:"items"`
}

func init() {
SchemeBuilder.Register(&ImageRepository{}, &ImageRepositoryList{})
}
188 changes: 188 additions & 0 deletions api/v1beta1/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit fe6ea2f

Please sign in to comment.