-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathClient.ts
More file actions
102 lines (90 loc) · 3.61 KB
/
Client.ts
File metadata and controls
102 lines (90 loc) · 3.61 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/**
* This file was auto-generated by Fern from our API Definition.
*/
import * as environments from "../../../../environments";
import * as core from "../../../../core";
import * as CodeCombat from "../../..";
import { default as URLSearchParams } from "@ungap/url-search-params";
import urlJoin from "url-join";
import * as errors from "../../../../errors";
export declare namespace Auth {
interface Options {
environment?: core.Supplier<environments.CodeCombatEnvironment | string>;
username: core.Supplier<string>;
password: core.Supplier<string>;
}
interface RequestOptions {
timeoutInSeconds?: number;
}
}
export class Auth {
constructor(protected readonly _options: Auth.Options) {}
/**
* Logs a user in. In this example, we call your lookup URL (let's say, `https://oauth.provider/user?t=<%= accessToken %>`) with the access token (`1234`). The lookup URL returns `{ id: 'abcd' }` in this case. We will match this `id` with the OAuthIdentity stored in the user information in our db. If everything checks out, the user is logged in and redirected to the home page.
*
*/
public async loginOauth(
request: CodeCombat.LoginOauthRequest,
requestOptions?: Auth.RequestOptions
): Promise<void> {
const { provider, accessToken, code, redirect, errorRedirect } = request;
const _queryParams = new URLSearchParams();
_queryParams.append("provider", provider);
if (accessToken != null) {
_queryParams.append("accessToken", accessToken);
}
if (code != null) {
_queryParams.append("code", code);
}
if (redirect != null) {
_queryParams.append("redirect", redirect);
}
if (errorRedirect != null) {
_queryParams.append("errorRedirect", errorRedirect);
}
const _response = await core.fetcher({
url: urlJoin(
(await core.Supplier.get(this._options.environment)) ?? environments.CodeCombatEnvironment.Default,
"auth/login-o-auth"
),
method: "GET",
headers: {
Authorization: await this._getAuthorizationHeader(),
"X-Fern-Language": "JavaScript",
"X-Fern-SDK-Name": "@fern-api/codecombat",
"X-Fern-SDK-Version": "0.1.5",
},
contentType: "application/json",
queryParameters: _queryParams,
timeoutMs: requestOptions?.timeoutInSeconds != null ? requestOptions.timeoutInSeconds * 1000 : 60000,
});
if (_response.ok) {
return;
}
if (_response.error.reason === "status-code") {
throw new errors.CodeCombatError({
statusCode: _response.error.statusCode,
body: _response.error.body,
});
}
switch (_response.error.reason) {
case "non-json":
throw new errors.CodeCombatError({
statusCode: _response.error.statusCode,
body: _response.error.rawBody,
});
case "timeout":
throw new errors.CodeCombatTimeoutError();
case "unknown":
throw new errors.CodeCombatError({
message: _response.error.errorMessage,
});
}
}
protected async _getAuthorizationHeader() {
return core.BasicAuth.toAuthorizationHeader({
username: await core.Supplier.get(this._options.username),
password: await core.Supplier.get(this._options.password),
});
}
}