tink/ts/tink.classes.tinkuser.ts

130 lines
4.3 KiB
TypeScript
Raw Permalink Normal View History

2022-02-18 11:55:56 +00:00
import * as plugins from './tink.plugins';
import { TinkAccount } from './tink.classes.tinkaccount';
2022-02-19 12:15:59 +00:00
import { TinkProviderConsent } from './tink.classes.tinkproviderconsent';
2022-02-18 11:55:56 +00:00
export class TinkUser {
// STATIC
2022-02-19 12:15:59 +00:00
public static async createNewTinkUser(tinkAccountArg: TinkAccount, externalUserIdArg: string) {
const accessToken = await tinkAccountArg.getClientAccessTokenForScope('user:create');
const responseData: {
external_user_id: string;
user_id: string;
} = await tinkAccountArg.request({
2022-02-18 11:55:56 +00:00
urlArg: '/api/v1/user/create',
2022-02-19 00:34:07 +00:00
accessToken,
2022-02-18 11:55:56 +00:00
methodArg: 'POST',
payloadArg: {
2022-02-19 10:43:10 +00:00
external_user_id: externalUserIdArg,
market: 'DE',
locale: 'en_US',
},
2022-02-18 11:55:56 +00:00
});
2022-02-19 12:15:59 +00:00
const newTinkUser = await TinkUser.getTinkUser(tinkAccountArg, externalUserIdArg);
return newTinkUser;
}
public static async getTinkUser(tinkAccountArg: TinkAccount, externalUserIdArg: string) {
const authorizationCode = await tinkAccountArg.getUserAuthorizationCode(
externalUserIdArg,
tinkAccountArg.clientId,
'user:read'
);
const accessToken = await tinkAccountArg.getUserAccessToken(authorizationCode);
const responseData: {
appId: string;
created: string;
externalUserId: string;
flags: string[];
id: string;
nationalId: string;
profile: {
// cashbackEnabled: boolean; // deprecated
currency: string;
locale: string;
market: string;
notificationSettings: {
balance: boolean;
budget: boolean;
doubleCharge: boolean;
einvoices: boolean;
fraud: boolean;
income: boolean;
largeExpense: boolean;
leftToSpend: boolean;
loanUpdate: boolean;
summaryMonthly: boolean;
summaryWeekly: boolean;
transaction: boolean;
unusualAccount: boolean;
unusualCategory: boolean;
};
periodAdjustedDay: 25;
periodMode: 'MONTHLY_ADJUSTED' | 'MONTHLY';
timeZone: string;
};
// username: string; // not relevant
} = await tinkAccountArg.request({
urlArg: '/api/v1/user',
accessToken,
methodArg: 'GET',
payloadArg: null,
});
const newTinkUser = new TinkUser(tinkAccountArg, responseData.id, responseData.externalUserId);
2022-02-19 00:34:07 +00:00
return newTinkUser;
2022-02-18 11:55:56 +00:00
}
// INSTANCE
public tinkAccountRef: TinkAccount;
public tinkUserId: string;
public externalUserIdArg: string;
2022-02-19 10:43:10 +00:00
public authorizationToken: string;
2022-02-18 11:55:56 +00:00
constructor(tinkAccountrefArg: TinkAccount, tinkUserIdArg: string, externalUserIdArg: string) {
this.tinkAccountRef = tinkAccountrefArg;
this.tinkUserId = tinkUserIdArg;
this.externalUserIdArg = externalUserIdArg;
}
/**
* deletes the user
*/
public async delete() {
2022-02-19 10:43:10 +00:00
const authorizationCode = await this.tinkAccountRef.getUserAuthorizationCode(
this.externalUserIdArg,
this.tinkAccountRef.clientId,
'user:delete'
);
2022-02-19 00:34:07 +00:00
const accessToken = await this.tinkAccountRef.getUserAccessToken(authorizationCode);
2022-02-18 11:55:56 +00:00
const response = await this.tinkAccountRef.request({
methodArg: 'POST',
2022-02-19 00:34:07 +00:00
accessToken,
2022-02-18 11:55:56 +00:00
payloadArg: {},
2022-02-19 10:43:10 +00:00
urlArg: '/api/v1/user/delete',
2022-02-18 11:55:56 +00:00
});
2022-02-19 00:34:07 +00:00
console.log(`successfully deleted user with externalId ${this.externalUserIdArg}`);
2022-02-18 11:55:56 +00:00
}
2022-02-19 10:43:10 +00:00
2022-02-19 12:15:59 +00:00
/**
* gets a tink link that can be used by a user to connect accounts
* @returns
*/
public async getTinkLinkForMarket(countryIdArg: string = 'DE'): Promise<string> {
2022-02-19 10:43:10 +00:00
const authorizationCode = await this.tinkAccountRef.getUserAuthorizationCode(
this.externalUserIdArg,
'df05e4b379934cd09963197cc855bfe9', // this is a hardcoded app id for tink link, as recommended by tink.com
'authorization:read,authorization:grant,credentials:refresh,credentials:read,credentials:write,providers:read,user:read'
);
2022-02-19 12:15:59 +00:00
const tinkLinkUrl = `https://link.tink.com/1.0/business-transactions/connect-accounts?client_id=${'teststate'}&redirect_uri=https://console.tink.com/callback&authorization_code=${authorizationCode}&market=${countryIdArg}`;
2022-02-19 10:43:10 +00:00
return tinkLinkUrl;
}
2022-02-19 12:15:59 +00:00
public async getProviderConsents(): Promise<TinkProviderConsent[]> {
const providerConsents: TinkProviderConsent[] =
await TinkProviderConsent.getProviderConsentsForUser(this);
return providerConsents;
}
2022-02-19 10:43:10 +00:00
}