The default configuration assumes you are using kube2iam to manage pod permissions. To set up a role for this controller use the following command
export INSTANCE_ROLE_ARNS=`comma delimited list of k8s worker instance ARNs`
make iam
To build and deploy the controller
export IMG=`some ecr repository`
export IAMROLEARN=`the iam role arn created above`
make docker-build
make docker-push
make deploy
---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: foobar-ingress
annotations:
kubernetes.io/ingress.class: apigateway
apigateway.ingress.kubernetes.io/stage-name: prod
apigateway.ingress.kubernetes.io/client-arns: arn::foo,arn::bar
apigateway.ingress.kubernetes.io/nginx-replicas: "3"
apigateway.ingress.kubernetes.io/nginx-image: nginx:latest
apigateway.ingress.kubernetes.io/nginx-service-port: "9090"
apigateway.authorizer.cognito.userpool-arns: "arn::cog-pool"
apigateway.ingress.kubernetes.io/cf-s3-object-key: "cf-stack"
apigateway.ingress.kubernetes.io/cf-s3-bucket-name: "bucket-name"
spec:
rules:
- http:
paths:
- backend:
serviceName: foo-service
servicePort: 8080
path: /api/v1/foo
- backend:
serviceName: bar-service
servicePort: 8080
path: /api/v1/bar