@hasna/connectors 0.3.16 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (127) hide show
  1. package/bin/index.js +71 -1
  2. package/bin/mcp.js +71 -1
  3. package/bin/serve.js +70 -0
  4. package/connectors/connect-asana/.env.example +11 -0
  5. package/connectors/connect-asana/CLAUDE.md +128 -0
  6. package/connectors/connect-asana/README.md +193 -0
  7. package/connectors/connect-asana/package.json +52 -0
  8. package/connectors/connect-asana/src/api/client.ts +119 -0
  9. package/connectors/connect-asana/src/api/index.ts +319 -0
  10. package/connectors/connect-asana/src/cli/index.ts +731 -0
  11. package/connectors/connect-asana/src/index.ts +19 -0
  12. package/connectors/connect-asana/src/types/index.ts +270 -0
  13. package/connectors/connect-asana/src/utils/config.ts +171 -0
  14. package/connectors/connect-asana/src/utils/output.ts +119 -0
  15. package/connectors/connect-asana/tsconfig.json +16 -0
  16. package/connectors/connect-clickup/.env.example +11 -0
  17. package/connectors/connect-clickup/CLAUDE.md +128 -0
  18. package/connectors/connect-clickup/README.md +193 -0
  19. package/connectors/connect-clickup/package.json +52 -0
  20. package/connectors/connect-clickup/src/api/client.ts +116 -0
  21. package/connectors/connect-clickup/src/api/index.ts +400 -0
  22. package/connectors/connect-clickup/src/cli/index.ts +625 -0
  23. package/connectors/connect-clickup/src/index.ts +19 -0
  24. package/connectors/connect-clickup/src/types/index.ts +591 -0
  25. package/connectors/connect-clickup/src/utils/config.ts +157 -0
  26. package/connectors/connect-clickup/src/utils/output.ts +119 -0
  27. package/connectors/connect-clickup/tsconfig.json +16 -0
  28. package/connectors/connect-confluence/.env.example +11 -0
  29. package/connectors/connect-confluence/CLAUDE.md +272 -0
  30. package/connectors/connect-confluence/README.md +193 -0
  31. package/connectors/connect-confluence/package.json +53 -0
  32. package/connectors/connect-confluence/scripts/release.ts +179 -0
  33. package/connectors/connect-confluence/src/api/client.ts +213 -0
  34. package/connectors/connect-confluence/src/api/example.ts +48 -0
  35. package/connectors/connect-confluence/src/api/index.ts +51 -0
  36. package/connectors/connect-confluence/src/cli/index.ts +254 -0
  37. package/connectors/connect-confluence/src/index.ts +103 -0
  38. package/connectors/connect-confluence/src/types/index.ts +237 -0
  39. package/connectors/connect-confluence/src/utils/auth.ts +274 -0
  40. package/connectors/connect-confluence/src/utils/bulk.ts +212 -0
  41. package/connectors/connect-confluence/src/utils/config.ts +326 -0
  42. package/connectors/connect-confluence/src/utils/output.ts +175 -0
  43. package/connectors/connect-confluence/src/utils/settings.ts +114 -0
  44. package/connectors/connect-confluence/src/utils/storage.ts +198 -0
  45. package/connectors/connect-confluence/tsconfig.json +16 -0
  46. package/connectors/connect-jira/.env.example +11 -0
  47. package/connectors/connect-jira/CLAUDE.md +128 -0
  48. package/connectors/connect-jira/README.md +193 -0
  49. package/connectors/connect-jira/package.json +53 -0
  50. package/connectors/connect-jira/src/api/client.ts +131 -0
  51. package/connectors/connect-jira/src/api/index.ts +266 -0
  52. package/connectors/connect-jira/src/cli/index.ts +653 -0
  53. package/connectors/connect-jira/src/index.ts +23 -0
  54. package/connectors/connect-jira/src/types/index.ts +448 -0
  55. package/connectors/connect-jira/src/utils/config.ts +179 -0
  56. package/connectors/connect-jira/src/utils/output.ts +119 -0
  57. package/connectors/connect-jira/tsconfig.json +16 -0
  58. package/connectors/connect-linear/CLAUDE.md +88 -0
  59. package/connectors/connect-linear/README.md +201 -0
  60. package/connectors/connect-linear/package.json +45 -0
  61. package/connectors/connect-linear/src/api/client.ts +62 -0
  62. package/connectors/connect-linear/src/api/index.ts +46 -0
  63. package/connectors/connect-linear/src/api/issues.ts +247 -0
  64. package/connectors/connect-linear/src/api/projects.ts +179 -0
  65. package/connectors/connect-linear/src/api/teams.ts +125 -0
  66. package/connectors/connect-linear/src/api/users.ts +112 -0
  67. package/connectors/connect-linear/src/cli/index.ts +560 -0
  68. package/connectors/connect-linear/src/index.ts +27 -0
  69. package/connectors/connect-linear/src/types/index.ts +275 -0
  70. package/connectors/connect-linear/src/utils/config.ts +249 -0
  71. package/connectors/connect-linear/src/utils/output.ts +119 -0
  72. package/connectors/connect-linear/tsconfig.json +16 -0
  73. package/connectors/connect-slack/.env.example +7 -0
  74. package/connectors/connect-slack/CLAUDE.md +69 -0
  75. package/connectors/connect-slack/README.md +150 -0
  76. package/connectors/connect-slack/package.json +44 -0
  77. package/connectors/connect-slack/src/api/channels.ts +112 -0
  78. package/connectors/connect-slack/src/api/client.ts +97 -0
  79. package/connectors/connect-slack/src/api/index.ts +42 -0
  80. package/connectors/connect-slack/src/api/messages.ts +127 -0
  81. package/connectors/connect-slack/src/api/users.ts +110 -0
  82. package/connectors/connect-slack/src/cli/index.ts +494 -0
  83. package/connectors/connect-slack/src/index.ts +21 -0
  84. package/connectors/connect-slack/src/types/index.ts +263 -0
  85. package/connectors/connect-slack/src/utils/config.ts +297 -0
  86. package/connectors/connect-slack/src/utils/output.ts +119 -0
  87. package/connectors/connect-slack/tsconfig.json +16 -0
  88. package/connectors/connect-telegram/.env.example +2 -0
  89. package/connectors/connect-telegram/package.json +49 -0
  90. package/connectors/connect-todoist/.env.example +11 -0
  91. package/connectors/connect-todoist/CLAUDE.md +104 -0
  92. package/connectors/connect-todoist/README.md +193 -0
  93. package/connectors/connect-todoist/package.json +52 -0
  94. package/connectors/connect-todoist/src/api/client.ts +117 -0
  95. package/connectors/connect-todoist/src/api/index.ts +188 -0
  96. package/connectors/connect-todoist/src/cli/index.ts +990 -0
  97. package/connectors/connect-todoist/src/index.ts +21 -0
  98. package/connectors/connect-todoist/src/types/index.ts +240 -0
  99. package/connectors/connect-todoist/src/utils/config.ts +157 -0
  100. package/connectors/connect-todoist/src/utils/output.ts +119 -0
  101. package/connectors/connect-todoist/tsconfig.json +16 -0
  102. package/connectors/connect-trello/.env.example +11 -0
  103. package/connectors/connect-trello/CLAUDE.md +128 -0
  104. package/connectors/connect-trello/README.md +193 -0
  105. package/connectors/connect-trello/package.json +53 -0
  106. package/connectors/connect-trello/src/api/client.ts +128 -0
  107. package/connectors/connect-trello/src/api/index.ts +278 -0
  108. package/connectors/connect-trello/src/cli/index.ts +737 -0
  109. package/connectors/connect-trello/src/index.ts +21 -0
  110. package/connectors/connect-trello/src/types/index.ts +314 -0
  111. package/connectors/connect-trello/src/utils/config.ts +182 -0
  112. package/connectors/connect-trello/src/utils/output.ts +119 -0
  113. package/connectors/connect-trello/tsconfig.json +16 -0
  114. package/connectors/connect-whatsapp/.env.example +11 -0
  115. package/connectors/connect-whatsapp/CLAUDE.md +113 -0
  116. package/connectors/connect-whatsapp/README.md +193 -0
  117. package/connectors/connect-whatsapp/package.json +53 -0
  118. package/connectors/connect-whatsapp/src/api/client.ts +133 -0
  119. package/connectors/connect-whatsapp/src/api/index.ts +365 -0
  120. package/connectors/connect-whatsapp/src/cli/index.ts +686 -0
  121. package/connectors/connect-whatsapp/src/index.ts +25 -0
  122. package/connectors/connect-whatsapp/src/types/index.ts +502 -0
  123. package/connectors/connect-whatsapp/src/utils/config.ts +179 -0
  124. package/connectors/connect-whatsapp/src/utils/output.ts +119 -0
  125. package/connectors/connect-whatsapp/tsconfig.json +16 -0
  126. package/dist/index.js +70 -0
  127. package/package.json +1 -1
