All files / src/apis/wallet funding-sources.api.ts

100% Statements 6/6
100% Branches 0/0
50% Functions 2/4
100% Lines 6/6

Press n or j to go to the next uncovered block, b, p or k for the previous block.

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 925x 5x                     5x                       1x       1x                                                                       1x                                                      
import { url } from "../shared/url";
import { WalletApi } from "./api";
import type { GetAccountsResponse, GetAccountOffersResponse } from "./wallet.types";
 
/**
 * # Баланс QIWI Кошелька
 * [Документация QIWI] (https://developer.qiwi.com/ru/qiwi-wallet-personal/#balance)
 *
 * @export
 * @class WalletFundingSourcesApi
 * @extends {WalletApi}
 */
export class WalletFundingSourcesApi extends WalletApi {
  /**
   * ## Список балансов
   *
   * Запрос выгружает текущие балансы счетов вашего QIWI Кошелька.
   *
   * **Этот метод требует наличия валидного `walletId` (номера телефона привязанного к кошельку) в конфигурации API.**
   *
   * @return {Promise<GetAccountsResponse>} Promise<GetAccountsResponse["accounts"]>
   * @memberof WalletFundingSourcesApi
   */
  async getAccounts(): Promise<GetAccountsResponse["accounts"]> {
    const { accounts } = await this.http.get<GetAccountsResponse>(
      url`funding-sources/v2/persons/${this.walletId}/accounts`()
    );
 
    return accounts;
  }
 
  /**
   * ## Создание баланса
   *
   * Запрос создает новый счет и баланс в вашем QIWI Кошельке.
   * Список доступных для создания счетов можно получить {@link WalletFundingSourcesApi.getAccountOffers}.
   *
   * **Этот метод требует наличия валидного `walletId` (номера телефона привязанного к кошельку) в конфигурации API.**
   *
   * @param {string} alias Псевдоним нового счета (см. [запрос доступных счетов](https://developer.qiwi.com/ru/qiwi-wallet-personal/?http#funding_offer))
   * @return {Promise<void>} Promise<void>
   * @memberof WalletFundingSourcesApi
   */
  async createAccount(alias: string): Promise<void> {
    // Деструктивный метод
    /* istanbul ignore next */
    await this.http.post(
      url`funding-sources/v2/persons/${this.walletId}/accounts`(),
      { alias }
    );
  }
 
  /**
   * ## Запрос доступных счетов
   *
   * Запрос отображает псевдонимы счетов, доступных для создания
   * в вашем QIWI Кошельке.
   *
   * **Этот метод требует наличия валидного `walletId` (номера телефона привязанного к кошельку) в конфигурации API.**
   *
   * @return {Promise<GetAccountOffersResponse>} Promise<GetAccountOffersResponse>
   * @memberof WalletFundingSourcesApi
   */
  async getAccountOffers(): Promise<GetAccountOffersResponse> {
    return await this.http.get(
      url`funding-sources/v2/persons/${this.walletId}/accounts/offer`()
    );
  }
 
  /**
   * ## Установка баланса по умолчанию
   *
   * Запрос устанавливает для вашего QIWI Кошелька счет, баланс
   * которого будет использоваться для фондирования всех платежей
   * по умолчанию. Счет должен содержаться в {@link WalletFundingSourcesApi.getAccounts}
   *
   * **Этот метод требует наличия валидного `walletId` (номера телефона привязанного к кошельку) в конфигурации API.**
   *
   * @param {string} alias Псевдоним счета (см. [запрос доступных счетов](https://developer.qiwi.com/ru/qiwi-wallet-personal/?http#funding_offer))
   * @return {Promise<void>} Promise<void>
   * @memberof WalletFundingSourcesApi
   */
  async setDefaultAccount(alias: string): Promise<void> {
    // Деструктивный метод
    /* istanbul ignore next */
    return await this.http.patch(
      url`funding-sources/v2/persons/${this.walletId}/accounts/${alias}`(),
      { defaultAccount: true }
    );
  }
}