mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-05 14:37:45 +00:00
49 lines
1.4 KiB
TypeScript
49 lines
1.4 KiB
TypeScript
|
import { sign } from 'jsonwebtoken'
|
||
|
|
||
|
export interface apiCallProperties {
|
||
|
authHeader: string
|
||
|
mgntBaseURL: string
|
||
|
}
|
||
|
|
||
|
export function apiAuth(): Cypress.Chainable<apiCallProperties> {
|
||
|
const apiUrl = Cypress.env('apiUrl')
|
||
|
const issuerUrl = Cypress.env('issuerUrl')
|
||
|
const zitadelProjectResourceID = (<string>Cypress.env('zitadelProjectResourceId')).replace('bignumber-', '')
|
||
|
|
||
|
const key = Cypress.env("parsedServiceAccountKey")
|
||
|
|
||
|
const now = new Date().getTime()
|
||
|
const iat = Math.floor(now / 1000)
|
||
|
const exp = Math.floor(new Date(now + 1000 * 60 * 55).getTime() / 1000) // 55 minutes
|
||
|
const bearerToken = sign({
|
||
|
iss: key.userId,
|
||
|
sub: key.userId,
|
||
|
aud: `${issuerUrl}`,
|
||
|
iat: iat,
|
||
|
exp: exp
|
||
|
}, key.key, {
|
||
|
header: {
|
||
|
alg: "RS256",
|
||
|
kid: key.keyId
|
||
|
}
|
||
|
})
|
||
|
|
||
|
return cy.request({
|
||
|
method: 'POST',
|
||
|
url: `${apiUrl}/oauth/v2/token`,
|
||
|
headers: {
|
||
|
'Content-Type': 'application/x-www-form-urlencoded'
|
||
|
},
|
||
|
body: {
|
||
|
'grant_type': 'urn:ietf:params:oauth:grant-type:jwt-bearer',
|
||
|
scope: `openid urn:zitadel:iam:org:project:id:${zitadelProjectResourceID}:aud`,
|
||
|
assertion: bearerToken,
|
||
|
}
|
||
|
}).its('body.access_token').then(token => {
|
||
|
|
||
|
return <apiCallProperties>{
|
||
|
authHeader: `Bearer ${token}`,
|
||
|
mgntBaseURL: `${apiUrl}/management/v1/`,
|
||
|
}
|
||
|
})
|
||
|
}
|