From a2a673475135df54287a3cd659412ba0399fbfda Mon Sep 17 00:00:00 2001 From: crazywoola Date: Fri, 12 May 2023 10:45:43 +0800 Subject: [PATCH 1/3] feat: use routes --- sdks/nodejs-client/index.js | 51 +++++++++++++++++++++++++++------ sdks/nodejs-client/package.json | 5 +++- 2 files changed, 47 insertions(+), 9 deletions(-) diff --git a/sdks/nodejs-client/index.js b/sdks/nodejs-client/index.js index 35039a6df4..d160a4343c 100644 --- a/sdks/nodejs-client/index.js +++ b/sdks/nodejs-client/index.js @@ -1,7 +1,41 @@ import axios from 'axios' +const BASE_URL = 'https://api.dify.ai/v1' + +const routes = { + application: { + method: 'GET', + url: () => `parameters` + }, + feedback: { + method: 'POST', + url: (messageId) => `/messages/${messageId}/feedbacks`, + }, + createCompletionMessage: { + method: 'POST', + url: () => `/completion-messages`, + }, + createChatMessage: { + method: 'POST', + url: () => `/chat-message`, + }, + getConversationMessages: { + method: 'GET', + url: () => '/messages', + }, + getConversations: { + method: 'GET', + url: () => '/conversations', + }, + renameConversation: { + method: 'PATCH', + url: (conversationId) => `/conversations/${conversationId}`, + } + +} + export class LangGeniusClient { - constructor(apiKey, baseUrl = 'https://api.dify.ai/v1') { + constructor(apiKey, baseUrl = BASE_URL) { this.apiKey = apiKey this.baseUrl = baseUrl } @@ -43,12 +77,12 @@ export class LangGeniusClient { rating, user, } - return this.sendRequest('POST', `/messages/${messageId}/feedbacks`, data) + return this.sendRequest(routes.feedback.method, routes.feedback.url(messageId), data) } getApplicationParameters(user) { const params = { user } - return this.sendRequest('GET', '/parameters', null, params) + return this.sendRequest(routes.application.method, routes.application.url(), null, params) } } @@ -60,7 +94,7 @@ export class CompletionClient extends LangGeniusClient { responseMode, user, } - return this.sendRequest('POST', '/completion-messages', data, null, responseMode === 'streaming') + return this.sendRequest(routes.createCompletionMessage.method, routes.createCompletionMessage.url(), data, null, responseMode === 'streaming') } } @@ -75,7 +109,7 @@ export class ChatClient extends LangGeniusClient { if (conversationId) data.conversation_id = conversationId - return this.sendRequest('POST', '/chat-messages', data, null, responseMode === 'streaming') + return this.sendRequest(routes.createChatMessage.method, routes.createChatMessage.url(), data, null, responseMode === 'streaming') } getConversationMessages(user, conversationId = '', firstId = null, limit = null) { @@ -90,17 +124,18 @@ export class ChatClient extends LangGeniusClient { if (limit) params.limit = limit - return this.sendRequest('GET', '/messages', null, params) + return this.sendRequest(routes.getConversationMessages.method, routes.getConversationMessages.url(), null, params) } getConversations(user, firstId = null, limit = null, pinned = null) { const params = { user, first_id: firstId, limit, pinned } - return this.sendRequest('GET', '/conversations', null, params) + return this.sendRequest(routes.getConversations.method, routes.getConversations.url(), null, params) } renameConversation(conversationId, name, user) { const data = { name, user } - return this.sendRequest('PATCH', `/conversations/${conversationId}`, data) + // return this.sendRequest('PATCH', `/conversations/${conversationId}`, data) + return this.sendRequest(routes.renameConversation.method, routes.renameConversation.url(conversationId), data) } } diff --git a/sdks/nodejs-client/package.json b/sdks/nodejs-client/package.json index 132516932a..ec4c3c1ee4 100644 --- a/sdks/nodejs-client/package.json +++ b/sdks/nodejs-client/package.json @@ -1,7 +1,7 @@ { "name": "langgenius-client", "version": "1.1.1", - "description": "This is the Node.js SDK for the LangGenius API, which allows you to easily integrate LangGenius into your Node.js applications.", + "description": "This is the Node.js SDK for the Dify.AI API, which allows you to easily integrate Dify.AI into your Node.js applications.", "main": "index.js", "type": "module", "keywords": [ @@ -9,6 +9,9 @@ "LLM" ], "author": "Joel", + "contributors": [ + " <<427733928@qq.com>> (https://github.com/crazywoola)" + ], "license": "MIT", "dependencies": { "axios": "^1.3.5" From d69b4059f33338a2697e5b6d1c04fe90b7f00120 Mon Sep 17 00:00:00 2001 From: crazywoola Date: Fri, 12 May 2023 10:57:13 +0800 Subject: [PATCH 2/3] feat: remove unused comments --- sdks/nodejs-client/index.js | 1 - 1 file changed, 1 deletion(-) diff --git a/sdks/nodejs-client/index.js b/sdks/nodejs-client/index.js index d160a4343c..3407620417 100644 --- a/sdks/nodejs-client/index.js +++ b/sdks/nodejs-client/index.js @@ -134,7 +134,6 @@ export class ChatClient extends LangGeniusClient { renameConversation(conversationId, name, user) { const data = { name, user } - // return this.sendRequest('PATCH', `/conversations/${conversationId}`, data) return this.sendRequest(routes.renameConversation.method, routes.renameConversation.url(conversationId), data) } } From 2a68bfbc84b53cc282f1f9552c254da1443f4b7d Mon Sep 17 00:00:00 2001 From: crazywoola Date: Fri, 12 May 2023 10:57:56 +0800 Subject: [PATCH 3/3] feat: add keywords --- sdks/nodejs-client/package.json | 1 + 1 file changed, 1 insertion(+) diff --git a/sdks/nodejs-client/package.json b/sdks/nodejs-client/package.json index ec4c3c1ee4..72e3760c6c 100644 --- a/sdks/nodejs-client/package.json +++ b/sdks/nodejs-client/package.json @@ -6,6 +6,7 @@ "type": "module", "keywords": [ "LangGenius", + "Dify.AI", "LLM" ], "author": "Joel",