From 2f125712ebfbc4f38a1dcd97c909ef4ee4724476 Mon Sep 17 00:00:00 2001 From: Victoria Prusakova Date: Thu, 6 Jun 2024 22:29:07 +0300 Subject: [PATCH] add patch dapp method --- packages/sdk/src/dapp/dapp.interface.ts | 24 +++++++++++++---- .../data-service-dapps-api.ts | 26 +++++++++++++++++++ packages/sdk/src/internal/dapp/dapp.ts | 15 +++++++++++ 3 files changed, 60 insertions(+), 5 deletions(-) diff --git a/packages/sdk/src/dapp/dapp.interface.ts b/packages/sdk/src/dapp/dapp.interface.ts index 5049ab5e..78e2e286 100644 --- a/packages/sdk/src/dapp/dapp.interface.ts +++ b/packages/sdk/src/dapp/dapp.interface.ts @@ -1,10 +1,16 @@ import type { AddressType, DappAddress } from '../address/addresses.interface'; -import type { NotificationConfig, NotificationSubscription, NotificationType } from '../wallet/wallet.interface'; +import type { + NotificationConfig, + NotificationSubscription, + NotificationType, +} from '../wallet/wallet.interface'; import type { AccountAddress } from '../auth/auth.interface'; export interface Dapps { create(command: CreateDappCommand): Promise; + patch(command: PatchDappCommand): Promise; + find(query?: FindOneDappQuery): Promise; findAll(query?: FindDappQuery): Promise; @@ -59,6 +65,15 @@ export interface CreateDappCommand { blockchainType: BlockchainType; } +export interface PatchDappCommand { + name?: string; + description?: string | null; + websiteUrl?: string | null; + avatarUrl?: string | null; + heroUrl?: string | null; + telegramBotConfiguration?: DappTelegramBotConfiguration; +} + export interface DappTelegramBotConfiguration { token: string; } @@ -81,7 +96,7 @@ interface DappMessageActionBase { type: DappMessageActionType; } -export interface DappMessageLinksAction extends DappMessageActionBase { +export interface DappMessageLinksAction extends DappMessageActionBase { type: DappMessageActionType.LINK; links: [DappMessageLinkAction]; } @@ -103,7 +118,6 @@ export interface SmartMessage { // eslint-disable-next-line @typescript-eslint/no-empty-interface export interface SmartMessageParams {} - export interface SendDappMessageCommandBase { message: string; title?: string; @@ -113,7 +127,8 @@ export interface SendDappMessageCommandBase { // tags?: string[]; } -export interface BroadcastDappMessageCommand extends SendDappMessageCommandBase { +export interface BroadcastDappMessageCommand + extends SendDappMessageCommandBase { actionsV2?: DappMessageLinksAction; } @@ -174,4 +189,3 @@ export class DappNotificationSubscription { notificationType!: NotificationType; subscriptions!: NotificationSubscription[]; } - diff --git a/packages/sdk/src/dialect-cloud-api/data-service-dapps-api.ts b/packages/sdk/src/dialect-cloud-api/data-service-dapps-api.ts index 9d0db0d1..cfb02629 100644 --- a/packages/sdk/src/dialect-cloud-api/data-service-dapps-api.ts +++ b/packages/sdk/src/dialect-cloud-api/data-service-dapps-api.ts @@ -9,6 +9,8 @@ import type { BlockchainType } from '../dapp/dapp.interface'; export interface DataServiceDappsApi { create(command: Omit): Promise; + patch(command: PatchDappCommandDto): Promise; + findAll(query?: FindDappQueryDto): Promise; find(dappAddress?: string): Promise; @@ -45,6 +47,21 @@ export class DataServiceDappsApiClient implements DataServiceDappsApi { ); } + async patch(command: PatchDappCommandDto): Promise { + const token = await this.tokenProvider.get(); + return withReThrowingDataServiceError( + axios + .patch( + `${this.baseUrl}/api/v1/dapps/${token.body.sub}`, + command, + { + headers: createHeaders(token), + }, + ) + .then((it) => it.data), + ); + } + async findAllDappAddresses(): Promise { const token = await this.tokenProvider.get(); return withReThrowingDataServiceError( @@ -153,6 +170,15 @@ export class CreateDappCommandDto { readonly blockchainType?: string; } +export class PatchDappCommandDto { + readonly name?: string; + readonly description?: string | null; + readonly websiteUrl?: string | null; + readonly avatarUrl?: string | null; + readonly heroUrl?: string | null; + readonly telegramBotConfiguration?: DappTelegramBotConfigurationDto; +} + export class DappTelegramBotConfigurationDto { readonly token!: string; } diff --git a/packages/sdk/src/internal/dapp/dapp.ts b/packages/sdk/src/internal/dapp/dapp.ts index d046920c..0135988b 100644 --- a/packages/sdk/src/internal/dapp/dapp.ts +++ b/packages/sdk/src/internal/dapp/dapp.ts @@ -15,6 +15,7 @@ import type { Dapps, FindDappQuery, FindOneDappQuery, + PatchDappCommand, ReadOnlyDapp, } from '../../dapp/dapp.interface'; import type { DataServiceDappNotificationTypes } from './data-service-dapp-notification-types'; @@ -93,6 +94,20 @@ export class DappsImpl implements Dapps { ); return this.toDapp(dappDto); } + + async patch(command: PatchDappCommand): Promise { + const dappDto = await withErrorParsing( + this.dappsApi.patch({ + name: command.name, + description: command.description, + websiteUrl: command.websiteUrl, + avatarUrl: command.avatarUrl, + heroUrl: command.heroUrl, + telegramBotConfiguration: command.telegramBotConfiguration, + }), + ); + return this.toDapp(dappDto); + } } export class DappImpl implements Dapp {