From 0044788446158c5c0547c4a14413e8f378499df0 Mon Sep 17 00:00:00 2001 From: Jakub Kowalski <155538368+jakubmkowalski@users.noreply.github.com> Date: Thu, 19 Dec 2024 10:10:41 +0100 Subject: [PATCH] feat(SPV-1214): add admin contact filter to retreive contacts by xpub_id (#1122) --- src/client.ts | 5 +- src/filters.ts | 214 +++++++++++++++++++++++++------------------------ 2 files changed, 112 insertions(+), 107 deletions(-) diff --git a/src/client.ts b/src/client.ts index 187507fe..7c52e179 100644 --- a/src/client.ts +++ b/src/client.ts @@ -50,6 +50,7 @@ import { HD, P2PKH, PrivateKey, Transaction } from '@bsv/sdk'; import { AccessKeyFilter, AdminAccessKeyFilter, + AdminContactFilter, AdminPaymailFilter, AdminUtxoFilter, ContactFilter, @@ -185,13 +186,13 @@ export class SpvWalletClient { /** * Admin only: Get a list of all contacts in the system, filtered by conditions, metadata and queryParams * - * @param {ContactFilter} conditions Key value object to use to filter the documents + * @param {AdminContactFilter} conditions Key value object to use to filter the documents * @param {Metadata} metadata Key value object to use to filter the documents by the metadata * @param {OldQueryParams} params Database query parameters for page, page size and sorting * @return {PageModel} */ async AdminGetContacts( - conditions: ContactFilter, + conditions: AdminContactFilter, metadata: Metadata, params: OldQueryParams, ): Promise> { diff --git a/src/filters.ts b/src/filters.ts index 91363d2b..ea359a95 100644 --- a/src/filters.ts +++ b/src/filters.ts @@ -1,105 +1,109 @@ -// TimeRange defines a range between two points in time. -export interface TimeRange { - from?: string; // from specifies the start time of the range. It's optional and can be nil. - to?: string; // to specifies the end time of the range. It's optional and can be nil -} - -// ModelFilter is a common model filter that contains common fields for all model filters. -export interface ModelFilter { - includeDeleted?: boolean; // includeDeleted is a flag whether or not to include deleted items in the search results - createdRange?: TimeRange; // createdRange specifies the time range when a record was created. - updatedRange?: TimeRange; // updatedRange specifies the time range when a record was updated. -} - -export interface AccessKeyFilter extends ModelFilter { - revokedRange?: TimeRange; -} - -export interface AdminAccessKeyFilter extends AccessKeyFilter { - xpubId?: string; -} - -export type ContactStatus = 'unconfirmed' | 'awaiting' | 'confirmed' | 'rejected'; -export interface ContactFilter extends ModelFilter { - id?: string; - fullName?: string; - paymail?: string; - pubKey?: string; - status?: ContactStatus; -} - -export interface DestinationFilter extends ModelFilter { - lockingScript?: string; - address?: string; - draftId?: string; -} - -export interface AdminPaymailFilter extends ModelFilter { - id?: string; - xpubId?: string; - alias?: string; - domain?: string; - publicName?: string; -} - -export type TransactionStatus = - | 'UNKNOWN' - | 'QUEUED' - | 'RECEIVED' - | 'STORED' - | 'ANNOUNCED_TO_NETWORK' - | 'REQUESTED_BY_NETWORK' - | 'SENT_TO_NETWORK' - | 'ACCEPTED_BY_NETWORK' - | 'SEEN_ON_NETWORK' - | 'MINED' - | 'SEEN_IN_ORPHAN_MEMPOOL' - | 'CONFIRMED' - | 'REJECTED'; - -export interface TransactionFilter extends ModelFilter { - id?: string; - hex?: string; - blockHash?: string; - blockHeight?: number; - fee?: number; - numberOfInputs?: number; - numberOfOutputs?: number; - draftId?: string; - totalValue?: number; - - // status is typically of the type TransactionStatus. However, it can be any string to accommodate custom situations. - status?: TransactionStatus | string; -} - -export type UtxoType = - | 'pubkey' - | 'pubkeyhash' - | 'nulldata' - | 'multisig' - | 'nonstandard' - | 'scripthash' - | 'metanet' - | 'token_stas' - | 'token_sensible'; - -export interface UtxoFilter extends ModelFilter { - transactionId?: string; - outputIndex?: number; - id?: string; - satoshis?: number; - scriptPubKey?: string; - type?: UtxoType; - draftId?: string; - reservedRange?: TimeRange; - spendingTxId?: string; -} - -export interface AdminUtxoFilter extends UtxoFilter { - xpubId?: string; -} - -export interface XpubFilter extends ModelFilter { - id?: string; - currentBalance?: number; -} +// TimeRange defines a range between two points in time. +export interface TimeRange { + from?: string; // from specifies the start time of the range. It's optional and can be nil. + to?: string; // to specifies the end time of the range. It's optional and can be nil +} + +// ModelFilter is a common model filter that contains common fields for all model filters. +export interface ModelFilter { + includeDeleted?: boolean; // includeDeleted is a flag whether or not to include deleted items in the search results + createdRange?: TimeRange; // createdRange specifies the time range when a record was created. + updatedRange?: TimeRange; // updatedRange specifies the time range when a record was updated. +} + +export interface AccessKeyFilter extends ModelFilter { + revokedRange?: TimeRange; +} + +export interface AdminAccessKeyFilter extends AccessKeyFilter { + xpubId?: string; +} + +export type ContactStatus = 'unconfirmed' | 'awaiting' | 'confirmed' | 'rejected'; +export interface ContactFilter extends ModelFilter { + id?: string; + fullName?: string; + paymail?: string; + pubKey?: string; + status?: ContactStatus; +} + +export interface DestinationFilter extends ModelFilter { + lockingScript?: string; + address?: string; + draftId?: string; +} + +export interface AdminPaymailFilter extends ModelFilter { + id?: string; + xpubId?: string; + alias?: string; + domain?: string; + publicName?: string; +} + +export type TransactionStatus = + | 'UNKNOWN' + | 'QUEUED' + | 'RECEIVED' + | 'STORED' + | 'ANNOUNCED_TO_NETWORK' + | 'REQUESTED_BY_NETWORK' + | 'SENT_TO_NETWORK' + | 'ACCEPTED_BY_NETWORK' + | 'SEEN_ON_NETWORK' + | 'MINED' + | 'SEEN_IN_ORPHAN_MEMPOOL' + | 'CONFIRMED' + | 'REJECTED'; + +export interface TransactionFilter extends ModelFilter { + id?: string; + hex?: string; + blockHash?: string; + blockHeight?: number; + fee?: number; + numberOfInputs?: number; + numberOfOutputs?: number; + draftId?: string; + totalValue?: number; + + // status is typically of the type TransactionStatus. However, it can be any string to accommodate custom situations. + status?: TransactionStatus | string; +} + +export type UtxoType = + | 'pubkey' + | 'pubkeyhash' + | 'nulldata' + | 'multisig' + | 'nonstandard' + | 'scripthash' + | 'metanet' + | 'token_stas' + | 'token_sensible'; + +export interface UtxoFilter extends ModelFilter { + transactionId?: string; + outputIndex?: number; + id?: string; + satoshis?: number; + scriptPubKey?: string; + type?: UtxoType; + draftId?: string; + reservedRange?: TimeRange; + spendingTxId?: string; +} + +export interface AdminUtxoFilter extends UtxoFilter { + xpubId?: string; +} + +export interface XpubFilter extends ModelFilter { + id?: string; + currentBalance?: number; +} + +export interface AdminContactFilter extends ContactFilter { + xpubId?: string; +}