-
Notifications
You must be signed in to change notification settings - Fork 4.2k
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
Bearer Token Authentication not responding #8794
Comments
Unfortunately, that sounds like an issue with token size. Most web servers support summary request header sizes up to 4-8 kB. We do not have any logic to detect token length. We could add that, but it would still not solve your issue. Does |
Dear @floreks, I'm a college of Kevin. I'm able to use the token in kubectl --token. so that does not seem to be the problem. Could maybe be 4 the limit or something? Thanks for checking Are there test commands we can try to run in the pod to see if the header is added correctly in the response? Thanks |
I think that kong by default supports summary header sizes up to 8 kB. They are using nginx underneath. Our UI -> API most probably has a 4 kB limit currently. I'd have to debug it on our side to make sure where it gets terminated. If you can configure token content and get rid of unused information it should make it work for now. I know that some providers include lots of unnecessary information that are not required by Kubernetes API server. |
Hi @floreks We are using Azure kubelogin, which does not allow configuring the token content as far as I know. I have taken a quick glance at the code with my limited go knowledge. Line 99 in 1d4897c
|
AFAIR azure allows configuring JWT token content, groups, audience, etc. With azure it is usually an issue of configuring too many groups and that all of them are embedded into the token, not only actually used ones. |
Regarding code changes, max header size would need to be checked and increased for both API and Auth modules. If that's the only issue. |
I can indeed see that there are many groups included in the token, but unfortunately i dont find a way to configure the response. We are using kubelogin which does not have the option to do so, but if you know of another way that leverages azure authentication to generate the token, it might help us to (temporarily) overcome this issue.
Given the behavior it does look like that would be the issue, but the only way to be sure is to test it of course. What would be the best course of action to get this tested? |
@floreks Thanks for finding the potential issue. Thanks for checking |
@floreks Did you get the chance to look at this? Or what can we do to make this move forward? |
It's a bit problematic to test locally, unfortunately. From what I have checked header is not trimmed on our side (auth container). It was able to receive headers bigger than 4kB. Configuring API server with a custom OIDC exchange to allow testing custom tokens is time-consuming. I didn't get a chance to do a full end-to-end test to figure out the root cause yet. On our side header size does not seem to be the problem. |
I was facing this issue and managed to login to kong-proxy with a regular admin-user token after i recreated it. |
This would reduce the length of the token, and as such avoid the issue. Unfortunately when you have no control over the token length (such as with azure generated tokens) this does not help. |
My use case is: |
The Kubernetes project currently lacks enough contributors to adequately respond to all issues. This bot triages un-triaged issues according to the following rules:
You can:
Please send feedback to sig-contributor-experience at kubernetes/community. /lifecycle stale |
The Kubernetes project currently lacks enough active contributors to adequately respond to all issues. This bot triages un-triaged issues according to the following rules:
You can:
Please send feedback to sig-contributor-experience at kubernetes/community. /lifecycle rotten |
/remove-lifecycle rotten |
This is still a show stopper for many install targets. |
agreed, we are still not able to update because of this issue. |
This issue is incredibly frustrating, I have tried everything but can't seem to get this working.
I have created a token for the "default" serviceaccount. When authenticating using
When I open my browser and navigate to the dashboard I get "401 Unauthorized", dashboard-auth shows:
I have no idea how to get this working. |
@Netroxen Any luck ? I'm in exactly in the same situation, /api/v1/me returns {"authenticated":true} but the same request in a browser results in error logged in auth pod {"ErrStatus":{"metadata":{},"status":"Failure","message":"MSG_LOGIN_UNAUTHORIZED_ERROR","reason":"Unauthorized","code":401}} It can't be a token issue. Passing the same token to the cluster API endpoint works. |
What type of token are you using? Service account or provider-specific? |
Same here. On my side I'm trying to configure a Github oauth backend. Here is my config - name: Setup oauth proxy
kubernetes.core.k8s:
kubeconfig: "{{ k8s_kubeconfig_path }}"
state: present
definition:
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
k8s-app: oauth2-proxy
name: oauth2-proxy
namespace: kubernetes-dashboard
spec:
replicas: 1
selector:
matchLabels:
k8s-app: oauth2-proxy
template:
metadata:
labels:
k8s-app: oauth2-proxy
spec:
containers:
- args:
- --email-domain=*
- --http-address=0.0.0.0:4180
env:
- name: OAUTH2_PROXY_PROVIDER
value: github
- name: OAUTH2_PROXY_LOGIN_URL
value: https://mygithub.enterprise.com/login/oauth/authorize
- name: OAUTH2_PROXY_REDEEM_URL
value: https://mygithub.enterprise.com/login/oauth/access_token
- name: OAUTH2_PROXY_REDIRECT_URL
value: "https://{{ k8s_dashboard_host }}/oauth2/callback"
- name: OAUTH2_PROXY_VALIDATE_URL
value: https://mygithub.enterprise.com/api/v3
- name: OAUTH2_PROXY_GITHUB_ORG
value: myorg
- name: OAUTH2_PROXY_GITHUB_TEAM
value: myteam
- name: OAUTH2_PROXY_CLIENT_ID
value: client_id
- name: OAUTH2_PROXY_CLIENT_SECRET
value: secret
- name: OAUTH2_PROXY_COOKIE_SECRET
value: secret
- name: OAUTH2_PROXY_UPSTREAM
value: "https://{{ k8s_dashboard_host }}"
- name: OAUTH2_PROXY_SSL_INSECURE_SKIP_VERIFY
value: "true"
- name: OAUTH2_PROXY_INSECURE_OIDC_ALLOW_UNVERIFIED_EMAIL
value: "true"
- name: OAUTH2_PROXY_PASS_AUTHORIZATION_HEADER
value: "true"
- name: OAUTH2_PROXY_SSL_UPSTREAM_INSECURE_SKIP_VERIFY
value: "true"
- name: OAUTH2_PROXY_OIDC_EMAIL_CLAIM
value: email
- name: OAUTH2_PROXY_GROUPS_CLAIM
value: groups
- name: OAUTH2_PROXY_SKIP_PROVIDER_BUTTON
value: "true"
- name: OAUTH2_PROXY_SET_AUTHORIZATION_HEADER
value: "true"
- name: OAUTH2_PROXY_PASS_ACCESS_TOKEN
value: "true"
- name: OAUTH2_PROXY_PASS_USER_HEADERS
value: "true"
- name: OAUTH2_PROXY_SET_XAUTHREQUEST
value: "true"
image: quay.io/oauth2-proxy/oauth2-proxy:latest
imagePullPolicy: Always
name: oauth2-proxy
ports:
- containerPort: 4180
protocol: TCP
- name: Setup oauth proxy service
kubernetes.core.k8s:
kubeconfig: "{{ k8s_kubeconfig_path }}"
state: present
definition:
apiVersion: v1
kind: Service
metadata:
labels:
k8s-app: oauth2-proxy
name: oauth2-proxy
namespace: kubernetes-dashboard
spec:
ports:
- name: http
port: 4180
protocol: TCP
targetPort: 4180
selector:
k8s-app: oauth2-proxy
- name: Setup oauth proxy ingress
kubernetes.core.k8s:
kubeconfig: "{{ k8s_kubeconfig_path }}"
state: present
definition:
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: oauth2-proxy
namespace: kubernetes-dashboard
spec:
ingressClassName: nginx
rules:
- host: "{{ k8s_dashboard_host }}"
http:
paths:
- path: /oauth2
pathType: Prefix
backend:
service:
name: oauth2-proxy
port:
number: 4180
- when: (expose_k8s_dashboard_with_ingress | default(false)) and k8s_dashboard_tls is not defined
name: Create dashboard route
kubernetes.core.k8s:
kubeconfig: "{{ k8s_kubeconfig_path }}"
state: present
definition:
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: dashboard-ingress
namespace: kubernetes-dashboard
annotations:
kubernetes.io/ingress.class: "nginx"
nginx.ingress.kubernetes.io/auth-url: "https://$host/oauth2/auth"
nginx.ingress.kubernetes.io/auth-signin: "https://$host/oauth2/start?rd=$escaped_request_uri"
# nginx.ingress.kubernetes.io/auth-response-headers: "Authorization"
ingress.kubernetes.io/ssl-redirect: "true"
nginx.ingress.kubernetes.io/backend-protocol: "HTTPS"
nginx.ingress.kubernetes.io/auth-response-headers: >-
X-Auth-Request-Email,X-Auth-Request-Preferred-,X-Auth-Request-Access-Token,
X-Auth-Request-Roles,X-Auth-Request-User,X-Auth-Request-Groups,X-Forwarded-Groups,
Authorization
spec:
rules:
- host: "{{ k8s_dashboard_host }}"
http:
paths:
- pathType: Prefix
path: "/"
backend:
service:
name: kubernetes-dashboard-kong-proxy
port:
number: 443 oauth is working fine, I get redirected to my Github enterprise instance. But in the kubernetes-dashboard-auth:
|
Still trying to figure out where the Authorization token is lost. The oauth process seems to work as expected. I'm redirected to Github to allow the app. In the browser logs I can see that the callback URL has been called. Headers received by the http-echo: {
"path": "/",
"headers": {
"host": "dashboard.kubespray-dev.lab.net",
"x-request-id": "65d14d649252dcdaca339f08d1601ecb",
"x-real-ip": "10.233.65.27",
"x-forwarded-for": "10.233.65.27",
"x-forwarded-host": "dashboard.kubespray-dev.lab.net",
"x-forwarded-port": "443",
"x-forwarded-proto": "https",
"x-forwarded-scheme": "https",
"x-scheme": "https",
"cache-control": "max-age=0",
"sec-ch-ua": "\"Google Chrome\";v=\"131\", \"Chromium\";v=\"131\", \"Not_A Brand\";v=\"24\"",
"sec-ch-ua-mobile": "?0",
"sec-ch-ua-platform": "\"Windows\"",
"upgrade-insecure-requests": "1",
"user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36",
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7",
"sec-fetch-site": "none",
"sec-fetch-mode": "navigate",
"sec-fetch-user": "?1",
"sec-fetch-dest": "document",
"accept-encoding": "gzip, deflate, br, zstd",
"accept-language": "fr-FR,fr;q=0.9,en-US;q=0.8,en;q=0.7",
"dnt": "1",
"sec-gpc": "1",
"priority": "u=0, i",
"cookie": "_oauth2_proxy=JM_yArn54Xc--TRUNCATED--LrACBOQ="
},
"method": "GET",
"body": "",
"fresh": false,
"hostname": "dashboard.kubespray-dev.lab.net",
"ip": "10.233.65.27",
"ips": [
"10.233.65.27"
],
"protocol": "https",
"query": {},
"subdomains": [
"glabs",
"k8s",
"kubespray-dev",
"dashboard"
],
"xhr": false,
"os": {
"hostname": "echo-server"
},
"connection": {}
} |
If the token size is too big it might not work as it will be trimmed to fit max header size. |
It works only if I set the token in the nginx header like described above. apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: dashboard-ingress
namespace: kubernetes-dashboard
annotations:
kubernetes.io/ingress.class: "nginx"
ingress.kubernetes.io/ssl-redirect: "true"
nginx.ingress.kubernetes.io/backend-protocol: "HTTPS"
nginx.ingress.kubernetes.io/auth-url: "https://$host/oauth2/auth"
nginx.ingress.kubernetes.io/auth-signin: "https://$host/oauth2/start?rd=$escaped_request_uri"
nginx.ingress.kubernetes.io/auth-response-headers: "Authorization"
nginx.ingress.kubernetes.io/large-client-header-buffers: "4 16k"
nginx.ingress.kubernetes.io/configuration-snippet: |
proxy_pass_header "Authorization";
proxy_set_header Authorization "Bearer XXXXX";
spec:
ingressClassName: nginx
rules:
- host: "{{ k8s_dashboard_host }}"
http:
paths:
- pathType: Prefix
path: "/"
backend:
service:
name: kubernetes-dashboard-kong-proxy
port:
number: 443 Is that normal? I don't have the same behavior on Openshift. |
You can test whether the K8S API server accepts the access token you are getting from the OIDC with |
Thanks @floreks for all the info. I'll try to update the API server config and give update here in case it help other Googlers. |
What happened?
When trying to login using a Bearer Token the page is not responding.
We can find this in the logs of the auth-pod:
in the kong-rpoxy we find this:
and in the devtools i can see the response 500 from /api/v1/me is this:
The token is correct because it works for directly authenticating. Also, when i just type some random characters, the UI returns a clear error and in devtools i can see it is returned from api/v1/login instead
What did you expect to happen?
The page responds and you are logged in (or you get an error message about invalid credentials)
How can we reproduce it (as minimally and precisely as possible)?
It is unclear, we have 2 environments where it works, and 2 others where it doesn't work. The environments are programatically deployed, and we can see no difference in configuration between the clusters.
The only difference we find is that the bearer token is much longer on the environment where it doesn't work so our best guess is that it has to do with this.
Anything else we need to know?
We are now running behind an Istio Virtualservice that redirects to Kong Proxy, but that should not be related, as we tried running istio directly without Kong. We also get the same result when using a portforward. (on the kong proxy, port forward does not seem to work since the pods have been split up)
What browsers are you seeing the problem on?
Chrome, Microsoft Edge, Firefox
Kubernetes Dashboard version
7.1.1 (Helm)
Kubernetes version
1.28.3
Dev environment
No response
The text was updated successfully, but these errors were encountered: