AWS Simple Queue Service Source¶
The IntegrationSource supports the Amazon Web Services (AWS) Simple Queue Service (SQS) service, through its aws.sqs property.
Amazon credentials¶
There are two options for authenticating to AWS.
Access key and secret¶
To use an IAM User access key and secret, create a Kubernetes Secret in the namespace of the resource. The Secret can be created like:
kubectl -n <namespace> create secret generic my-secret --from-literal=aws.accessKey=<accessKey> --from-literal=aws.secretKey=<secretKey>
IntegrationSource .spec.aws.auth section reference the Secret like this:
      auth:
        secret:
          ref:
            name: "my-secret"
Pod Default Credentials¶
If you are using IAM Role for Service Accounts or Pod Identity, you can create a Kubernetes ServiceAccount and associate it with an AWS IAM role. Then in the IntegrationSource .spec.aws.auth section specify the name of the ServiceAccount. This will assign the ServiceAccount to the Deployment resource created for the IntegrationSource.
      auth:
        serviceAccountName: "my-service-account"
AWS SQS Source Example¶
Below is an IntegrationSource to receive data from AWS SQS.
apiVersion: sources.knative.dev/v1alpha1
kind: IntegrationSource
metadata:
  name: integration-source-aws-sqs
  namespace: knative-samples
spec:
  aws:
    sqs:
      arn: "arn:aws:s3:::my-queue"
      region: "eu-north-1"
    auth:
      secret:
        ref:
          name: "my-secret"
  sink:
    ref:
      apiVersion: eventing.knative.dev/v1
      kind: Broker
      name: default
aws.sqs object we define the name of the queue (or arn) and its region. The credentials for the AWS service are referenced from the my-secret Kubernetes Secret
More details about the Apache Camel Kamelet aws-sqs-source.