@chat-adapter/shared
v4.28.1
Published
Shared utilities for chat SDK adapters
Readme
@chat-adapter/shared
Shared utilities for Chat SDK adapters. Provides common helpers used across adapter implementations.
Installation
pnpm add @chat-adapter/sharedUtilities
Adapter helpers
extractCard(message)- extract aCardElementfrom anAdapterPostableMessageextractFiles(message)- extractFileUpload[]from anAdapterPostableMessage
Buffer conversion
toBuffer(input)- convert various inputs (Buffer, Blob, string, URL) to BuffertoBufferSync(input)- synchronous version of toBufferbufferToDataUri(buffer, mimeType)- convert a Buffer to a data URI string
Card conversion
cardToFallbackText(card)- render aCardElementas plain text for platforms that don't support cardscreateEmojiConverter(platform)- create a function that converts emoji placeholders to platform formatmapButtonStyle(style)- map generic button styles to platform-specific variantsrenderGfmTable(headers, rows)- render a GitHub Flavored Markdown tableescapeTableCell(text)- escape pipe characters in table cells
Token encryption
AES-256-GCM helpers for encrypting OAuth tokens at rest before writing them to a state adapter. Used by @chat-adapter/slack and @chat-adapter/linear; available to any adapter that persists credentials.
encryptToken(plaintext, key)- encrypt a string and return anEncryptedTokenDataenvelope (random 12-byte IV per call)decryptToken(data, key)- decrypt an envelope back to the original stringdecodeKey(encoded)- decode a hex-64 or base64-44 encoded 32-byte key; throws on wrong lengthisEncryptedTokenData(value)- type guard for distinguishing envelopes from legacy plaintext recordsEncryptedTokenData- the envelope type ({ data, iv, tag }, all base64)
Error classes
Standardized errors for adapter implementations:
AdapterError- base error classAdapterRateLimitError- platform rate limit (includesretryAfter)AuthenticationError- expired or invalid tokensNetworkError- connection failuresPermissionError- missing scopes or permissionsResourceNotFoundError- missing channel/thread/messageValidationError- invalid config or input
License
MIT