@@ -0,0 +1,113 @@
1
+ # CLAUDE.md
2
+
3
+ This file provides guidance to Claude Code when working with code in this repository.
4
+
5
+ ## Project Overview
6
+
7
+ connect-whatsapp is a TypeScript connector for the WhatsApp Business Cloud API. It provides CLI and library access to send messages, manage templates, and handle media.
8
+
9
+ ## Build & Run Commands
10
+
11
+ ```bash
12
+ # Install dependencies
13
+ bun install
14
+
15
+ # Run CLI in development
16
+ bun run dev
17
+
18
+ # Build for distribution
19
+ bun run build
20
+
21
+ # Type check
22
+ bun run typecheck
23
+
24
+ # Run specific commands
25
+ bun run dev message text <to> "Hello"
26
+ bun run dev template list
27
+ bun run dev config show
28
+ ```
29
+
30
+ ## Code Style
31
+
32
+ - TypeScript with strict mode
33
+ - ESM modules (type: module)
34
+ - Use async/await for all async operations
35
+ - Minimal dependencies: commander, chalk only
36
+ - Type annotations required everywhere
37
+
38
+ ## Project Structure
39
+
40
+ ```
41
+ src/
42
+ ├── api/
43
+ │ ├── client.ts # HTTP client with Bearer token auth
44
+ │ └── index.ts # WhatsApp API wrapper class
45
+ ├── cli/
46
+ │ └── index.ts # CLI commands
47
+ ├── types/
48
+ │ └── index.ts # Type definitions
49
+ ├── utils/
50
+ │ ├── config.ts # Multi-profile configuration
51
+ │ └── output.ts # CLI output formatting
52
+ └── index.ts # Library exports
53
+ ```
54
+
55
+ ## API Coverage
56
+
57
+ ### Messages
58
+ - Send text, image, audio, video, document, sticker
59
+ - Send location, contacts
60
+ - Send interactive messages (buttons, lists)
61
+ - Send template messages
62
+ - Send reactions
63
+ - Mark messages as read
64
+
65
+ ### Media
66
+ - Get media URL
67
+ - Delete media
68
+
69
+ ### Business Profile
70
+ - Get and update business profile
71
+
72
+ ### Phone Numbers
73
+ - Get phone number info
74
+ - List phone numbers
75
+ - Request and verify codes
76
+
77
+ ### Templates
78
+ - List, get, delete message templates
79
+
80
+ ## Authentication
81
+
82
+ Uses Bearer token authentication with Meta Graph API:
83
+ ```typescript
84
+ 'Authorization': `Bearer ${this.accessToken}`
85
+ ```
86
+
87
+ Requires:
88
+ - Access Token (from Meta Business Suite)
89
+ - Phone Number ID (from WhatsApp Business)
90
+ - Business Account ID (optional, for some operations)
91
+
92
+ ## Environment Variables
93
+
94
+ | Variable | Description |
95
+ |----------|-------------|
96
+ | `WHATSAPP_ACCESS_TOKEN` | Access token (overrides profile) |
97
+ | `WHATSAPP_PHONE_NUMBER_ID` | Phone number ID (overrides profile) |
98
+ | `WHATSAPP_BUSINESS_ACCOUNT_ID` | Business account ID (overrides profile) |
99
+
100
+ ## Data Storage
101
+
102
+ ```
103
+ ~/.connect/connect-whatsapp/
104
+ ├── current_profile # Active profile name
105
+ └── profiles/
106
+ ├── default.json # Default profile
107
+ └── {name}.json # Named profiles
108
+ ```
109
+
110
+ ## Dependencies
111
+
112
+ - commander: CLI framework
113
+ - chalk: Terminal styling
@@ -0,0 +1,193 @@
1
+ # scaffold-connector
2
+
3
+ A TypeScript scaffold for building API connector CLIs with multi-profile support.
4
+
5
+ ## Features
6
+
7
+ - Multi-profile configuration (switch between different API keys/accounts)
8
+ - Bearer token authentication (easily customizable)
9
+ - Clean CLI structure with Commander.js
10
+ - Pretty and JSON output formats
11
+ - TypeScript with strict mode
12
+
13
+ ## Quick Start
14
+
15
+ ### 1. Clone and Rename
16
+
17
+ ```bash
18
+ # Clone for your connector
19
+ git clone https://github.com/hasna/connectors.git connect-yourapi
20
+ cd connect-yourapi
21
+
22
+ # Update package.json name
23
+ # Change "@hasna/scaffold-connector" to "@hasna/connect-yourapi"
24
+ ```
25
+
26
+ ### 2. Update Configuration
27
+
28
+ Search for `TODO` comments throughout the codebase and update:
29
+
30
+ - `src/cli/index.ts` - Update `CONNECTOR_NAME` and description
31
+ - `src/utils/config.ts` - Update `CONNECTOR_NAME` and env var names
32
+ - `src/api/client.ts` - Update `DEFAULT_BASE_URL` and authentication method
33
+ - `src/api/index.ts` - Rename `Connector` class to your API name
34
+ - `src/types/index.ts` - Add your API's type definitions
35
+ - `package.json` - Update name, description, bin command
36
+ - `.env.example` - Update environment variable names
37
+
38
+ ### 3. Install and Test
39
+
40
+ ```bash
41
+ # Install dependencies
42
+ bun install
43
+
44
+ # Run CLI
45
+ bun run dev
46
+
47
+ # Or run specific commands
48
+ bun run dev profile list
49
+ bun run dev config show
50
+ ```
51
+
52
+ ## CLI Structure
53
+
54
+ ```bash
55
+ connector [options] [command]
56
+
57
+ Options:
58
+ -k, --api-key <key> API key (overrides config)
59
+ -f, --format <format> Output format (json, pretty)
60
+ -p, --profile <profile> Use a specific profile
61
+
62
+ Commands:
63
+ profile list List all profiles
64
+ profile use <name> Switch to a profile
65
+ profile create <name> Create a new profile
66
+ profile delete <name> Delete a profile
67
+ profile show [name] Show profile configuration
68
+
69
+ config set-key <key> Set API key for active profile
70
+ config show Show current configuration
71
+ config clear Clear configuration
72
+
73
+ example list Example API command (replace)
74
+ example get <id> Example API command (replace)
75
+ example create Example API command (replace)
76
+ ```
77
+
78
+ ## Project Structure
79
+
80
+ ```
81
+ src/
82
+ ├── api/
83
+ │ ├── client.ts # HTTP client with authentication
84
+ │ ├── example.ts # Example API module (replace with your API)
85
+ │ └── index.ts # Main connector class
86
+ ├── cli/
87
+ │ └── index.ts # CLI commands
88
+ ├── types/
89
+ │ └── index.ts # Type definitions
90
+ ├── utils/
91
+ │ ├── config.ts # Multi-profile configuration
92
+ │ └── output.ts # CLI output formatting
93
+ └── index.ts # Library exports
94
+ ```
95
+
96
+ ## Multi-Profile Configuration
97
+
98
+ Profiles are stored in `~/.connect/{connector-name}/profiles/`:
99
+
100
+ ```
101
+ ~/.connect/connector/
102
+ ├── current_profile # Name of active profile
103
+ └── profiles/
104
+ ├── default.json # Default profile
105
+ ├── work.json # Named profile
106
+ └── personal.json # Named profile
107
+ ```
108
+
109
+ ### Profile Commands
110
+
111
+ ```bash
112
+ # Create profiles
113
+ connector profile create work --api-key sk-xxx --use
114
+ connector profile create personal --api-key sk-yyy
115
+
116
+ # Switch profiles
117
+ connector profile use work
118
+
119
+ # Use profile for single command
120
+ connector -p personal example list
121
+
122
+ # List profiles
123
+ connector profile list
124
+ ```
125
+
126
+ ## Customizing Authentication
127
+
128
+ Edit `src/api/client.ts` to change authentication:
129
+
130
+ ```typescript
131
+ // Bearer token (default)
132
+ 'Authorization': `Bearer ${this.apiKey}`,
133
+
134
+ // API Key header
135
+ 'X-API-Key': this.apiKey,
136
+
137
+ // Basic auth
138
+ 'Authorization': `Basic ${Buffer.from(`${this.apiKey}:${this.apiSecret}`).toString('base64')}`,
139
+ ```
140
+
141
+ ## Adding API Endpoints
142
+
143
+ 1. Create a new file in `src/api/` (e.g., `users.ts`)
144
+ 2. Export it from `src/api/index.ts`
145
+ 3. Add types in `src/types/index.ts`
146
+ 4. Add CLI commands in `src/cli/index.ts`
147
+
148
+ Example API module:
149
+
150
+ ```typescript
151
+ // src/api/users.ts
152
+ import type { ConnectorClient } from './client';
153
+
154
+ export class UsersApi {
155
+ constructor(private readonly client: ConnectorClient) {}
156
+
157
+ async list(options?: { limit?: number }) {
158
+ return this.client.get('/users', { limit: options?.limit });
159
+ }
160
+
161
+ async get(id: string) {
162
+ return this.client.get(`/users/${id}`);
163
+ }
164
+ }
165
+ ```
166
+
167
+ ## Environment Variables
168
+
169
+ | Variable | Description |
170
+ |----------|-------------|
171
+ | `CONNECTOR_API_KEY` | API key (overrides profile config) |
172
+ | `CONNECTOR_API_SECRET` | API secret (optional) |
173
+ | `CONNECTOR_BASE_URL` | Override base URL (optional) |
174
+
175
+ ## Development
176
+
177
+ ```bash
178
+ # Install dependencies
179
+ bun install
180
+
181
+ # Run CLI in development
182
+ bun run dev
183
+
184
+ # Build for distribution
185
+ bun run build
186
+
187
+ # Type check
188
+ bun run typecheck
189
+ ```
190
+
191
+ ## License
192
+
193
+ Apache-2.0
@@ -0,0 +1,53 @@
1
+ {
2
+ "name": "@hasna/connect-whatsapp",
3
+ "version": "0.1.0",
4
+ "description": "WhatsApp Business Cloud connector - Send messages, manage templates, and handle webhooks",
5
+ "type": "module",
6
+ "bin": {
7
+ "connect-whatsapp": "./bin/index.js"
8
+ },
9
+ "exports": {
10
+ ".": {
11
+ "import": "./dist/index.js",
12
+ "types": "./dist/index.d.ts"
13
+ }
14
+ },
15
+ "main": "./dist/index.js",
16
+ "types": "./dist/index.d.ts",
17
+ "scripts": {
18
+ "build": "bun build ./src/index.ts --outdir ./dist --target bun && bun build ./src/cli/index.ts --outdir ./bin --target bun",
19
+ "dev": "bun run ./src/cli/index.ts",
20
+ "typecheck": "tsc --noEmit",
21
+ "prepublishOnly": "bun run build"
22
+ },
23
+ "keywords": [
24
+ "hasna",
25
+ "whatsapp",
26
+ "business",
27
+ "messaging",
28
+ "chat",
29
+ "meta",
30
+ "api",
31
+ "connector",
32
+ "cli",
33
+ "typescript",
34
+ "bun"
35
+ ],
36
+ "author": "Hasna",
37
+ "license": "Apache-2.0",
38
+ "devDependencies": {
39
+ "@types/bun": "latest",
40
+ "typescript": "^5"
41
+ },
42
+ "dependencies": {
43
+ "commander": "^12.1.0",
44
+ "chalk": "^5.3.0"
45
+ },
46
+ "engines": {
47
+ "bun": ">=1.0.0"
48
+ },
49
+ "repository": {
50
+ "type": "git",
51
+ "url": "git+https://github.com/hasna/connectors.git"
52
+ }
53
+ }
@@ -0,0 +1,133 @@
1
+ import type { WhatsAppConfig, WhatsAppErrorResponse } from '../types';
2
+ import { WhatsAppApiError } from '../types';
3
+
4
+ const DEFAULT_BASE_URL = 'https://graph.facebook.com/v18.0';
5
+
6
+ export interface RequestOptions {
7
+ method?: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';
8
+ params?: Record<string, string | number | boolean | undefined>;
9
+ body?: Record<string, unknown> | unknown[];
10
+ headers?: Record<string, string>;
11
+ }
12
+
13
+ export class WhatsAppClient {
14
+ private readonly accessToken: string;
15
+ private readonly phoneNumberId: string;
16
+ private readonly businessAccountId?: string;
17
+ private readonly baseUrl: string;
18
+
19
+ constructor(config: WhatsAppConfig) {
20
+ if (!config.accessToken) {
21
+ throw new Error('Access token is required');
22
+ }
23
+ if (!config.phoneNumberId) {
24
+ throw new Error('Phone number ID is required');
25
+ }
26
+ this.accessToken = config.accessToken;
27
+ this.phoneNumberId = config.phoneNumberId;
28
+ this.businessAccountId = config.businessAccountId;
29
+ this.baseUrl = config.baseUrl || DEFAULT_BASE_URL;
30
+ }
31
+
32
+ private buildUrl(path: string, params?: Record<string, string | number | boolean | undefined>): string {
33
+ const url = new URL(`${this.baseUrl}${path}`);
34
+
35
+ if (params) {
36
+ Object.entries(params).forEach(([key, value]) => {
37
+ if (value !== undefined && value !== null && value !== '') {
38
+ url.searchParams.append(key, String(value));
39
+ }
40
+ });
41
+ }
42
+
43
+ return url.toString();
44
+ }
45
+
46
+ async request<T>(path: string, options: RequestOptions = {}): Promise<T> {
47
+ const { method = 'GET', params, body, headers = {} } = options;
48
+
49
+ const url = this.buildUrl(path, params);
50
+
51
+ const requestHeaders: Record<string, string> = {
52
+ 'Authorization': `Bearer ${this.accessToken}`,
53
+ 'Accept': 'application/json',
54
+ ...headers,
55
+ };
56
+
57
+ if (body && ['POST', 'PUT', 'PATCH'].includes(method)) {
58
+ requestHeaders['Content-Type'] = 'application/json';
59
+ }
60
+
61
+ const fetchOptions: RequestInit = {
62
+ method,
63
+ headers: requestHeaders,
64
+ };
65
+
66
+ if (body && ['POST', 'PUT', 'PATCH'].includes(method)) {
67
+ fetchOptions.body = JSON.stringify(body);
68
+ }
69
+
70
+ const response = await fetch(url, fetchOptions);
71
+
72
+ if (response.status === 204) {
73
+ return {} as T;
74
+ }
75
+
76
+ let data: unknown;
77
+ const contentType = response.headers.get('content-type') || '';
78
+
79
+ if (contentType.includes('application/json')) {
80
+ const text = await response.text();
81
+ if (text) {
82
+ try {
83
+ data = JSON.parse(text);
84
+ } catch {
85
+ data = text;
86
+ }
87
+ }
88
+ } else {
89
+ data = await response.text();
90
+ }
91
+
92
+ if (!response.ok) {
93
+ const errorData = data as WhatsAppErrorResponse | null;
94
+ const error = errorData?.error;
95
+ throw new WhatsAppApiError(
96
+ error?.message || response.statusText,
97
+ response.status,
98
+ error?.code || 0,
99
+ error?.fbtrace_id || '',
100
+ error?.error_subcode
101
+ );
102
+ }
103
+
104
+ return data as T;
105
+ }
106
+
107
+ async get<T>(path: string, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
108
+ return this.request<T>(path, { method: 'GET', params });
109
+ }
110
+
111
+ async post<T>(path: string, body?: Record<string, unknown>): Promise<T> {
112
+ return this.request<T>(path, { method: 'POST', body });
113
+ }
114
+
115
+ async delete<T>(path: string, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
116
+ return this.request<T>(path, { method: 'DELETE', params });
117
+ }
118
+
119
+ getPhoneNumberId(): string {
120
+ return this.phoneNumberId;
121
+ }
122
+
123
+ getBusinessAccountId(): string | undefined {
124
+ return this.businessAccountId;
125
+ }
126
+
127
+ getTokenPreview(): string {
128
+ if (this.accessToken.length > 15) {
129
+ return `${this.accessToken.substring(0, 10)}...${this.accessToken.substring(this.accessToken.length - 4)}`;
130
+ }
131
+ return '***';
132
+ }
133
+ }