From abeb4b47c45a1b277a8c5d4ee010fc2501527b88 Mon Sep 17 00:00:00 2001 From: Lucas Caresia Date: Thu, 2 May 2024 18:04:49 -0300 Subject: [PATCH] Added actions --- .../chat-completions/chat-completions.mjs | 48 +++++++++++++++++ components/perplexity/common/constants.mjs | 15 ++++++ components/perplexity/package.json | 7 ++- components/perplexity/perplexity.app.mjs | 53 +++++++++++++++++-- pnpm-lock.yaml | 16 +++++- 5 files changed, 131 insertions(+), 8 deletions(-) create mode 100644 components/perplexity/actions/chat-completions/chat-completions.mjs create mode 100644 components/perplexity/common/constants.mjs diff --git a/components/perplexity/actions/chat-completions/chat-completions.mjs b/components/perplexity/actions/chat-completions/chat-completions.mjs new file mode 100644 index 0000000000000..96e44c3ef154f --- /dev/null +++ b/components/perplexity/actions/chat-completions/chat-completions.mjs @@ -0,0 +1,48 @@ +import app from "../../perplexity.app.mjs"; + +export default { + key: "perplexity-chat-completions", + name: "Chat Completions", + description: "Generates a model's response for the given chat conversation. [See the documentation](https://docs.perplexity.ai/reference/post_chat_completions)", + version: "0.0.1", + type: "action", + props: { + app, + model: { + propDefinition: [ + app, + "model", + ], + }, + content: { + propDefinition: [ + app, + "content", + ], + }, + role: { + propDefinition: [ + app, + "role", + ], + }, + }, + async run({ $ }) { + const response = await this.app.chatCompletions({ + $, + data: { + model: this.model, + messages: [ + { + role: this.role, + content: this.content, + }, + ], + }, + }); + + $.export("$summary", "Successfully generated a response from the selected model"); + + return response; + }, +}; diff --git a/components/perplexity/common/constants.mjs b/components/perplexity/common/constants.mjs new file mode 100644 index 0000000000000..7c1bf16783ff4 --- /dev/null +++ b/components/perplexity/common/constants.mjs @@ -0,0 +1,15 @@ +export default { + MODELS: [ + "sonar-small-chat", + "sonar-small-online", + "sonar-medium-chat", + "sonar-medium-online", + "mistral-7b-instruct", + "mixtral-8x7b-instruct", + ], + ROLES: [ + "system", + "user", + "assistant", + ], +}; diff --git a/components/perplexity/package.json b/components/perplexity/package.json index 9e6ad06f0b0bd..4caff5d7319f1 100644 --- a/components/perplexity/package.json +++ b/components/perplexity/package.json @@ -1,6 +1,6 @@ { "name": "@pipedream/perplexity", - "version": "0.0.1", + "version": "0.1.0", "description": "Pipedream Perplexity Components", "main": "perplexity.app.mjs", "keywords": [ @@ -11,5 +11,8 @@ "author": "Pipedream (https://pipedream.com/)", "publishConfig": { "access": "public" + }, + "dependencies": { + "@pipedream/platform": "^1.6.5" } -} \ No newline at end of file +} diff --git a/components/perplexity/perplexity.app.mjs b/components/perplexity/perplexity.app.mjs index 8cb047fa417ed..b7cba4a78ee95 100644 --- a/components/perplexity/perplexity.app.mjs +++ b/components/perplexity/perplexity.app.mjs @@ -1,11 +1,54 @@ +import { axios } from "@pipedream/platform"; +import constants from "./common/constants.mjs"; + export default { type: "app", app: "perplexity", - propDefinitions: {}, + propDefinitions: { + model: { + type: "string", + label: "Model", + description: "The name of the model that will complete your prompt", + options: constants.MODELS, + }, + content: { + type: "string", + label: "Content", + description: "The contents of the message in this turn of conversation", + }, + role: { + type: "string", + label: "Role", + description: "The role of the speaker in this turn of conversation. After the (optional) system message, user and assistant roles should alternate with 'user' then 'assistant', ending in 'user'.", + options: constants.ROLES, + }, + }, methods: { - // this.$auth contains connected account data - authKeys() { - console.log(Object.keys(this.$auth)); + _baseUrl() { + return "https://api.perplexity.ai"; + }, + async _makeRequest(opts = {}) { + const { + $ = this, + path, + headers, + ...otherOpts + } = opts; + return axios($, { + ...otherOpts, + url: this._baseUrl() + path, + headers: { + ...headers, + Authorization: `Bearer ${this.$auth.api_key}`, + }, + }); + }, + async chatCompletions(args = {}) { + return this._makeRequest({ + method: "post", + path: "/chat/completions", + ...args, + }); }, }, -}; \ No newline at end of file +}; diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index a9358383d99d3..d891c6d8a6aec 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -6065,7 +6065,10 @@ importers: '@pipedream/platform': 1.6.2 components/perplexity: - specifiers: {} + specifiers: + '@pipedream/platform': ^1.6.5 + dependencies: + '@pipedream/platform': 1.6.5 components/perry_github_test: specifiers: {} @@ -14996,6 +14999,17 @@ packages: - debug dev: false + /@pipedream/platform/1.6.5: + resolution: {integrity: sha512-h7afdBjRtptMKvejOhAYbhV3b+Kmy1jq7vETMBFLLnOfeXUbtbRX0sm1cdR96lbU1xw5EA5R0uaCB9l7+AUwPA==} + dependencies: + axios: 1.6.5 + fp-ts: 2.16.1 + io-ts: 2.2.20_fp-ts@2.16.1 + querystring: 0.2.1 + transitivePeerDependencies: + - debug + dev: false + /@pipedream/types/0.0.5: resolution: {integrity: sha512-VVQB9j+94XG/EB7fzKA1t0McQcQIPhaireePeLRTlJIN4y5W59SJjERjW4h5l7zWIfTnwpLizk3qGholyiw1Vw==} dependencies: