|
|
|
@ -55,4 +55,52 @@ export class Auth { |
|
|
|
status: 302, |
|
|
|
})) |
|
|
|
} |
|
|
|
|
|
|
|
getToken(code) { |
|
|
|
this._code = code |
|
|
|
return 'test' |
|
|
|
} |
|
|
|
|
|
|
|
async callback(event) { |
|
|
|
const url = new URL(event.request.url) |
|
|
|
const { state, code } = Object.fromEntries( |
|
|
|
url.searchParams.entries() |
|
|
|
) |
|
|
|
const cookies = cookie.getCookies( |
|
|
|
event.request.headers |
|
|
|
) |
|
|
|
const headers = new Headers({ |
|
|
|
Location: '/#/' |
|
|
|
}) |
|
|
|
if (cookies['oauth.gitea.state'] !== state) { |
|
|
|
event.respondWith(new Response('invalid state', { |
|
|
|
status: 401, |
|
|
|
})) |
|
|
|
return |
|
|
|
} |
|
|
|
const token = await this.getToken(code) |
|
|
|
cookie.deleteCookie(headers, 'oauth.gitea.state') |
|
|
|
cookie.setCookie(headers, { |
|
|
|
name: 'oauth.gitea.token', |
|
|
|
value: token, |
|
|
|
}) |
|
|
|
event.respondWith(new Response('', { |
|
|
|
headers, |
|
|
|
status: 302, |
|
|
|
})) |
|
|
|
} |
|
|
|
|
|
|
|
async serve(event) { |
|
|
|
const {pathname} = new URL(event.request.url) |
|
|
|
const u = this.baseUrl |
|
|
|
if (pathname === `${u}/api/auth`) { |
|
|
|
await this.redirect(event) |
|
|
|
} else if (pathname === `${u}/api/auth/callback`) { |
|
|
|
await this.callback(event) |
|
|
|
} else { |
|
|
|
event.respondWith(new Response( |
|
|
|
'Not Found', {status: 404} |
|
|
|
)) |
|
|
|
} |
|
|
|
} |
|
|
|
} |