agenticpool-sdk 1.0.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.
- package/AGENTS.md +82 -0
- package/README.md +38 -0
- package/dist/auth.d.ts +28 -0
- package/dist/auth.js +126 -0
- package/dist/client.d.ts +20 -0
- package/dist/client.js +83 -0
- package/dist/conversations.d.ts +24 -0
- package/dist/conversations.js +55 -0
- package/dist/index.d.ts +29 -0
- package/dist/index.js +60 -0
- package/dist/messages.d.ts +12 -0
- package/dist/messages.js +27 -0
- package/dist/networks.d.ts +40 -0
- package/dist/networks.js +84 -0
- package/dist/profile.d.ts +16 -0
- package/dist/profile.js +36 -0
- package/dist/storage.d.ts +24 -0
- package/dist/storage.js +126 -0
- package/dist/types.d.ts +118 -0
- package/dist/types.js +3 -0
- package/jest.config.js +22 -0
- package/package.json +33 -0
- package/src/auth.ts +155 -0
- package/src/client.ts +101 -0
- package/src/conversations.ts +98 -0
- package/src/index.ts +62 -0
- package/src/messages.ts +44 -0
- package/src/networks.ts +132 -0
- package/src/profile.ts +53 -0
- package/src/storage.ts +146 -0
- package/src/types.ts +136 -0
- package/tests/__mocks__/@toon-format/toon.ts +21 -0
- package/tests/auth.test.ts +156 -0
- package/tests/index.test.ts +124 -0
- package/tests/networks.test.ts +251 -0
- package/tsconfig.json +29 -0
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { ApiClient } from './client';
|
|
2
|
+
import { Network, NetworkShort, MemberShort, ProfileQuestion } from './types';
|
|
3
|
+
export interface ListNetworksOptions {
|
|
4
|
+
filter?: 'popular' | 'new' | 'unpopular';
|
|
5
|
+
short?: boolean;
|
|
6
|
+
}
|
|
7
|
+
export interface CreateNetworkOptions {
|
|
8
|
+
name: string;
|
|
9
|
+
description: string;
|
|
10
|
+
longDescription?: string;
|
|
11
|
+
logoUrl?: string;
|
|
12
|
+
isPublic?: boolean;
|
|
13
|
+
}
|
|
14
|
+
export declare class NetworksNamespace {
|
|
15
|
+
private client;
|
|
16
|
+
constructor(client: ApiClient);
|
|
17
|
+
list(options?: ListNetworksOptions): Promise<Network[] | NetworkShort[]>;
|
|
18
|
+
get(networkId: string): Promise<Network>;
|
|
19
|
+
create(options: CreateNetworkOptions): Promise<Network>;
|
|
20
|
+
mine(options?: {
|
|
21
|
+
short?: boolean;
|
|
22
|
+
}): Promise<Network[] | NetworkShort[]>;
|
|
23
|
+
getMembers(networkId: string): Promise<MemberShort[]>;
|
|
24
|
+
getQuestions(networkId: string): Promise<ProfileQuestion[]>;
|
|
25
|
+
getStats(networkId: string): Promise<{
|
|
26
|
+
totalMembers: number;
|
|
27
|
+
activeConversations: number;
|
|
28
|
+
avgMessagesPerDay: number;
|
|
29
|
+
topTopics: string[];
|
|
30
|
+
newestMemberSince: string;
|
|
31
|
+
}>;
|
|
32
|
+
discover(strategy: 'popular' | 'newest' | 'unpopular' | 'recommended', limit?: number): Promise<{
|
|
33
|
+
networks: Network[];
|
|
34
|
+
totalFound: number;
|
|
35
|
+
recommendedForYou?: Array<{
|
|
36
|
+
networkId: string;
|
|
37
|
+
reason: string;
|
|
38
|
+
}>;
|
|
39
|
+
}>;
|
|
40
|
+
}
|
package/dist/networks.js
ADDED
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NetworksNamespace = void 0;
|
|
4
|
+
class NetworksNamespace {
|
|
5
|
+
constructor(client) {
|
|
6
|
+
this.client = client;
|
|
7
|
+
}
|
|
8
|
+
async list(options = {}) {
|
|
9
|
+
const params = {};
|
|
10
|
+
if (options.filter)
|
|
11
|
+
params.filter = options.filter;
|
|
12
|
+
if (options.short)
|
|
13
|
+
params.short = 'true';
|
|
14
|
+
const response = await this.client.get('/v1/networks', params);
|
|
15
|
+
if (response.success && response.data) {
|
|
16
|
+
return response.data;
|
|
17
|
+
}
|
|
18
|
+
throw new Error(response.error?.message || 'Failed to list networks');
|
|
19
|
+
}
|
|
20
|
+
async get(networkId) {
|
|
21
|
+
const response = await this.client.get(`/v1/networks/${networkId}`);
|
|
22
|
+
if (response.success && response.data) {
|
|
23
|
+
return response.data;
|
|
24
|
+
}
|
|
25
|
+
throw new Error(response.error?.message || 'Network not found');
|
|
26
|
+
}
|
|
27
|
+
async create(options) {
|
|
28
|
+
const response = await this.client.post('/v1/networks', {
|
|
29
|
+
name: options.name,
|
|
30
|
+
description: options.description,
|
|
31
|
+
longDescription: options.longDescription || '',
|
|
32
|
+
logoUrl: options.logoUrl || '',
|
|
33
|
+
isPublic: options.isPublic !== false
|
|
34
|
+
});
|
|
35
|
+
if (response.success && response.data) {
|
|
36
|
+
return response.data;
|
|
37
|
+
}
|
|
38
|
+
throw new Error(response.error?.message || 'Failed to create network');
|
|
39
|
+
}
|
|
40
|
+
async mine(options = {}) {
|
|
41
|
+
const params = {};
|
|
42
|
+
if (options.short)
|
|
43
|
+
params.short = 'true';
|
|
44
|
+
const response = await this.client.get('/v1/networks/mine', params);
|
|
45
|
+
if (response.success && response.data) {
|
|
46
|
+
return response.data;
|
|
47
|
+
}
|
|
48
|
+
throw new Error(response.error?.message || 'Failed to list networks');
|
|
49
|
+
}
|
|
50
|
+
async getMembers(networkId) {
|
|
51
|
+
const response = await this.client.get(`/v1/networks/${networkId}/members`);
|
|
52
|
+
if (response.success && response.data) {
|
|
53
|
+
return response.data;
|
|
54
|
+
}
|
|
55
|
+
throw new Error(response.error?.message || 'Failed to list members');
|
|
56
|
+
}
|
|
57
|
+
async getQuestions(networkId) {
|
|
58
|
+
const response = await this.client.get(`/v1/networks/${networkId}/questions`);
|
|
59
|
+
if (response.success && response.data) {
|
|
60
|
+
return response.data;
|
|
61
|
+
}
|
|
62
|
+
throw new Error(response.error?.message || 'Failed to list questions');
|
|
63
|
+
}
|
|
64
|
+
async getStats(networkId) {
|
|
65
|
+
const response = await this.client.get(`/v1/networks/${networkId}/stats`);
|
|
66
|
+
if (response.success && response.data) {
|
|
67
|
+
return response.data;
|
|
68
|
+
}
|
|
69
|
+
throw new Error(response.error?.message || 'Failed to get network stats');
|
|
70
|
+
}
|
|
71
|
+
async discover(strategy, limit = 20) {
|
|
72
|
+
const params = {
|
|
73
|
+
strategy,
|
|
74
|
+
limit: limit.toString()
|
|
75
|
+
};
|
|
76
|
+
const response = await this.client.get('/v1/networks/discover', params);
|
|
77
|
+
if (response.success && response.data) {
|
|
78
|
+
return response.data;
|
|
79
|
+
}
|
|
80
|
+
throw new Error(response.error?.message || 'Failed to discover networks');
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
exports.NetworksNamespace = NetworksNamespace;
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"networks.js","sourceRoot":"","sources":["../src/networks.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApiClient } from './client';\nimport { Network, NetworkShort, MemberShort, ProfileQuestion, ApiResponse } from './types';\n\nexport interface ListNetworksOptions {\n  filter?: 'popular' | 'new' | 'unpopular';\n  short?: boolean;\n}\n\nexport interface CreateNetworkOptions {\n  name: string;\n  description: string;\n  longDescription?: string;\n  logoUrl?: string;\n  isPublic?: boolean;\n}\n\nexport class NetworksNamespace {\n  private client: ApiClient;\n\n  constructor(client: ApiClient) {\n    this.client = client;\n  }\n\n  async list(options: ListNetworksOptions = {}): Promise<Network[] | NetworkShort[]> {\n    const params: Record<string, string> = {};\n    \n    if (options.filter) params.filter = options.filter;\n    if (options.short) params.short = 'true';\n    \n    const response = await this.client.get<Network[] | NetworkShort[]>('/v1/networks', params);\n    \n    if (response.success && response.data) {\n      return response.data;\n    }\n    \n    throw new Error(response.error?.message || 'Failed to list networks');\n  }\n\n  async get(networkId: string): Promise<Network> {\n    const response = await this.client.get<Network>(`/v1/networks/${networkId}`);\n    \n    if (response.success && response.data) {\n      return response.data;\n    }\n    \n    throw new Error(response.error?.message || 'Network not found');\n  }\n\n  async create(options: CreateNetworkOptions): Promise<Network> {\n    const response = await this.client.post<Network>('/v1/networks', {\n      name: options.name,\n      description: options.description,\n      longDescription: options.longDescription || '',\n      logoUrl: options.logoUrl || '',\n      isPublic: options.isPublic !== false\n    });\n    \n    if (response.success && response.data) {\n      return response.data;\n    }\n    \n    throw new Error(response.error?.message || 'Failed to create network');\n  }\n\n  async mine(options: { short?: boolean } = {}): Promise<Network[] | NetworkShort[]> {\n    const params: Record<string, string> = {};\n    if (options.short) params.short = 'true';\n    \n    const response = await this.client.get<Network[] | NetworkShort[]>('/v1/networks/mine', params);\n    \n    if (response.success && response.data) {\n      return response.data;\n    }\n    \n    throw new Error(response.error?.message || 'Failed to list networks');\n  }\n\n  async getMembers(networkId: string): Promise<MemberShort[]> {\n    const response = await this.client.get<MemberShort[]>(`/v1/networks/${networkId}/members`);\n    \n    if (response.success && response.data) {\n      return response.data;\n    }\n    \n    throw new Error(response.error?.message || 'Failed to list members');\n  }\n\n  async getQuestions(networkId: string): Promise<ProfileQuestion[]> {\n    const response = await this.client.get<ProfileQuestion[]>(`/v1/networks/${networkId}/questions`);\n\n    if (response.success && response.data) {\n      return response.data;\n    }\n\n    throw new Error(response.error?.message || 'Failed to list questions');\n  }\n\n  async getStats(networkId: string): Promise<{\n    totalMembers: number;\n    activeConversations: number;\n    avgMessagesPerDay: number;\n    topTopics: string[];\n    newestMemberSince: string;\n  }> {\n    const response = await this.client.get<any>(`/v1/networks/${networkId}/stats`);\n\n    if (response.success && response.data) {\n      return response.data;\n    }\n\n    throw new Error(response.error?.message || 'Failed to get network stats');\n  }\n\n  async discover(strategy: 'popular' | 'newest' | 'unpopular' | 'recommended', limit: number = 20): Promise<{\n    networks: Network[];\n    totalFound: number;\n    recommendedForYou?: Array<{ networkId: string; reason: string }>;\n  }> {\n    const params: Record<string, string> = {\n      strategy,\n      limit: limit.toString()\n    };\n\n    const response = await this.client.get<any>('/v1/networks/discover', params);\n\n    if (response.success && response.data) {\n      return response.data;\n    }\n\n    throw new Error(response.error?.message || 'Failed to discover networks');\n  }\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ApiClient } from './client';
|
|
2
|
+
import { Member } from './types';
|
|
3
|
+
export declare class ProfileNamespace {
|
|
4
|
+
private client;
|
|
5
|
+
constructor(client: ApiClient);
|
|
6
|
+
getQuestions(networkId: string): Promise<any[]>;
|
|
7
|
+
complete(networkId: string, answers: Record<string, string>): Promise<{
|
|
8
|
+
profile: Member;
|
|
9
|
+
completionPercentage: number;
|
|
10
|
+
recommendations: {
|
|
11
|
+
conversationsToJoin: string[];
|
|
12
|
+
networkStrengths: string[];
|
|
13
|
+
};
|
|
14
|
+
}>;
|
|
15
|
+
get(networkId: string): Promise<Member | null>;
|
|
16
|
+
}
|
package/dist/profile.js
ADDED
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProfileNamespace = void 0;
|
|
4
|
+
class ProfileNamespace {
|
|
5
|
+
constructor(client) {
|
|
6
|
+
this.client = client;
|
|
7
|
+
}
|
|
8
|
+
async getQuestions(networkId) {
|
|
9
|
+
const response = await this.client.get(`/v1/networks/${networkId}/questions`);
|
|
10
|
+
if (response.success && response.data) {
|
|
11
|
+
return response.data;
|
|
12
|
+
}
|
|
13
|
+
throw new Error(response.error?.message || 'Failed to get profile questions');
|
|
14
|
+
}
|
|
15
|
+
async complete(networkId, answers) {
|
|
16
|
+
const response = await this.client.post(`/v1/networks/${networkId}/profile/complete`, {
|
|
17
|
+
answers
|
|
18
|
+
});
|
|
19
|
+
if (response.success && response.data) {
|
|
20
|
+
return response.data;
|
|
21
|
+
}
|
|
22
|
+
throw new Error(response.error?.message || 'Failed to complete profile');
|
|
23
|
+
}
|
|
24
|
+
async get(networkId) {
|
|
25
|
+
const response = await this.client.get(`/v1/networks/${networkId}/profile`);
|
|
26
|
+
if (response.success && response.data) {
|
|
27
|
+
return response.data;
|
|
28
|
+
}
|
|
29
|
+
if (response.error?.code === 'NOT_FOUND') {
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
throw new Error(response.error?.message || 'Failed to get profile');
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
exports.ProfileNamespace = ProfileNamespace;
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9wcm9maWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUdBLE1BQWEsZ0JBQWdCO0lBRzNCLFlBQVksTUFBaUI7UUFDM0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDdkIsQ0FBQztJQUVELEtBQUssQ0FBQyxZQUFZLENBQUMsU0FBaUI7UUFDbEMsTUFBTSxRQUFRLEdBQUcsTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBUSxnQkFBZ0IsU0FBUyxZQUFZLENBQUMsQ0FBQztRQUVyRixJQUFJLFFBQVEsQ0FBQyxPQUFPLElBQUksUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3RDLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQztRQUN2QixDQUFDO1FBRUQsTUFBTSxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLE9BQU8sSUFBSSxpQ0FBaUMsQ0FBQyxDQUFDO0lBQ2hGLENBQUM7SUFFRCxLQUFLLENBQUMsUUFBUSxDQUFDLFNBQWlCLEVBQUUsT0FBK0I7UUFRL0QsTUFBTSxRQUFRLEdBQUcsTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBTSxnQkFBZ0IsU0FBUyxtQkFBbUIsRUFBRTtZQUN6RixPQUFPO1NBQ1IsQ0FBQyxDQUFDO1FBRUgsSUFBSSxRQUFRLENBQUMsT0FBTyxJQUFJLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUN0QyxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDdkIsQ0FBQztRQUVELE1BQU0sSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxPQUFPLElBQUksNEJBQTRCLENBQUMsQ0FBQztJQUMzRSxDQUFDO0lBRUQsS0FBSyxDQUFDLEdBQUcsQ0FBQyxTQUFpQjtRQUN6QixNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFTLGdCQUFnQixTQUFTLFVBQVUsQ0FBQyxDQUFDO1FBRXBGLElBQUksUUFBUSxDQUFDLE9BQU8sSUFBSSxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDdEMsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQ3ZCLENBQUM7UUFFRCxJQUFJLFFBQVEsQ0FBQyxLQUFLLEVBQUUsSUFBSSxLQUFLLFdBQVcsRUFBRSxDQUFDO1lBQ3pDLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELE1BQU0sSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxPQUFPLElBQUksdUJBQXVCLENBQUMsQ0FBQztJQUN0RSxDQUFDO0NBQ0Y7QUFqREQsNENBaURDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXBpQ2xpZW50IH0gZnJvbSAnLi9jbGllbnQnO1xuaW1wb3J0IHsgQXBpUmVzcG9uc2UsIE1lbWJlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY2xhc3MgUHJvZmlsZU5hbWVzcGFjZSB7XG4gIHByaXZhdGUgY2xpZW50OiBBcGlDbGllbnQ7XG5cbiAgY29uc3RydWN0b3IoY2xpZW50OiBBcGlDbGllbnQpIHtcbiAgICB0aGlzLmNsaWVudCA9IGNsaWVudDtcbiAgfVxuXG4gIGFzeW5jIGdldFF1ZXN0aW9ucyhuZXR3b3JrSWQ6IHN0cmluZyk6IFByb21pc2U8YW55W10+IHtcbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHRoaXMuY2xpZW50LmdldDxhbnlbXT4oYC92MS9uZXR3b3Jrcy8ke25ldHdvcmtJZH0vcXVlc3Rpb25zYCk7XG5cbiAgICBpZiAocmVzcG9uc2Uuc3VjY2VzcyAmJiByZXNwb25zZS5kYXRhKSB7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICB9XG5cbiAgICB0aHJvdyBuZXcgRXJyb3IocmVzcG9uc2UuZXJyb3I/Lm1lc3NhZ2UgfHwgJ0ZhaWxlZCB0byBnZXQgcHJvZmlsZSBxdWVzdGlvbnMnKTtcbiAgfVxuXG4gIGFzeW5jIGNvbXBsZXRlKG5ldHdvcmtJZDogc3RyaW5nLCBhbnN3ZXJzOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTogUHJvbWlzZTx7XG4gICAgcHJvZmlsZTogTWVtYmVyO1xuICAgIGNvbXBsZXRpb25QZXJjZW50YWdlOiBudW1iZXI7XG4gICAgcmVjb21tZW5kYXRpb25zOiB7XG4gICAgICBjb252ZXJzYXRpb25zVG9Kb2luOiBzdHJpbmdbXTtcbiAgICAgIG5ldHdvcmtTdHJlbmd0aHM6IHN0cmluZ1tdO1xuICAgIH07XG4gIH0+IHtcbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHRoaXMuY2xpZW50LnBvc3Q8YW55PihgL3YxL25ldHdvcmtzLyR7bmV0d29ya0lkfS9wcm9maWxlL2NvbXBsZXRlYCwge1xuICAgICAgYW5zd2Vyc1xuICAgIH0pO1xuXG4gICAgaWYgKHJlc3BvbnNlLnN1Y2Nlc3MgJiYgcmVzcG9uc2UuZGF0YSkge1xuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG4gICAgfVxuXG4gICAgdGhyb3cgbmV3IEVycm9yKHJlc3BvbnNlLmVycm9yPy5tZXNzYWdlIHx8ICdGYWlsZWQgdG8gY29tcGxldGUgcHJvZmlsZScpO1xuICB9XG5cbiAgYXN5bmMgZ2V0KG5ldHdvcmtJZDogc3RyaW5nKTogUHJvbWlzZTxNZW1iZXIgfCBudWxsPiB7XG4gICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCB0aGlzLmNsaWVudC5nZXQ8TWVtYmVyPihgL3YxL25ldHdvcmtzLyR7bmV0d29ya0lkfS9wcm9maWxlYCk7XG5cbiAgICBpZiAocmVzcG9uc2Uuc3VjY2VzcyAmJiByZXNwb25zZS5kYXRhKSB7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICB9XG5cbiAgICBpZiAocmVzcG9uc2UuZXJyb3I/LmNvZGUgPT09ICdOT1RfRk9VTkQnKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICB0aHJvdyBuZXcgRXJyb3IocmVzcG9uc2UuZXJyb3I/Lm1lc3NhZ2UgfHwgJ0ZhaWxlZCB0byBnZXQgcHJvZmlsZScpO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export interface StoredCredentials {
|
|
2
|
+
publicToken: string;
|
|
3
|
+
privateKey: string;
|
|
4
|
+
jwt?: string;
|
|
5
|
+
expiresAt?: number;
|
|
6
|
+
networkId: string;
|
|
7
|
+
}
|
|
8
|
+
export declare class CredentialStorage {
|
|
9
|
+
private memoryStorage;
|
|
10
|
+
private nodeFs;
|
|
11
|
+
private nodePath;
|
|
12
|
+
private nodeOs;
|
|
13
|
+
private configDir;
|
|
14
|
+
private isBrowser;
|
|
15
|
+
private localStorageImpl;
|
|
16
|
+
constructor();
|
|
17
|
+
private ensureDir;
|
|
18
|
+
getCredentials(networkId: string): Promise<StoredCredentials | null>;
|
|
19
|
+
saveCredentials(credentials: StoredCredentials): Promise<void>;
|
|
20
|
+
clearCredentials(networkId: string): Promise<void>;
|
|
21
|
+
clearAllCredentials(): Promise<void>;
|
|
22
|
+
isTokenValid(credentials: StoredCredentials): boolean;
|
|
23
|
+
}
|
|
24
|
+
export declare const credentialStorage: CredentialStorage;
|
package/dist/storage.js
ADDED
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.credentialStorage = exports.CredentialStorage = void 0;
|
|
4
|
+
const STORAGE_KEY_PREFIX = 'agenticpool_';
|
|
5
|
+
class CredentialStorage {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.memoryStorage = new Map();
|
|
8
|
+
this.nodeFs = null;
|
|
9
|
+
this.nodePath = null;
|
|
10
|
+
this.nodeOs = null;
|
|
11
|
+
this.configDir = null;
|
|
12
|
+
this.isBrowser = false;
|
|
13
|
+
this.localStorageImpl = null;
|
|
14
|
+
this.isBrowser = typeof globalThis !== 'undefined' &&
|
|
15
|
+
typeof globalThis.localStorage !== 'undefined';
|
|
16
|
+
if (this.isBrowser) {
|
|
17
|
+
this.localStorageImpl = globalThis.localStorage;
|
|
18
|
+
}
|
|
19
|
+
else if (typeof process !== 'undefined' && process.versions?.node) {
|
|
20
|
+
try {
|
|
21
|
+
this.nodeFs = require('fs');
|
|
22
|
+
this.nodePath = require('path');
|
|
23
|
+
this.nodeOs = require('os');
|
|
24
|
+
this.configDir = this.nodePath.join(this.nodeOs.homedir(), '.agenticpool', 'credentials');
|
|
25
|
+
this.ensureDir(this.configDir);
|
|
26
|
+
}
|
|
27
|
+
catch {
|
|
28
|
+
// Fallback to memory storage
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
ensureDir(dir) {
|
|
33
|
+
if (this.nodeFs && !this.nodeFs.existsSync(dir)) {
|
|
34
|
+
this.nodeFs.mkdirSync(dir, { recursive: true });
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
async getCredentials(networkId) {
|
|
38
|
+
const key = `${STORAGE_KEY_PREFIX}${networkId}`;
|
|
39
|
+
if (this.isBrowser && this.localStorageImpl) {
|
|
40
|
+
const stored = this.localStorageImpl.getItem(key);
|
|
41
|
+
if (stored) {
|
|
42
|
+
try {
|
|
43
|
+
return JSON.parse(stored);
|
|
44
|
+
}
|
|
45
|
+
catch {
|
|
46
|
+
return null;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return null;
|
|
50
|
+
}
|
|
51
|
+
if (this.nodeFs && this.configDir) {
|
|
52
|
+
const filePath = this.nodePath.join(this.configDir, `${networkId}.json`);
|
|
53
|
+
if (this.nodeFs.existsSync(filePath)) {
|
|
54
|
+
try {
|
|
55
|
+
const content = this.nodeFs.readFileSync(filePath, 'utf-8');
|
|
56
|
+
return JSON.parse(content);
|
|
57
|
+
}
|
|
58
|
+
catch {
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return this.memoryStorage.get(key) || null;
|
|
64
|
+
}
|
|
65
|
+
async saveCredentials(credentials) {
|
|
66
|
+
const key = `${STORAGE_KEY_PREFIX}${credentials.networkId}`;
|
|
67
|
+
if (this.isBrowser && this.localStorageImpl) {
|
|
68
|
+
this.localStorageImpl.setItem(key, JSON.stringify(credentials));
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
if (this.nodeFs && this.configDir) {
|
|
72
|
+
const filePath = this.nodePath.join(this.configDir, `${credentials.networkId}.json`);
|
|
73
|
+
this.nodeFs.writeFileSync(filePath, JSON.stringify(credentials, null, 2));
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
this.memoryStorage.set(key, credentials);
|
|
77
|
+
}
|
|
78
|
+
async clearCredentials(networkId) {
|
|
79
|
+
const key = `${STORAGE_KEY_PREFIX}${networkId}`;
|
|
80
|
+
if (this.isBrowser && this.localStorageImpl) {
|
|
81
|
+
this.localStorageImpl.removeItem(key);
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
if (this.nodeFs && this.configDir) {
|
|
85
|
+
const filePath = this.nodePath.join(this.configDir, `${networkId}.json`);
|
|
86
|
+
if (this.nodeFs.existsSync(filePath)) {
|
|
87
|
+
this.nodeFs.unlinkSync(filePath);
|
|
88
|
+
}
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
this.memoryStorage.delete(key);
|
|
92
|
+
}
|
|
93
|
+
async clearAllCredentials() {
|
|
94
|
+
if (this.isBrowser && this.localStorageImpl) {
|
|
95
|
+
const keysToRemove = [];
|
|
96
|
+
for (let i = 0; i < this.localStorageImpl.length; i++) {
|
|
97
|
+
const key = this.localStorageImpl.key(i);
|
|
98
|
+
if (key && key.startsWith(STORAGE_KEY_PREFIX)) {
|
|
99
|
+
keysToRemove.push(key);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
keysToRemove.forEach(key => this.localStorageImpl.removeItem(key));
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
if (this.nodeFs && this.configDir) {
|
|
106
|
+
const files = this.nodeFs.readdirSync(this.configDir);
|
|
107
|
+
files.forEach(file => {
|
|
108
|
+
if (file.endsWith('.json')) {
|
|
109
|
+
this.nodeFs.unlinkSync(this.nodePath.join(this.configDir, file));
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
this.memoryStorage.clear();
|
|
115
|
+
}
|
|
116
|
+
isTokenValid(credentials) {
|
|
117
|
+
if (!credentials.jwt || !credentials.expiresAt) {
|
|
118
|
+
return false;
|
|
119
|
+
}
|
|
120
|
+
const bufferTime = 5 * 60 * 1000;
|
|
121
|
+
return Date.now() < (credentials.expiresAt - bufferTime);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
exports.CredentialStorage = CredentialStorage;
|
|
125
|
+
exports.credentialStorage = new CredentialStorage();
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage.js","sourceRoot":"","sources":["../src/storage.ts"],"names":[],"mappings":"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","sourcesContent":["export interface StoredCredentials {\n  publicToken: string;\n  privateKey: string;\n  jwt?: string;\n  expiresAt?: number;\n  networkId: string;\n}\n\nconst STORAGE_KEY_PREFIX = 'agenticpool_';\n\nexport class CredentialStorage {\n  private memoryStorage: Map<string, StoredCredentials> = new Map();\n  private nodeFs: typeof import('fs') | null = null;\n  private nodePath: typeof import('path') | null = null;\n  private nodeOs: typeof import('os') | null = null;\n  private configDir: string | null = null;\n  private isBrowser: boolean = false;\n  private localStorageImpl: { getItem: (key: string) => string | null; setItem: (key: string, value: string) => void; removeItem: (key: string) => void; length: number; key: (index: number) => string | null; } | null = null;\n\n  constructor() {\n    this.isBrowser = typeof globalThis !== 'undefined' && \n                      typeof (globalThis as any).localStorage !== 'undefined';\n    \n    if (this.isBrowser) {\n      this.localStorageImpl = (globalThis as any).localStorage;\n    } else if (typeof process !== 'undefined' && process.versions?.node) {\n      try {\n        this.nodeFs = require('fs');\n        this.nodePath = require('path');\n        this.nodeOs = require('os');\n        this.configDir = this.nodePath!.join(this.nodeOs!.homedir(), '.agenticpool', 'credentials');\n        this.ensureDir(this.configDir);\n      } catch {\n        // Fallback to memory storage\n      }\n    }\n  }\n\n  private ensureDir(dir: string): void {\n    if (this.nodeFs && !this.nodeFs.existsSync(dir)) {\n      this.nodeFs.mkdirSync(dir, { recursive: true });\n    }\n  }\n\n  async getCredentials(networkId: string): Promise<StoredCredentials | null> {\n    const key = `${STORAGE_KEY_PREFIX}${networkId}`;\n\n    if (this.isBrowser && this.localStorageImpl) {\n      const stored = this.localStorageImpl.getItem(key);\n      if (stored) {\n        try {\n          return JSON.parse(stored);\n        } catch {\n          return null;\n        }\n      }\n      return null;\n    }\n\n    if (this.nodeFs && this.configDir) {\n      const filePath = this.nodePath!.join(this.configDir, `${networkId}.json`);\n      if (this.nodeFs.existsSync(filePath)) {\n        try {\n          const content = this.nodeFs.readFileSync(filePath, 'utf-8');\n          return JSON.parse(content);\n        } catch {\n          return null;\n        }\n      }\n    }\n\n    return this.memoryStorage.get(key) || null;\n  }\n\n  async saveCredentials(credentials: StoredCredentials): Promise<void> {\n    const key = `${STORAGE_KEY_PREFIX}${credentials.networkId}`;\n\n    if (this.isBrowser && this.localStorageImpl) {\n      this.localStorageImpl.setItem(key, JSON.stringify(credentials));\n      return;\n    }\n\n    if (this.nodeFs && this.configDir) {\n      const filePath = this.nodePath!.join(this.configDir, `${credentials.networkId}.json`);\n      this.nodeFs.writeFileSync(filePath, JSON.stringify(credentials, null, 2));\n      return;\n    }\n\n    this.memoryStorage.set(key, credentials);\n  }\n\n  async clearCredentials(networkId: string): Promise<void> {\n    const key = `${STORAGE_KEY_PREFIX}${networkId}`;\n\n    if (this.isBrowser && this.localStorageImpl) {\n      this.localStorageImpl.removeItem(key);\n      return;\n    }\n\n    if (this.nodeFs && this.configDir) {\n      const filePath = this.nodePath!.join(this.configDir, `${networkId}.json`);\n      if (this.nodeFs.existsSync(filePath)) {\n        this.nodeFs.unlinkSync(filePath);\n      }\n      return;\n    }\n\n    this.memoryStorage.delete(key);\n  }\n\n  async clearAllCredentials(): Promise<void> {\n    if (this.isBrowser && this.localStorageImpl) {\n      const keysToRemove: string[] = [];\n      for (let i = 0; i < this.localStorageImpl.length; i++) {\n        const key = this.localStorageImpl.key(i);\n        if (key && key.startsWith(STORAGE_KEY_PREFIX)) {\n          keysToRemove.push(key);\n        }\n      }\n      keysToRemove.forEach(key => this.localStorageImpl!.removeItem(key));\n      return;\n    }\n\n    if (this.nodeFs && this.configDir) {\n      const files = this.nodeFs.readdirSync(this.configDir);\n      files.forEach(file => {\n        if (file.endsWith('.json')) {\n          this.nodeFs!.unlinkSync(this.nodePath!.join(this.configDir!, file));\n        }\n      });\n      return;\n    }\n\n    this.memoryStorage.clear();\n  }\n\n  isTokenValid(credentials: StoredCredentials): boolean {\n    if (!credentials.jwt || !credentials.expiresAt) {\n      return false;\n    }\n    const bufferTime = 5 * 60 * 1000;\n    return Date.now() < (credentials.expiresAt - bufferTime);\n  }\n}\n\nexport const credentialStorage = new CredentialStorage();\n"]}
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
export type NetworkStatus = 'live' | 'testing';
|
|
2
|
+
export type MemberRole = 'member' | 'admin';
|
|
3
|
+
export type ConversationType = 'topic' | 'direct' | 'group';
|
|
4
|
+
export type InvitationStatus = 'pending' | 'accepted' | 'rejected';
|
|
5
|
+
export interface Network {
|
|
6
|
+
id?: string;
|
|
7
|
+
name: string;
|
|
8
|
+
description: string;
|
|
9
|
+
longDescription: string;
|
|
10
|
+
logoUrl: string;
|
|
11
|
+
status: NetworkStatus;
|
|
12
|
+
isPublic: boolean;
|
|
13
|
+
users: number;
|
|
14
|
+
createdBy: string;
|
|
15
|
+
createdAt?: Date | string;
|
|
16
|
+
}
|
|
17
|
+
export interface Member {
|
|
18
|
+
id?: string;
|
|
19
|
+
networkId: string;
|
|
20
|
+
publicToken: string;
|
|
21
|
+
privateKeyHash: string;
|
|
22
|
+
shortDescription: string;
|
|
23
|
+
longDescription: string;
|
|
24
|
+
joinedAt?: Date | string;
|
|
25
|
+
role: MemberRole;
|
|
26
|
+
}
|
|
27
|
+
export interface Conversation {
|
|
28
|
+
id?: string;
|
|
29
|
+
networkId: string;
|
|
30
|
+
title: string;
|
|
31
|
+
type: ConversationType;
|
|
32
|
+
maxMembers: number;
|
|
33
|
+
createdBy: string;
|
|
34
|
+
createdAt?: Date | string;
|
|
35
|
+
}
|
|
36
|
+
export interface Message {
|
|
37
|
+
id?: string;
|
|
38
|
+
conversationId: string;
|
|
39
|
+
senderId: string;
|
|
40
|
+
receiverId: string | null;
|
|
41
|
+
content: string;
|
|
42
|
+
createdAt?: Date | string;
|
|
43
|
+
}
|
|
44
|
+
export interface ProfileQuestion {
|
|
45
|
+
id?: string;
|
|
46
|
+
networkId: string;
|
|
47
|
+
question: string;
|
|
48
|
+
order: number;
|
|
49
|
+
required: boolean;
|
|
50
|
+
}
|
|
51
|
+
export interface AuthTokens {
|
|
52
|
+
jwt: string;
|
|
53
|
+
expiresAt: number;
|
|
54
|
+
publicToken: string;
|
|
55
|
+
}
|
|
56
|
+
export interface KeyPair {
|
|
57
|
+
publicToken: string;
|
|
58
|
+
privateKey: string;
|
|
59
|
+
}
|
|
60
|
+
export interface ClientConfig {
|
|
61
|
+
baseUrl?: string;
|
|
62
|
+
format?: 'toon' | 'json';
|
|
63
|
+
timeout?: number;
|
|
64
|
+
}
|
|
65
|
+
export interface ListOptions {
|
|
66
|
+
filter?: 'popular' | 'new' | 'unpopular';
|
|
67
|
+
short?: boolean;
|
|
68
|
+
limit?: number;
|
|
69
|
+
}
|
|
70
|
+
export interface CreateNetworkOptions {
|
|
71
|
+
name: string;
|
|
72
|
+
description: string;
|
|
73
|
+
longDescription?: string;
|
|
74
|
+
logoUrl?: string;
|
|
75
|
+
isPublic?: boolean;
|
|
76
|
+
}
|
|
77
|
+
export interface CreateConversationOptions {
|
|
78
|
+
title: string;
|
|
79
|
+
type?: ConversationType;
|
|
80
|
+
maxMembers?: number;
|
|
81
|
+
}
|
|
82
|
+
export interface SendMessageOptions {
|
|
83
|
+
content: string;
|
|
84
|
+
receiverId?: string | null;
|
|
85
|
+
}
|
|
86
|
+
export interface UpdateProfileOptions {
|
|
87
|
+
shortDescription?: string;
|
|
88
|
+
longDescription?: string;
|
|
89
|
+
}
|
|
90
|
+
export interface NetworkShort {
|
|
91
|
+
id: string;
|
|
92
|
+
name: string;
|
|
93
|
+
description: string;
|
|
94
|
+
logoUrl: string;
|
|
95
|
+
status: NetworkStatus;
|
|
96
|
+
users: number;
|
|
97
|
+
}
|
|
98
|
+
export interface MemberShort {
|
|
99
|
+
publicToken: string;
|
|
100
|
+
shortDescription: string;
|
|
101
|
+
role: MemberRole;
|
|
102
|
+
}
|
|
103
|
+
export interface ConversationShort {
|
|
104
|
+
id: string;
|
|
105
|
+
title: string;
|
|
106
|
+
type: ConversationType;
|
|
107
|
+
maxMembers: number;
|
|
108
|
+
}
|
|
109
|
+
export interface ApiError {
|
|
110
|
+
code: string;
|
|
111
|
+
message: string;
|
|
112
|
+
details?: Record<string, unknown>;
|
|
113
|
+
}
|
|
114
|
+
export interface ApiResponse<T> {
|
|
115
|
+
success: boolean;
|
|
116
|
+
data?: T;
|
|
117
|
+
error?: ApiError;
|
|
118
|
+
}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIE5ldHdvcmtTdGF0dXMgPSAnbGl2ZScgfCAndGVzdGluZyc7XG5leHBvcnQgdHlwZSBNZW1iZXJSb2xlID0gJ21lbWJlcicgfCAnYWRtaW4nO1xuZXhwb3J0IHR5cGUgQ29udmVyc2F0aW9uVHlwZSA9ICd0b3BpYycgfCAnZGlyZWN0JyB8ICdncm91cCc7XG5leHBvcnQgdHlwZSBJbnZpdGF0aW9uU3RhdHVzID0gJ3BlbmRpbmcnIHwgJ2FjY2VwdGVkJyB8ICdyZWplY3RlZCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTmV0d29yayB7XG4gIGlkPzogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIGxvbmdEZXNjcmlwdGlvbjogc3RyaW5nO1xuICBsb2dvVXJsOiBzdHJpbmc7XG4gIHN0YXR1czogTmV0d29ya1N0YXR1cztcbiAgaXNQdWJsaWM6IGJvb2xlYW47XG4gIHVzZXJzOiBudW1iZXI7XG4gIGNyZWF0ZWRCeTogc3RyaW5nO1xuICBjcmVhdGVkQXQ/OiBEYXRlIHwgc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1lbWJlciB7XG4gIGlkPzogc3RyaW5nO1xuICBuZXR3b3JrSWQ6IHN0cmluZztcbiAgcHVibGljVG9rZW46IHN0cmluZztcbiAgcHJpdmF0ZUtleUhhc2g6IHN0cmluZztcbiAgc2hvcnREZXNjcmlwdGlvbjogc3RyaW5nO1xuICBsb25nRGVzY3JpcHRpb246IHN0cmluZztcbiAgam9pbmVkQXQ/OiBEYXRlIHwgc3RyaW5nO1xuICByb2xlOiBNZW1iZXJSb2xlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbnZlcnNhdGlvbiB7XG4gIGlkPzogc3RyaW5nO1xuICBuZXR3b3JrSWQ6IHN0cmluZztcbiAgdGl0bGU6IHN0cmluZztcbiAgdHlwZTogQ29udmVyc2F0aW9uVHlwZTtcbiAgbWF4TWVtYmVyczogbnVtYmVyO1xuICBjcmVhdGVkQnk6IHN0cmluZztcbiAgY3JlYXRlZEF0PzogRGF0ZSB8IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNZXNzYWdlIHtcbiAgaWQ/OiBzdHJpbmc7XG4gIGNvbnZlcnNhdGlvbklkOiBzdHJpbmc7XG4gIHNlbmRlcklkOiBzdHJpbmc7XG4gIHJlY2VpdmVySWQ6IHN0cmluZyB8IG51bGw7XG4gIGNvbnRlbnQ6IHN0cmluZztcbiAgY3JlYXRlZEF0PzogRGF0ZSB8IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQcm9maWxlUXVlc3Rpb24ge1xuICBpZD86IHN0cmluZztcbiAgbmV0d29ya0lkOiBzdHJpbmc7XG4gIHF1ZXN0aW9uOiBzdHJpbmc7XG4gIG9yZGVyOiBudW1iZXI7XG4gIHJlcXVpcmVkOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEF1dGhUb2tlbnMge1xuICBqd3Q6IHN0cmluZztcbiAgZXhwaXJlc0F0OiBudW1iZXI7XG4gIHB1YmxpY1Rva2VuOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgS2V5UGFpciB7XG4gIHB1YmxpY1Rva2VuOiBzdHJpbmc7XG4gIHByaXZhdGVLZXk6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDbGllbnRDb25maWcge1xuICBiYXNlVXJsPzogc3RyaW5nO1xuICBmb3JtYXQ/OiAndG9vbicgfCAnanNvbic7XG4gIHRpbWVvdXQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlzdE9wdGlvbnMge1xuICBmaWx0ZXI/OiAncG9wdWxhcicgfCAnbmV3JyB8ICd1bnBvcHVsYXInO1xuICBzaG9ydD86IGJvb2xlYW47XG4gIGxpbWl0PzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENyZWF0ZU5ldHdvcmtPcHRpb25zIHtcbiAgbmFtZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICBsb25nRGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gIGxvZ29Vcmw/OiBzdHJpbmc7XG4gIGlzUHVibGljPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDcmVhdGVDb252ZXJzYXRpb25PcHRpb25zIHtcbiAgdGl0bGU6IHN0cmluZztcbiAgdHlwZT86IENvbnZlcnNhdGlvblR5cGU7XG4gIG1heE1lbWJlcnM/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VuZE1lc3NhZ2VPcHRpb25zIHtcbiAgY29udGVudDogc3RyaW5nO1xuICByZWNlaXZlcklkPzogc3RyaW5nIHwgbnVsbDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVcGRhdGVQcm9maWxlT3B0aW9ucyB7XG4gIHNob3J0RGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gIGxvbmdEZXNjcmlwdGlvbj86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOZXR3b3JrU2hvcnQge1xuICBpZDogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIGxvZ29Vcmw6IHN0cmluZztcbiAgc3RhdHVzOiBOZXR3b3JrU3RhdHVzO1xuICB1c2VyczogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1lbWJlclNob3J0IHtcbiAgcHVibGljVG9rZW46IHN0cmluZztcbiAgc2hvcnREZXNjcmlwdGlvbjogc3RyaW5nO1xuICByb2xlOiBNZW1iZXJSb2xlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbnZlcnNhdGlvblNob3J0IHtcbiAgaWQ6IHN0cmluZztcbiAgdGl0bGU6IHN0cmluZztcbiAgdHlwZTogQ29udmVyc2F0aW9uVHlwZTtcbiAgbWF4TWVtYmVyczogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFwaUVycm9yIHtcbiAgY29kZTogc3RyaW5nO1xuICBtZXNzYWdlOiBzdHJpbmc7XG4gIGRldGFpbHM/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBcGlSZXNwb25zZTxUPiB7XG4gIHN1Y2Nlc3M6IGJvb2xlYW47XG4gIGRhdGE/OiBUO1xuICBlcnJvcj86IEFwaUVycm9yO1xufVxuIl19
|
package/jest.config.js
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
module.exports = {
|
|
2
|
+
preset: 'ts-jest',
|
|
3
|
+
testEnvironment: 'node',
|
|
4
|
+
roots: ['<rootDir>/tests'],
|
|
5
|
+
testMatch: ['**/*.test.ts'],
|
|
6
|
+
collectCoverageFrom: [
|
|
7
|
+
'src/**/*.ts',
|
|
8
|
+
'!src/index.ts'
|
|
9
|
+
],
|
|
10
|
+
coverageThreshold: {
|
|
11
|
+
global: {
|
|
12
|
+
branches: 80,
|
|
13
|
+
functions: 80,
|
|
14
|
+
lines: 80,
|
|
15
|
+
statements: 80
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
moduleNameMapper: {
|
|
19
|
+
'^@agenticpool/datamodel$': '<rootDir>/../datamodel/src',
|
|
20
|
+
'^@toon-format/toon$': '<rootDir>/tests/__mocks__/@toon-format/toon.ts'
|
|
21
|
+
}
|
|
22
|
+
};
|
package/package.json
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "agenticpool-sdk",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "JavaScript/TypeScript SDK for AgenticPool API",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"build": "tsc",
|
|
9
|
+
"test": "jest",
|
|
10
|
+
"test:watch": "jest --watch",
|
|
11
|
+
"test:coverage": "jest --coverage",
|
|
12
|
+
"prepublishOnly": "npm run build"
|
|
13
|
+
},
|
|
14
|
+
"keywords": [
|
|
15
|
+
"agenticpool",
|
|
16
|
+
"sdk",
|
|
17
|
+
"api",
|
|
18
|
+
"agents"
|
|
19
|
+
],
|
|
20
|
+
"author": "AgenticPool",
|
|
21
|
+
"license": "MIT",
|
|
22
|
+
"dependencies": {
|
|
23
|
+
"axios": "^1.6.5"
|
|
24
|
+
},
|
|
25
|
+
"devDependencies": {
|
|
26
|
+
"@types/jest": "^29.5.12",
|
|
27
|
+
"@types/node": "^20.11.0",
|
|
28
|
+
"jest": "^29.7.0",
|
|
29
|
+
"ts-jest": "^29.1.2",
|
|
30
|
+
"typescript": "^5.3.3"
|
|
31
|
+
},
|
|
32
|
+
"homepage": "https://agenticpool.net"
|
|
33
|
+
}
|