diff options
Diffstat (limited to 'src/temp/dm/sendMessageBatch.ts')
-rw-r--r-- | src/temp/dm/sendMessageBatch.ts | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/src/temp/dm/sendMessageBatch.ts b/src/temp/dm/sendMessageBatch.ts new file mode 100644 index 000000000..c2ce1d82c --- /dev/null +++ b/src/temp/dm/sendMessageBatch.ts @@ -0,0 +1,66 @@ +import {ValidationResult} from '@atproto/lexicon' +import {Headers, XRPCError} from '@atproto/xrpc' + +import * as TempDmDefs from './defs' + +export interface QueryParams {} + +export interface InputSchema { + items: BatchItem[] + [k: string]: unknown +} + +export interface OutputSchema { + items: TempDmDefs.MessageView[] + [k: string]: unknown +} + +export interface CallOptions { + headers?: Headers + qp?: QueryParams + encoding: 'application/json' +} + +export interface Response { + success: boolean + headers: Headers + data: OutputSchema +} + +export function toKnownErr(e: any) { + if (e instanceof XRPCError) { + } + return e +} + +export interface BatchItem { + chatId: string + message: TempDmDefs.Message + [k: string]: unknown +} + +export function isBatchItem(v: unknown): v is BatchItem { + return ( + isObj(v) && + hasProp(v, '$type') && + v.$type === 'temp.dm.sendMessageBatch#batchItem' + ) +} + +export function validateBatchItem(v: unknown): ValidationResult { + return { + success: true, + value: v, + } +} + +export function isObj(v: unknown): v is Record<string, unknown> { + return typeof v === 'object' && v !== null +} + +export function hasProp<K extends PropertyKey>( + data: object, + prop: K, +): data is Record<K, unknown> { + return prop in data +} |