Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

operator ack-lambda-controller (1.5.3) #5134

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 21 additions & 0 deletions operators/ack-lambda-controller/1.5.3/bundle.Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
FROM scratch

# Core bundle labels.
LABEL operators.operatorframework.io.bundle.mediatype.v1=registry+v1
LABEL operators.operatorframework.io.bundle.manifests.v1=manifests/
LABEL operators.operatorframework.io.bundle.metadata.v1=metadata/
LABEL operators.operatorframework.io.bundle.package.v1=ack-lambda-controller
LABEL operators.operatorframework.io.bundle.channels.v1=alpha
LABEL operators.operatorframework.io.bundle.channel.default.v1=alpha
LABEL operators.operatorframework.io.metrics.builder=operator-sdk-v1.28.0
LABEL operators.operatorframework.io.metrics.mediatype.v1=metrics+v1
LABEL operators.operatorframework.io.metrics.project_layout=unknown

# Labels for testing.
LABEL operators.operatorframework.io.test.mediatype.v1=scorecard+v1
LABEL operators.operatorframework.io.test.config.v1=tests/scorecard/

# Copy files to locations specified by labels.
COPY bundle/manifests /manifests/
COPY bundle/metadata /metadata/
COPY bundle/tests/scorecard /tests/scorecard/

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
apiVersion: v1
kind: Service
metadata:
creationTimestamp: null
name: ack-lambda-metrics-service
spec:
ports:
- name: metricsport
port: 8080
protocol: TCP
targetPort: http
selector:
app.kubernetes.io/name: ack-lambda-controller
type: NodePort
status:
loadBalancer: {}
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
creationTimestamp: null
name: ack-lambda-reader
rules:
- apiGroups:
- lambda.services.k8s.aws
resources:
- aliases
- codesigningconfigs
- eventsourcemappings
- functions
- functionurlconfigs
- layerversions
- versions
verbs:
- get
- list
- watch
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
creationTimestamp: null
name: ack-lambda-writer
rules:
- apiGroups:
- lambda.services.k8s.aws
resources:
- aliases
- codesigningconfigs
- eventsourcemappings
- functions
- functionurlconfigs
- layerversions
- versions
verbs:
- create
- delete
- get
- list
- patch
- update
- watch
- apiGroups:
- lambda.services.k8s.aws
resources:
- aliases
- codesigningconfigs
- eventsourcemappings
- functions
- functionurlconfigs
- layerversions
- versions
verbs:
- get
- patch
- update
Original file line number Diff line number Diff line change
@@ -0,0 +1,243 @@
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.16.2
creationTimestamp: null
name: aliases.lambda.services.k8s.aws
spec:
group: lambda.services.k8s.aws
names:
kind: Alias
listKind: AliasList
plural: aliases
singular: alias
scope: Namespaced
versions:
- name: v1alpha1
schema:
openAPIV3Schema:
description: Alias is the Schema for the Aliases API
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
properties:
description:
description: A description of the alias.
type: string
functionEventInvokeConfig:
description: |-
Configures options for asynchronous invocation on an alias.

- DestinationConfig
A destination for events after they have been sent to a function for processing.

Types of Destinations:
Function - The Amazon Resource Name (ARN) of a Lambda function.
Queue - The ARN of a standard SQS queue.
Topic - The ARN of a standard SNS topic.
Event Bus - The ARN of an Amazon EventBridge event bus.

- MaximumEventAgeInSeconds
The maximum age of a request that Lambda sends to a function for processing.

- MaximumRetryAttempts
The maximum number of times to retry when the function returns an error.
properties:
destinationConfig:
description: |-
A configuration object that specifies the destination of an event after Lambda
processes it.
properties:
onFailure:
description: A destination for events that failed processing.
properties:
destination:
type: string
type: object
onSuccess:
description: A destination for events that were processed
successfully.
properties:
destination:
type: string
type: object
type: object
functionName:
type: string
maximumEventAgeInSeconds:
format: int64
type: integer
maximumRetryAttempts:
format: int64
type: integer
qualifier:
type: string
type: object
functionName:
description: |-
The name of the Lambda function.

Name formats

* Function name - MyFunction.

* Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.

* Partial ARN - 123456789012:function:MyFunction.

The length constraint applies only to the full ARN. If you specify only the
function name, it is limited to 64 characters in length.
type: string
functionRef:
description: "AWSResourceReferenceWrapper provides a wrapper around
*AWSResourceReference\ntype to provide more user friendly syntax
for references using 'from' field\nEx:\nAPIIDRef:\n\n\tfrom:\n\t
\ name: my-api"
properties:
from:
description: |-
AWSResourceReference provides all the values necessary to reference another
k8s resource for finding the identifier(Id/ARN/Name)
properties:
name:
type: string
namespace:
type: string
type: object
type: object
functionVersion:
description: The function version that the alias invokes.
type: string
name:
description: The name of the alias.
type: string
provisionedConcurrencyConfig:
description: |-
Configures provisioned concurrency to a function's alias

- ProvisionedConcurrentExecutions
The amount of provisioned concurrency to allocate for the version or alias.
Minimum value of 1 is required
properties:
functionName:
type: string
provisionedConcurrentExecutions:
format: int64
type: integer
qualifier:
type: string
type: object
routingConfig:
description: |-
The routing configuration (https://docs.aws.amazon.com/lambda/latest/dg/configuration-aliases.html#configuring-alias-routing)
of the alias.
properties:
additionalVersionWeights:
additionalProperties:
type: number
type: object
type: object
required:
- functionVersion
- name
type: object
status:
description: AliasStatus defines the observed state of Alias
properties:
ackResourceMetadata:
description: |-
All CRs managed by ACK have a common `Status.ACKResourceMetadata` member
that is used to contain resource sync state, account ownership,
constructed ARN for the resource
properties:
arn:
description: |-
ARN is the Amazon Resource Name for the resource. This is a
globally-unique identifier and is set only by the ACK service controller
once the controller has orchestrated the creation of the resource OR
when it has verified that an "adopted" resource (a resource where the
ARN annotation was set by the Kubernetes user on the CR) exists and
matches the supplied CR's Spec field values.
https://github.com/aws/aws-controllers-k8s/issues/270
type: string
ownerAccountID:
description: |-
OwnerAccountID is the AWS Account ID of the account that owns the
backend AWS service API resource.
type: string
region:
description: Region is the AWS region in which the resource exists
or will exist.
type: string
required:
- ownerAccountID
- region
type: object
conditions:
description: |-
All CRS managed by ACK have a common `Status.Conditions` member that
contains a collection of `ackv1alpha1.Condition` objects that describe
the various terminal states of the CR and its backend AWS service API
resource
items:
description: |-
Condition is the common struct used by all CRDs managed by ACK service
controllers to indicate terminal states of the CR and its backend AWS
service API resource
properties:
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
format: date-time
type: string
message:
description: A human readable message indicating details about
the transition.
type: string
reason:
description: The reason for the condition's last transition.
type: string
status:
description: Status of the condition, one of True, False, Unknown.
type: string
type:
description: Type is the type of the Condition
type: string
required:
- status
- type
type: object
type: array
revisionID:
description: A unique identifier that changes when you update the
alias.
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
status:
acceptedNames:
kind: ""
plural: ""
conditions: null
storedVersions: null
Loading
Loading