Search code examples
nginxkuberneteskubernetes-ingressnginx-ingress

How can I put basic auth on specific HTTP methods in ngnix ingress?


I can create ingress with basic auth. I followed the template from kubernetes/ingress-nginx:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: ingress-with-auth
  annotations:
    # type of authentication
    nginx.ingress.kubernetes.io/auth-type: basic
    # name of the secret that contains the user/password definitions
    nginx.ingress.kubernetes.io/auth-secret: basic-auth
    # message to display with an appropriate context why the authentication is required
    nginx.ingress.kubernetes.io/auth-realm: 'Authentication Required - foo'
spec:
  rules:
  - host: foo.bar.com
    http:
      paths:
      - path: /
        backend:
          serviceName: http-svc
          servicePort: 80

It works fine, but I need to allow 'OPTIONS' method without basic auth for pre-flight requests. Any pointers on how to do it will be very helpful.


Solution

  • I just encountered the same problem. I solved it by using a configuration-snippet.

    apiVersion: networking.k8s.io/v1
    kind: Ingress
    metadata:
      name: my-cors-auth-ingress
      annotations:
        nginx.ingress.kubernetes.io/configuration-snippet: |
          # fix cors issues of ingress when using external auth service
          if ($request_method = OPTIONS) {
            add_header Content-Length 0;
            add_header Content-Type text/plain;
            return 204;
          }
          more_set_headers "Access-Control-Allow-Credentials: true";
          more_set_headers "Access-Control-Allow-Methods: GET, POST, PUT, PATCH, DELETE, OPTIONS";
          more_set_headers "Access-Control-Allow-Headers: DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization";
          more_set_headers "Access-Control-Allow-Origin: $http_origin";
          more_set_headers "Access-Control-Max-Age: 600";
        nginx.ingress.kubernetes.io/auth-url: "http://auth-service.default.svc.cluster.local:80"