strong-barista-29632
01/29/2023, 7:53 AMCSRF_TOKEN_VALIDATION_FAILED
, any clues on how to debug the problem?
The flyte is deployed on self-hosted k8s cluster with an internal domain name and HTTP access (not HTTPS) using template generated by flyte-core
helm chart (helm template flyte-core -f values.yaml
). The OIDC seems to work (After a fresh deployment, when opening flyte console, it will redirect to the gitlab authorization page, and after approval it can redirect back to flyte console page with username show on the top-right corner), but when I try to register workflow according to the tutorial [1] with command flytectl register files --project flytesnacks --domain development --archive flyte-package.tgz --version v1
, the gitlab authorization page is prompted successfully but when redirect back to <http://flyte.example.com/callback|flyte.example.com/callback>
page, it complains about 401
error. And the log of flyteadmin
shows something like
{
"json": {},
"level": "error",
"msg": "Invalid CSRF token cookie [CSRF_TOKEN_VALIDATION_FAILED] CSRF token does not match state 2r4rcd3npg, 3237e1083ec0ae2bd20acbe8a5817d18475faaee5a060d2184ab7ffddd151290 vs OXpoczQyanRxcW43c3hnZ3RjbnBnZjZrNnptMnA2dDY",
"ts": "2023-01-29T06:43:34Z"
}
There are several small questions that might be relevant:
1. In the auth doc [2], there is a comment for redirectUri: <http://localhost:53593/callback>
saying that This should not change
, but I suppose it is for sandbox deployment so I changed it to the domain name something like <http://flyte.example.com/callback>
. Otherwise, it will complains about invalid redirect uri when authorize on gitlab page.
2. For the scopes
, according to the gitlab doc [3], I only set it to read_user
.
3. Any approach to show more logs for flytectl
CLI? I tried to set the log level to 0
, but it does not show anything.
4. Any approach to show more logs for flyteadmin
service? I found there is a flyteadmin.extraArgs
in the template but does not know how to inject --logger.level 0
.
The relevant values.yaml
for auth is shown as following (with some sensitive info masked):
configmap:
adminServer:
auth:
appAuth:
authServerType: External
externalAuthServer:
metadataUrl: .well-known/openid-configuration
thirdPartyConfig:
flyteClient:
clientId: <client_id generated by gitlab>
redirectUri: <http://flyte.example.com/callback>
scopes:
- read_user
authorizedUris:
- <http://flyte.example.com>
- <http://flyteadmin:80>
- <http://flyteadmin.flyte.svc.cluster.local:80>
userAuth:
openId:
baseUrl: <https://git.example.com>
clientId: <client_id generated by gitlab>
scopes:
- openid
server:
security:
useAuth: true
flyteadmin:
secrets:
oidc_client_secret: <client_secret generated by gitlab>
secrets:
adminOauthClientCredentials:
clientId: <client_id generated by gitlab>
clientSecret: <client_secret generated by gitlab>
[1] https://docs.flyte.org/projects/cookbook/en/latest/auto/larger_apps/larger_apps_deploy.html#build-deploy-your-application-to-the-cluster
[2] https://docs.flyte.org/en/latest/deployment/cluster_config/auth_setup.html
[3] https://docs.gitlab.com/ee/integration/oauth_provider.html#view-all-authorized-applicationsfreezing-airport-6809
strong-barista-29632
01/29/2023, 5:44 PMfreezing-airport-6809
freezing-airport-6809
strong-barista-29632
01/30/2023, 2:25 AMstrong-barista-29632
01/30/2023, 4:26 AMconfig.yaml
I use now is
admin:
authType: Pkce
endpoint: dns:///flyte.example.com
insecure: false
insecureSkipVerify: true
logger:
level: 0
show-source: true
With this config, the gitlab authorization page can be prompted successfully but 401
error after callback to flyteadmin
.
I also tried the ClientSecret
type but failed. It complains about JWT_VERIFICATION_FAILED
or 500
error for gitlab. The gitlab authorization page will not shown.icy-agent-73298
01/30/2023, 6:18 AMIn the auth doc [2], there is a comment forThis needs to remain the samesaying thatredirectUri: <http://localhost:53593/callback>
, but I suppose it is for sandbox deployment so I changed it to the domain name something likeThis should not change
.<http://flyte.example.com/callback>
<http://localhost:53593/callback>
as this is the url where flytectl recives a callback to exchange auth code for the token in PKCE flow started by it.
So this would remain same irrespective of sandbox.
Otherwise, it will complains about invalid redirect uri when authorize on gitlab page.You don’t have to configure this callback url in gitlab . Can you more details here
For theCurrently its required according to our current set of supported providers to define scope name, according to the gitlab doc [3], I only set it toscopes
.read_user
all
. other providers like okta support adding new scopes for oauth apps
Any approach to show more logs forYou can pass arguments --logger.level 6CLI? I tried to set the log level toflytectl
, but it does not show anything.0
Any approach to show more logs foryou can edit you flyte admin base configmap and add logger configuration with level 6service? I found there is aflyteadmin
in the template but does not know how to injectflyteadmin.extraArgs
.--logger.level 0
logger.yaml: |
logger:
level: 6
strong-barista-29632
01/30/2023, 6:24 AMstrong-barista-29632
01/30/2023, 8:23 AMredirectUri
part. Let us assume the flyte is deployed with an internal domain name, for example, <http://flyte.example.com>
.
The redirectUri
need to be configured for both flyteadmin
and gitlab Application [1]. And during the OAuth process [2], web browser will firstly redirect to the Gitlab authorization page, And after clicking Authorize
, it will redirect back to the configured redirectUri
. If we use <http://localhost:53593/callback>
then it will be an invalid address since the service is deploy with <http://flyte.example.com>
instead.
Any comments?
[1] https://docs.gitlab.com/ee/integration/oauth_provider.html#create-a-user-owned-application
[2] https://docs.gitlab.com/ee/api/oauth2.html#authorization-code-with-proof-key-for-code-exchange-pkcetall-lock-23197
redirectUri
is <http://localhost:53593/callback>
?strong-barista-29632
01/30/2023, 10:19 AM<http://localhost:53593/callback>
otherwise it will complains about invalid redirect uri. And then after I click the Authorize
button when being prompted to Gitlab Authorization page, it will redirect back to <http://localhost:53593/callback>
in web browser which is a invalid address since the flyte is deployed on the server.icy-agent-73298
01/30/2023, 3:08 PMconfigmap:
adminServer:
auth:
appAuth:
authServerType: External
externalAuthServer:
metadataUrl: .well-known/openid-configuration
thirdPartyConfig:
flyteClient:
clientId: <client_id generated by gitlab> => This clientId is used for flytectl client and should be configured as native ouath app
redirectUri: <http://flyte.example.com/callback> => the redirectURI here should be <http://localhost:53593/callback> since flytectl starts a http server to receive the callback in this flow
scopes:
- read_user
authorizedUris:
- <http://flyte.example.com>
- <http://flyteadmin:80>
- <http://flyteadmin.flyte.svc.cluster.local:80>
userAuth:
openId:
baseUrl: <https://git.example.com>
clientId: <client_id generated by gitlab> => this clientId is used for flyteconsole or UI client which uses client credentials flow and it secret is stored in oidc_client_secret . The redirect URI for this app should be <http://flyte.example.com/callback> or wherever your <flyte domain is configured>/callback
scopes:
- openid
server:
security:
useAuth: true
flyteadmin:
secrets:
oidc_client_secret: <client_secret generated by gitlab> => used as secret for openId.clientId
secrets:
adminOauthClientCredentials:
clientId: <client_id generated by gitlab> => this clientId is used by flytepropeller and scheduler . this should also use the same callback used by flyteconsole <http://flyte.example.com/callback> or wherever your <flyte domain is configured>/callback
clientSecret: <client_secret generated by gitlab> => secret for the above clientId
icy-agent-73298
01/30/2023, 3:13 PMicy-agent-73298
01/30/2023, 3:14 PMstrong-barista-29632
01/31/2023, 5:43 AMstrong-barista-29632
01/31/2023, 10:15 AMPkce
auth type, but the auth process still does not work. The config is something like
admin:
authType: Pkce
endpoint: dns:///flyte.example.com
insecure: false
insecureSkipVerify: true
And the error log is
{"json":{"src":"token_source_provider.go:140"},"level":"error","msg":"Error fetching token using auth flow due to error while exchanging auth code due to oauth2: cannot fetch token: 401 Unauthorized\nResponse: {\"error\":\"invalid_client\",\"error_description\":\"Client authentication failed due to unknown client, no client authentication included, or unsupported authentication method.\"}","ts":"2023-01-31T18:07:09+08:00"}
Error: authentication error! Original Error: rpc error: code = Unauthenticated desc = token parse error [JWT_VERIFICATION_FAILED] Could not retrieve id token from metadata, caused by: rpc error: code = Unauthenticated desc = Request unauthenticated with IDToken, Auth Error: error while exchanging auth code due to oauth2: cannot fetch token: 401 Unauthorized
Response: {"error":"invalid_client","error_description":"Client authentication failed due to unknown client, no client authentication included, or unsupported authentication method."}
{"json":{"src":"main.go:13"},"level":"error","msg":"authentication error! Original Error: rpc error: code = Unauthenticated desc = token parse error [JWT_VERIFICATION_FAILED] Could not retrieve id token from metadata, caused by: rpc error: code = Unauthenticated desc = Request unauthenticated with IDToken, Auth Error: error while exchanging auth code due to oauth2: cannot fetch token: 401 Unauthorized\nResponse: {\"error\":\"invalid_client\",\"error_description\":\"Client authentication failed due to unknown client, no client authentication included, or unsupported authentication method.\"}","ts":"2023-01-31T18:07:09+08:00"}
BTW, I failed to find any place to set the client_secret
for flytectl
in helm chart template, that may be the cause for the unauthenticated problem.
I also tried ClientSecret
auth type, but it will get 500 internal error from gitlab. The config is something like
admin:
authType: ClientSecret
clientId: <client id for flytectl>
clientSecretLocation: <path of client secret for flytectl>
endpoint: dns:///flyte.example.com
insecure: false
insecureSkipVerify: true
scopes: [ "openid", "read_user"]
The relevant error log is
{
"json": {
"src": "main.go:13"
},
"level": "error",
"msg": "Connection Info: [Endpoint: dns:///flyte.example.com, InsecureConnection?: false, AuthMode: ClientSecret]: rpc error: code = Unauthenticated desc = transport: per-RPC creds failed due to error: oauth2: cannot fetch token: 500 Internal Server Error\nResponse: <!DOCTYPE html>\n<html>\n<head>\n <meta content=\"width=device-width, initial-scale=1, maximum-scale=1\" name=\"viewport\">\n <title>Something went wrong (500)</title>\n <style>\n body {\n color: #666;\n text-align: center;\n font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n margin: auto;\n font-size: 14px;\n }\n\n h1 {\n font-size: 56px;\n line-height: 100px;\n font-weight: 400;\n color: #456;\n }\n\n h2 {\n font-size: 24px;\n color: #666;\n line-height: 1.5em;\n }\n\n h3 {\n color: #456;\n font-size: 20px;\n font-weight: 400;\n line-height: 28px;\n }\n\n hr {\n max-width: 800px;\n margin: 18px auto;\n border: 0;\n border-top: 1px solid #EEE;\n border-bottom: 1px solid white;\n }\n\n img {\n max-width: 40vw;\n display: block;\n margin: 40px auto;\n }\n\n a {\n line-height: 100px;\n font-weight: 400;\n color: #4A8BEE;\n font-size: 18px;\n text-decoration: none;\n }\n\n .container {\n margin: auto 20px;\n }\n\n .go-back {\n display: none;\n }\n\n </style>\n</head>\n\n<body>\n <a href=\"/\">\n <img src=\"\"\n alt=\"GitLab Logo\" />\n </a>\n <h1>\n 500\n </h1>\n <div class=\"container\">\n <h3>Whoops, something went wrong on our end.</h3>\n <hr />\n <p>Try refreshing the page, or going back and attempting the action again.</p>\n <p>Please contact your GitLab administrator if this problem persists.</p>\n <a href=\"javascript:history.back()\" class=\"js-go-back go-back\">Go back</a>\n </div>\n <script>\n (function () {\n var goBack = document.querySelector('.js-go-back');\n\n if (history.length > 1) {\n goBack.style.display = 'inline';\n }\n })();\n </script>\n</body>\n</html>\n",
"ts": "2023-01-31T16:05:02+08:00"
}
Any comments are welcome. And Thanks in advance!icy-agent-73298
01/31/2023, 4:21 PMClient authentication failed due to unknown client, no client authentication included, or unsupported authentication method
indicates this misconfiguration. Seems it attempting to do a PKCE flow on an gitlab oauth app which has been created as client secret app
• When you are using ClientSecret of flytectl and getting 500 error which is again not an expected flow and hence it might be throwing this from gitlab.
I would suggest getting right docs to setup gitlab oauth PKCE app (no client secret)
Other option is to use client secret based app in which you can try reusing the clientId and secret which is used for flytepropeller and scheduler
i.e this one
adminOauthClientCredentials:
clientId: <client_id generated by gitlab>
clientSecret: <client_secret generated by gitlab>
The second option is suited for CI usescases where you just have CI server authenticating with gitlab whereas if you are deploying flytectl to multiple users machines with browser access, PKCE based oauth is the preferred approachstrong-barista-29632
02/01/2023, 2:39 AMicy-agent-73298
02/02/2023, 3:21 AMstrong-barista-29632
02/02/2023, 3:56 AMPkce
auth type, Good news is that I can see the successful authentication result page from localhost
with info Cool! Your authentication was successful and you can close the window.
. The key point for no client secret authentication is to uncheck the Confidential
option (refer to the attached screenshot). But the auth process still has some problem. The error log is something like below:
{"json":{"src":"auth_flow_orchestrator.go:77"},"level":"info","msg":"Opening the browser at <https://git.example.com/oauth/authorize?client_id=><client_id for flytectl with localhost redirect uri>\u0026redirect_uri=http%3A%2F%2Flocalhost%3A53593%2Fcallback\u0026response_type=code\u0026scope=email+openid+profile+read_user\u0026code_challenge=gYYRv7I-Eo2E3xiEbF2iSaIJl5hVVOeXJBzI0NQ-6l4\u0026code_challenge_method=S256\u0026nonce=cG1sd2NobG5zNzYycjJrY3ZqeDRrN3ZsNWQ1NDdkang\u0026state=cTduc242bTZja3FuNWdtczJ2ZmNuMmI2czdoc3hkdHo","ts":"2023-02-02T11:17:00+08:00"}
Error: Connection Info: [Endpoint: dns:///flyte.example.com, InsecureConnection?: false, AuthMode: Pkce]: rpc error: code = Unauthenticated desc = token parse error [JWT_VERIFICATION_FAILED] Could not retrieve id token from metadata, caused by: rpc error: code = Unauthenticated desc = Request unauthenticated with IDToken
{"json":{"src":"main.go:13"},"level":"error","msg":"Connection Info: [Endpoint: dns:///flyte.example.com, InsecureConnection?: false, AuthMode: Pkce]: rpc error: code = Unauthenticated desc = token parse error [JWT_VERIFICATION_FAILED] Could not retrieve id token from metadata, caused by: rpc error: code = Unauthenticated desc = Request unauthenticated with IDToken","ts":"2023-02-02T11:17:10+08:00"}
I searched on the Google and find a StackOverflow answer [1] saying that email
scope need to be checked, but I tried it with even more scopes and it does not work.
For the ClientSecret
auth type, I tried to reuse the client_id
and client_secret
for flytepropeller and scheduler, but it still get 500 error from gitlab.
For reminder, the auth related values.yaml
for flyte-core
helm chart template I use now is
configmap:
adminServer:
auth:
appAuth:
authServerType: External
externalAuthServer:
metadataUrl: .well-known/openid-configuration
thirdPartyConfig:
flyteClient:
clientId: <client_id for flytectl and SAME with flyteproerller and scheduler for ClientSecret auth type>
redirectUri: <http://localhost:53593/callback>
scopes:
- email
- openid
- profile
- read_user
authorizedUris:
- <http://flyte.example.com>
- <http://flyteadmin:80>
- <http://flyteadmin.flyte.svc.cluster.local:80>
userAuth:
openId:
baseUrl: <https://git.example.com>
clientId: <client_id for flyteconsole>
scopes:
- email
- openid
- profile
- read_user
server:
security:
useAuth: true
flyteadmin:
secrets:
oidc_client_secret: <client_secret for flyteconsole>
secrets:
adminOauthClientCredentials:
clientId: <client_id for flytepropeller and scheduler>
clientSecret: <client_secret for flytepropeller and scheudler>
the client config for Pkce
and ClientSecret
is almost the same as before
admin:
authType: Pkce
endpoint: dns:///flyte.example.com
insecure: false
insecureSkipVerify: true
and
admin:
authType: ClientSecret
clientId: <SAME client_id for flytepropeller and scheduler>
clientSecretLocation: /etc/secrets/client_secret
endpoint: dns:///flyte.example.com
insecure: false
insecureSkipVerify: true
[1] https://stackoverflow.com/a/67213376strong-barista-29632
02/02/2023, 4:01 AMstrong-barista-29632
02/02/2023, 4:02 AMClientSecret
auth type should be a must have option since we have scenarios for CICD, e.g., Daily Test, auto finetune with incremental data. Also algorithm engineers tend to work on server over ssh with no easy (though it could be done via ssh forward) web browser access.freezing-airport-6809
strong-barista-29632
02/02/2023, 6:44 AMicy-agent-73298
02/02/2023, 6:52 AM{"json":{"src":"handlers.go:248"},"level":"info","msg":"Failed to parse Access Token from context. Will attempt to find IDToken. Error: oidc: malformed jwt: square/go-jose: compact JWS format must have three parts","ts":"2023-02-02T06:34:38Z"}
{"json":{"src":"token.go:103"},"level":"deb
This has happened in the past when the authserver is not sent the right audience config and which has been fixed to allow setting this from client config in flytectl (We dont face this internally since we have okta auth server with default audience set to hosted flyte endpoint. Certain auth providers like gitlab and auth0 dont have an option to set this default audience and expect the client to send in this when requesting the auth token)
We will upgrade flytectl with latest flyteidl and test this out with passing audience config and take it from there.freezing-airport-6809
icy-agent-73298
02/02/2023, 5:54 PMflytectl upgrade
and use the config with audience .
Also this change to the audience would need to be done to all flyteadmin clients , ie. scheduler, propeller and later flytekit too (PR in progress for flytekit https://github.com/flyteorg/flytekit/pull/1403)
We can first verify that this audience issue and then update the values file for propeller and admin to use the same .freezing-airport-6809
strong-barista-29632
02/03/2023, 5:05 AMstrong-barista-29632
02/06/2023, 5:21 AM0.6.27
of flytectl and it seems to be the same error.
Config for flytectl
admin:
authType: Pkce
endpoint: dns:///flyte.example.com
insecure: false
insecureSkipVerify: true
audience: <http://flyte.example.com>
logger:
level: 6
show-source: true
Error log for flytectl
{"json":{"src":"auth_flow_orchestrator.go:77"},"level":"info","msg":"Opening the browser at <https://git.example.com/oauth/authorize?client_id=88151b597efcd5adbfe86fcf54c2a3eb685daa552a41f4bfe4888b95bb10c571>\u0026redirect_uri=http%3A%2F%2Flocalhost%3A53593%2Fcallback\u0026response_type=code\u0026scope=email+openid+profile+read_user\u0026code_challenge=c6ja-6ytu4dOTvNfvwgwjnjOmw10niejG7To47Jqymw\u0026code_challenge_method=S256\u0026nonce=bDkyeGo2c25jdmZucDYyNDhnbDJzbGhuanI1aGd6MmI\u0026state=aHo1ZHh4ZHp2NGZxaGhkdGJycHZzZ240bHhoZDh2dHQ","ts":"2023-02-06T13:17:41+08:00"}
{"json":{"src":"version.go:103"},"level":"debug","msg":"Failed to get version of control plane rpc error: code = Unauthenticated desc = token parse error [JWT_VERIFICATION_FAILED] Could not retrieve id token from metadata, caused by: rpc error: code = Unauthenticated desc = Request unauthenticated with IDToken: \n","ts":"2023-02-06T13:17:46+08:00"}
{"json":{"src":"version.go:81"},"level":"debug","msg":"rpc error: code = Unauthenticated desc = token parse error [JWT_VERIFICATION_FAILED] Could not retrieve id token from metadata, caused by: rpc error: code = Unauthenticated desc = Request unauthenticated with IDToken","ts":"2023-02-06T13:17:46+08:00"}
ConfigMap for flyteadmin, the values.yaml
configmap:
adminServer:
auth:
appAuth:
authServerType: External
externalAuthServer:
allowedAudience: <http://flyte.example.com>
metadataUrl: .well-known/openid-configuration
thirdPartyConfig:
flyteClient:
audience: <http://flyte.example.com>
clientId: 88151b597efcd5adbfe86fcf54c2a3eb685daa552a41f4bfe4888b95bb10c571
redirectUri: <http://localhost:53593/callback>
scopes:
- email
- openid
- profile
- read_user
authorizedUris:
- <http://flyte.example.com>
- <http://flyteadmin:80>
- <http://flyteadmin.flyte.svc.cluster.local:80>
userAuth:
openId:
baseUrl: <https://git.example.com>
clientId: 3483bdaa483ebe93638fe637481013c5ca869dd67dceaf45ccf6351ed61ba0ca
scopes:
- email
- openid
- profile
- read_user
server:
security:
useAuth: true
Error log for flyteadmin
{"json":{"src":"handlers.go:238"},"level":"debug","msg":"Running authentication gRPC interceptor","ts":"2023-02-06T05:17:41Z"}
{"json":{"src":"token.go:83"},"level":"debug","msg":"Could not retrieve bearer token from metadata rpc error: code = Unauthenticated desc = Request unauthenticated with Bearer","ts":"2023-02-06T05:17:41Z"}
{"json":{"src":"handlers.go:248"},"level":"info","msg":"Failed to parse Access Token from context. Will attempt to find IDToken. Error: [JWT_VERIFICATION_FAILED] Could not retrieve bearer token from metadata, caused by: rpc error: code = Unauthenticated desc = Request unauthenticated with Bearer","ts":"2023-02-06T05:17:41Z"}
{"json":{"src":"token.go:103"},"level":"debug","msg":"Could not retrieve id token from metadata rpc error: code = Unauthenticated desc = Request unauthenticated with IDToken","ts":"2023-02-06T05:17:41Z"}
{"json":{"src":"handlers.go:194"},"level":"debug","msg":"gRPC server info in logging interceptor []method [/flyteidl.service.AuthMetadataService/GetPublicClientConfig]\n","ts":"2023-02-06T05:17:41Z"}
{"json":{"src":"handlers.go:194"},"level":"debug","msg":"gRPC server info in logging interceptor []method [/flyteidl.service.AuthMetadataService/GetOAuth2Metadata]\n","ts":"2023-02-06T05:17:41Z"}
{"json":{"src":"handlers.go:194"},"level":"debug","msg":"gRPC server info in logging interceptor []method [/flyteidl.service.AuthMetadataService/GetPublicClientConfig]\n","ts":"2023-02-06T05:17:41Z"}
{"json":{"src":"handlers.go:210"},"level":"debug","msg":"Found existing metadata Bearer e54a72ad7f9e782bdcd0febfd146dc83f5b2340a789892ada5808c58df58eadb","ts":"2023-02-06T05:17:46Z"}
{"json":{"src":"handlers.go:238"},"level":"debug","msg":"Running authentication gRPC interceptor","ts":"2023-02-06T05:17:46Z"}
{"json":{"src":"handlers.go:248"},"level":"info","msg":"Failed to parse Access Token from context. Will attempt to find IDToken. Error: oidc: malformed jwt: square/go-jose: compact JWS format must have three parts","ts":"2023-02-06T05:17:46Z"}
{"json":{"src":"token.go:103"},"level":"debug","msg":"Could not retrieve id token from metadata rpc error: code = Unauthenticated desc = Request unauthenticated with IDToken","ts":"2023-02-06T05:17:46Z"}
strong-barista-29632
02/06/2023, 5:39 AM$ curl --header "Authorization: Bearer e54a72ad7f9e782bdcd0febfd146dc83f5b2340a789892ada5808c58df58eadb" "<https://git.example.com/oauth/token/info>"
icy-agent-73298
02/06/2023, 8:21 AMstrong-barista-29632
02/06/2023, 9:39 AMstrong-barista-29632
02/06/2023, 10:54 AMCould not retrieve bearer token from metadata
, will this be the actual cause? Which should be related to this code snippet [2], but since I am not familiar with Go, I failed to find anything unusual.
[1] https://docs.flyte.org/en/v1.0.0/deployment/cluster_config/auth_setup.html#overview
[2] https://github.com/flyteorg/flyteadmin/blob/master/auth/token.go#L81