mirror of
https://github.com/bitwarden/browser
synced 2025-12-12 22:33:35 +00:00
* Add fix for bw login with apikey argument fails bug * Changes after running the prettier * Revert chnages on the launch.json file * Changes after running a lint * Renaming a filename to remove capital letters * Resolving the error on test run * Renaming file names due lint errors * Renaming new files to conform to snake case * Remove the test for user api login strategy * Adding the user api login test and file renaming * Rename file name to organization-api-login.spec.ts * Fixing the lint error on PR * Adding the apiLogIn.strategy to whitelist-capital-letters * Removing all the apiLogIn.strategy in whitelist-capital-letters. * Fixing PR comment relating OrganizationApiTokenRequest * Resolve PR comment on OrganizationApiTokenRequest model * Fixing PR comment of separating organization token model * fixing the lint error message * Fixing the lint error * Reverting the changes on lunch.js * revert the actual content on launch.json * Reverting changes relating to organization api login * Removing the OrganizationIdentityTokenResponse file * Removing OrganizationIdentityTokenResponse file Co-authored-by: dynwee <onwudiweokeke@gmail.com>
56 lines
1.5 KiB
TypeScript
56 lines
1.5 KiB
TypeScript
import { DeviceRequest } from "../device.request";
|
|
|
|
import { TokenTwoFactorRequest } from "./token-two-factor.request";
|
|
|
|
export abstract class TokenRequest {
|
|
protected device?: DeviceRequest;
|
|
protected passwordlessAuthRequest: string;
|
|
|
|
constructor(protected twoFactor: TokenTwoFactorRequest, device?: DeviceRequest) {
|
|
this.device = device != null ? device : null;
|
|
}
|
|
|
|
// eslint-disable-next-line
|
|
alterIdentityTokenHeaders(headers: Headers) {
|
|
// Implemented in subclass if required
|
|
}
|
|
|
|
setTwoFactor(twoFactor: TokenTwoFactorRequest) {
|
|
this.twoFactor = twoFactor;
|
|
}
|
|
|
|
setPasswordlessAccessCode(accessCode: string) {
|
|
this.passwordlessAuthRequest = accessCode;
|
|
}
|
|
|
|
protected toIdentityToken(clientId: string) {
|
|
const obj: any = {
|
|
scope: "api offline_access",
|
|
client_id: clientId,
|
|
};
|
|
|
|
if (this.device) {
|
|
obj.deviceType = this.device.type;
|
|
obj.deviceIdentifier = this.device.identifier;
|
|
obj.deviceName = this.device.name;
|
|
// no push tokens for browser apps yet
|
|
// obj.devicePushToken = this.device.pushToken;
|
|
}
|
|
|
|
//passswordless login
|
|
if (this.passwordlessAuthRequest) {
|
|
obj.authRequest = this.passwordlessAuthRequest;
|
|
}
|
|
|
|
if (this.twoFactor) {
|
|
if (this.twoFactor.token && this.twoFactor.provider != null) {
|
|
obj.twoFactorToken = this.twoFactor.token;
|
|
obj.twoFactorProvider = this.twoFactor.provider;
|
|
obj.twoFactorRemember = this.twoFactor.remember ? "1" : "0";
|
|
}
|
|
}
|
|
|
|
return obj;
|
|
}
|
|
}
|