From df491dda9cc449b83a1af6b44b9dfdfd9655d671 Mon Sep 17 00:00:00 2001 From: devleejb Date: Mon, 29 Jan 2024 16:27:59 +0900 Subject: [PATCH 01/10] Add LangChain --- backend/package-lock.json | 1072 ++++++++++++++++++++++++++++++++++++- backend/package.json | 3 + 2 files changed, 1067 insertions(+), 8 deletions(-) diff --git a/backend/package-lock.json b/backend/package-lock.json index 79ca26e2..ff3eebd7 100644 --- a/backend/package-lock.json +++ b/backend/package-lock.json @@ -9,6 +9,8 @@ "version": "0.0.1", "license": "UNLICENSED", "dependencies": { + "@langchain/community": "^0.0.21", + "@langchain/core": "^0.1.18", "@nestjs/common": "^10.0.0", "@nestjs/config": "^3.1.1", "@nestjs/core": "^10.0.0", @@ -19,6 +21,7 @@ "@prisma/client": "^5.8.1", "class-transformer": "^0.5.1", "class-validator": "^0.14.1", + "langchain": "^0.1.9", "moment": "^2.30.1", "passport-github": "^1.1.0", "passport-jwt": "^4.0.1", @@ -245,6 +248,30 @@ "node": ">=0.12.0" } }, + "node_modules/@anthropic-ai/sdk": { + "version": "0.9.1", + "resolved": "https://registry.npmjs.org/@anthropic-ai/sdk/-/sdk-0.9.1.tgz", + "integrity": "sha512-wa1meQ2WSfoY8Uor3EdrJq0jTiZJoKoSii2ZVWRY1oN4Tlr5s59pADg9T79FTbPe1/se5c3pBeZgJL63wmuoBA==", + "dependencies": { + "@types/node": "^18.11.18", + "@types/node-fetch": "^2.6.4", + "abort-controller": "^3.0.0", + "agentkeepalive": "^4.2.1", + "digest-fetch": "^1.3.0", + "form-data-encoder": "1.7.2", + "formdata-node": "^4.3.2", + "node-fetch": "^2.6.7", + "web-streams-polyfill": "^3.2.1" + } + }, + "node_modules/@anthropic-ai/sdk/node_modules/@types/node": { + "version": "18.19.10", + "resolved": "https://registry.npmjs.org/@types/node/-/node-18.19.10.tgz", + "integrity": "sha512-IZD8kAM02AW1HRDTPOlz3npFava678pr8Ie9Vp8uRhBROXAv8MXT2pCnGZZAKYdromsNQLHQcfWQ6EOatVLtqA==", + "dependencies": { + "undici-types": "~5.26.4" + } + }, "node_modules/@babel/code-frame": { "version": "7.23.5", "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", @@ -1663,6 +1690,408 @@ "@jridgewell/sourcemap-codec": "^1.4.14" } }, + "node_modules/@langchain/community": { + "version": "0.0.21", + "resolved": "https://registry.npmjs.org/@langchain/community/-/community-0.0.21.tgz", + "integrity": "sha512-2b3azTwY3i4hKeNpxXhZ34h9CQHvPu1kNTxAT8mSuOwkA0ZZ+DQ1niOT0Ai1K0ZrSyice5aivgvy6v7Jf0yFZw==", + "dependencies": { + "@langchain/core": "~0.1.16", + "@langchain/openai": "~0.0.10", + "flat": "^5.0.2", + "langsmith": "~0.0.48", + "uuid": "^9.0.0", + "zod": "^3.22.3" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@aws-crypto/sha256-js": "^5.0.0", + "@aws-sdk/client-bedrock-agent-runtime": "^3.485.0", + "@aws-sdk/client-bedrock-runtime": "^3.422.0", + "@aws-sdk/client-dynamodb": "^3.310.0", + "@aws-sdk/client-kendra": "^3.352.0", + "@aws-sdk/client-lambda": "^3.310.0", + "@aws-sdk/client-sagemaker-runtime": "^3.310.0", + "@aws-sdk/client-sfn": "^3.310.0", + "@aws-sdk/credential-provider-node": "^3.388.0", + "@azure/search-documents": "^12.0.0", + "@clickhouse/client": "^0.2.5", + "@cloudflare/ai": "^1.0.12", + "@datastax/astra-db-ts": "^0.1.4", + "@elastic/elasticsearch": "^8.4.0", + "@getmetal/metal-sdk": "*", + "@getzep/zep-js": "^0.9.0", + "@gomomento/sdk": "^1.51.1", + "@gomomento/sdk-core": "^1.51.1", + "@google-ai/generativelanguage": "^0.2.1", + "@gradientai/nodejs-sdk": "^1.2.0", + "@huggingface/inference": "^2.6.4", + "@mozilla/readability": "*", + "@opensearch-project/opensearch": "*", + "@pinecone-database/pinecone": "^1.1.0", + "@planetscale/database": "^1.8.0", + "@qdrant/js-client-rest": "^1.2.0", + "@raycast/api": "^1.55.2", + "@rockset/client": "^0.9.1", + "@smithy/eventstream-codec": "^2.0.5", + "@smithy/protocol-http": "^3.0.6", + "@smithy/signature-v4": "^2.0.10", + "@smithy/util-utf8": "^2.0.0", + "@supabase/postgrest-js": "^1.1.1", + "@supabase/supabase-js": "^2.10.0", + "@tensorflow-models/universal-sentence-encoder": "*", + "@tensorflow/tfjs-converter": "*", + "@tensorflow/tfjs-core": "*", + "@upstash/redis": "^1.20.6", + "@vercel/kv": "^0.2.3", + "@vercel/postgres": "^0.5.0", + "@writerai/writer-sdk": "^0.40.2", + "@xata.io/client": "^0.28.0", + "@xenova/transformers": "^2.5.4", + "@zilliz/milvus2-sdk-node": ">=2.2.7", + "cassandra-driver": "^4.7.2", + "chromadb": "*", + "closevector-common": "0.1.0-alpha.1", + "closevector-node": "0.1.0-alpha.10", + "closevector-web": "0.1.0-alpha.16", + "cohere-ai": ">=6.0.0", + "convex": "^1.3.1", + "discord.js": "^14.14.1", + "faiss-node": "^0.5.1", + "firebase-admin": "^11.9.0", + "google-auth-library": "^8.9.0", + "googleapis": "^126.0.1", + "hnswlib-node": "^1.4.2", + "html-to-text": "^9.0.5", + "ioredis": "^5.3.2", + "jsdom": "*", + "llmonitor": "^0.5.9", + "lodash": "^4.17.21", + "lunary": "^0.6.11", + "mongodb": "^5.2.0", + "mysql2": "^3.3.3", + "neo4j-driver": "*", + "node-llama-cpp": "*", + "pg": "^8.11.0", + "pg-copy-streams": "^6.0.5", + "pickleparser": "^0.2.1", + "portkey-ai": "^0.1.11", + "redis": "^4.6.4", + "replicate": "^0.18.0", + "typeorm": "^0.3.12", + "typesense": "^1.5.3", + "usearch": "^1.1.1", + "vectordb": "^0.1.4", + "voy-search": "0.6.2", + "weaviate-ts-client": "^1.4.0", + "web-auth-library": "^1.0.3", + "ws": "^8.14.2" + }, + "peerDependenciesMeta": { + "@aws-crypto/sha256-js": { + "optional": true + }, + "@aws-sdk/client-bedrock-agent-runtime": { + "optional": true + }, + "@aws-sdk/client-bedrock-runtime": { + "optional": true + }, + "@aws-sdk/client-dynamodb": { + "optional": true + }, + "@aws-sdk/client-kendra": { + "optional": true + }, + "@aws-sdk/client-lambda": { + "optional": true + }, + "@aws-sdk/client-sagemaker-runtime": { + "optional": true + }, + "@aws-sdk/client-sfn": { + "optional": true + }, + "@aws-sdk/credential-provider-node": { + "optional": true + }, + "@azure/search-documents": { + "optional": true + }, + "@clickhouse/client": { + "optional": true + }, + "@cloudflare/ai": { + "optional": true + }, + "@datastax/astra-db-ts": { + "optional": true + }, + "@elastic/elasticsearch": { + "optional": true + }, + "@getmetal/metal-sdk": { + "optional": true + }, + "@getzep/zep-js": { + "optional": true + }, + "@gomomento/sdk": { + "optional": true + }, + "@gomomento/sdk-core": { + "optional": true + }, + "@google-ai/generativelanguage": { + "optional": true + }, + "@gradientai/nodejs-sdk": { + "optional": true + }, + "@huggingface/inference": { + "optional": true + }, + "@mozilla/readability": { + "optional": true + }, + "@opensearch-project/opensearch": { + "optional": true + }, + "@pinecone-database/pinecone": { + "optional": true + }, + "@planetscale/database": { + "optional": true + }, + "@qdrant/js-client-rest": { + "optional": true + }, + "@raycast/api": { + "optional": true + }, + "@rockset/client": { + "optional": true + }, + "@smithy/eventstream-codec": { + "optional": true + }, + "@smithy/protocol-http": { + "optional": true + }, + "@smithy/signature-v4": { + "optional": true + }, + "@smithy/util-utf8": { + "optional": true + }, + "@supabase/postgrest-js": { + "optional": true + }, + "@supabase/supabase-js": { + "optional": true + }, + "@tensorflow-models/universal-sentence-encoder": { + "optional": true + }, + "@tensorflow/tfjs-converter": { + "optional": true + }, + "@tensorflow/tfjs-core": { + "optional": true + }, + "@upstash/redis": { + "optional": true + }, + "@vercel/kv": { + "optional": true + }, + "@vercel/postgres": { + "optional": true + }, + "@writerai/writer-sdk": { + "optional": true + }, + "@xata.io/client": { + "optional": true + }, + "@xenova/transformers": { + "optional": true + }, + "@zilliz/milvus2-sdk-node": { + "optional": true + }, + "cassandra-driver": { + "optional": true + }, + "chromadb": { + "optional": true + }, + "closevector-common": { + "optional": true + }, + "closevector-node": { + "optional": true + }, + "closevector-web": { + "optional": true + }, + "cohere-ai": { + "optional": true + }, + "convex": { + "optional": true + }, + "discord.js": { + "optional": true + }, + "faiss-node": { + "optional": true + }, + "firebase-admin": { + "optional": true + }, + "google-auth-library": { + "optional": true + }, + "googleapis": { + "optional": true + }, + "hnswlib-node": { + "optional": true + }, + "html-to-text": { + "optional": true + }, + "ioredis": { + "optional": true + }, + "jsdom": { + "optional": true + }, + "llmonitor": { + "optional": true + }, + "lodash": { + "optional": true + }, + "lunary": { + "optional": true + }, + "mongodb": { + "optional": true + }, + "mysql2": { + "optional": true + }, + "neo4j-driver": { + "optional": true + }, + "node-llama-cpp": { + "optional": true + }, + "pg": { + "optional": true + }, + "pg-copy-streams": { + "optional": true + }, + "pickleparser": { + "optional": true + }, + "portkey-ai": { + "optional": true + }, + "redis": { + "optional": true + }, + "replicate": { + "optional": true + }, + "typeorm": { + "optional": true + }, + "typesense": { + "optional": true + }, + "usearch": { + "optional": true + }, + "vectordb": { + "optional": true + }, + "voy-search": { + "optional": true + }, + "weaviate-ts-client": { + "optional": true + }, + "web-auth-library": { + "optional": true + }, + "ws": { + "optional": true + } + } + }, + "node_modules/@langchain/core": { + "version": "0.1.18", + "resolved": "https://registry.npmjs.org/@langchain/core/-/core-0.1.18.tgz", + "integrity": "sha512-fDjocs899HDq3nf3PE0TveQoVabO0vyedt9i74Yef4Ds2o22TEDSh3MfoMxM8stcHiV3/9i+0wH4Xdm0E2YLdg==", + "dependencies": { + "ansi-styles": "^5.0.0", + "camelcase": "6", + "decamelize": "1.2.0", + "js-tiktoken": "^1.0.8", + "langsmith": "~0.0.48", + "ml-distance": "^4.0.0", + "p-queue": "^6.6.2", + "p-retry": "4", + "uuid": "^9.0.0", + "zod": "^3.22.4", + "zod-to-json-schema": "^3.22.3" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@langchain/core/node_modules/ansi-styles": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", + "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/@langchain/core/node_modules/camelcase": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", + "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@langchain/openai": { + "version": "0.0.13", + "resolved": "https://registry.npmjs.org/@langchain/openai/-/openai-0.0.13.tgz", + "integrity": "sha512-kgPwFiUA5Abmt8Q/cDhC4o1o5QAYuq962CqneVieMIgTUOJhYqB8Na4/7JI0EIfEZuUP2uuTrtqsulbLpGNQ8w==", + "dependencies": { + "@langchain/core": "~0.1.13", + "js-tiktoken": "^1.0.7", + "openai": "^4.26.0", + "zod": "^3.22.4", + "zod-to-json-schema": "^3.22.3" + }, + "engines": { + "node": ">=18" + } + }, "node_modules/@ljharb/through": { "version": "2.3.11", "resolved": "https://registry.npmjs.org/@ljharb/through/-/through-2.3.11.tgz", @@ -2328,6 +2757,15 @@ "undici-types": "~5.26.4" } }, + "node_modules/@types/node-fetch": { + "version": "2.6.11", + "resolved": "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.6.11.tgz", + "integrity": "sha512-24xFj9R5+rfQJLRyM56qh+wnVSYhyXC2tkoBndtY0U+vubqNsYXGjufB2nn8Q6gt0LrARwL6UBtMCSVCwl4B1g==", + "dependencies": { + "@types/node": "*", + "form-data": "^4.0.0" + } + }, "node_modules/@types/qs": { "version": "6.9.11", "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.11.tgz", @@ -2340,6 +2778,11 @@ "integrity": "sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ==", "dev": true }, + "node_modules/@types/retry": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/@types/retry/-/retry-0.12.0.tgz", + "integrity": "sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA==" + }, "node_modules/@types/semver": { "version": "7.5.6", "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.6.tgz", @@ -2394,6 +2837,11 @@ "@types/superagent": "^8.1.0" } }, + "node_modules/@types/uuid": { + "version": "9.0.8", + "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-9.0.8.tgz", + "integrity": "sha512-jg+97EGIcY9AGHJJRaaPVgetKDsrTgbRjQ5Msgjh/DQKEFl0DtyRr/VCOyD1T2R1MNeWPK/u7JoGhlDZnKBAfA==" + }, "node_modules/@types/validator": { "version": "13.11.8", "resolved": "https://registry.npmjs.org/@types/validator/-/validator-13.11.8.tgz", @@ -2768,6 +3216,17 @@ "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==", "dev": true }, + "node_modules/abort-controller": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", + "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", + "dependencies": { + "event-target-shim": "^5.0.0" + }, + "engines": { + "node": ">=6.5" + } + }, "node_modules/accepts": { "version": "1.3.8", "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", @@ -2819,6 +3278,17 @@ "node": ">=0.4.0" } }, + "node_modules/agentkeepalive": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/agentkeepalive/-/agentkeepalive-4.5.0.tgz", + "integrity": "sha512-5GG/5IbQQpC9FpkRGsSvZI5QYeSCzlJHdpBQntCsuTOxhKD8lqKhrleg2Yi7yvMIf82Ycmmqln9U8V9qwEiJew==", + "dependencies": { + "humanize-ms": "^1.2.1" + }, + "engines": { + "node": ">= 8.0.0" + } + }, "node_modules/ajv": { "version": "8.12.0", "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz", @@ -2981,8 +3451,7 @@ "node_modules/asynckit": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", - "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", - "dev": true + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "node_modules/babel-jest": { "version": "29.7.0", @@ -3106,11 +3575,15 @@ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", "dev": true }, + "node_modules/base-64": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/base-64/-/base-64-0.1.0.tgz", + "integrity": "sha512-Y5gU45svrR5tI2Vt/X9GPd3L0HNIKzGu202EjxrXMpuc2V2CiKgemAbUUsqYmZJvPtCXoUKjNZwBJzsNScUbXA==" + }, "node_modules/base64-js": { "version": "1.5.1", "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", - "dev": true, "funding": [ { "type": "github", @@ -3138,11 +3611,15 @@ "version": "2.2.0", "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", - "dev": true, "engines": { "node": ">=8" } }, + "node_modules/binary-search": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/binary-search/-/binary-search-1.3.6.tgz", + "integrity": "sha512-nbE1WxOTTrUWIfsfZ4aHGYu5DOuNkbxGokjV6Z2kxfJK3uaAb8zNK1muzOeipoLHZjInT4Br88BHpzevc681xA==" + }, "node_modules/bl": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", @@ -3412,6 +3889,14 @@ "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", "dev": true }, + "node_modules/charenc": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/charenc/-/charenc-0.0.2.tgz", + "integrity": "sha512-yrLQ/yVUFXkzg7EDQsPieE/53+0RlaWTs+wBrvW36cyilJ2SaDWfl4Yj7MtLTXleV9uEKefbAGUPv2/iWSooRA==", + "engines": { + "node": "*" + } + }, "node_modules/chokidar": { "version": "3.5.3", "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", @@ -3608,7 +4093,6 @@ "version": "1.0.8", "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", - "dev": true, "dependencies": { "delayed-stream": "~1.0.0" }, @@ -3803,6 +4287,14 @@ "node": ">= 8" } }, + "node_modules/crypt": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/crypt/-/crypt-0.0.2.tgz", + "integrity": "sha512-mCxBlsHFYh9C+HVpiEacem8FEBnMXgU9gy4zmNC+SXAZNB/1idgp/aulFJ4FgCi7GPEVbfyng092GqL2k2rmow==", + "engines": { + "node": "*" + } + }, "node_modules/debug": { "version": "4.3.4", "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", @@ -3820,6 +4312,14 @@ } } }, + "node_modules/decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==", + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/dedent": { "version": "1.5.1", "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.5.1.tgz", @@ -3878,7 +4378,6 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", - "dev": true, "engines": { "node": ">=0.4.0" } @@ -3937,6 +4436,15 @@ "node": "^14.15.0 || ^16.10.0 || >=18.0.0" } }, + "node_modules/digest-fetch": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/digest-fetch/-/digest-fetch-1.3.0.tgz", + "integrity": "sha512-CGJuv6iKNM7QyZlM2T3sPAdZWd/p9zQiRNS9G+9COUCwzWFTs0Xp8NF5iePx7wtvhDykReiRRrSeNb4oMmB8lA==", + "dependencies": { + "base-64": "^0.1.0", + "md5": "^2.3.0" + } + }, "node_modules/dir-glob": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", @@ -4346,6 +4854,19 @@ "node": ">= 0.6" } }, + "node_modules/event-target-shim": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", + "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==", + "engines": { + "node": ">=6" + } + }, + "node_modules/eventemitter3": { + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", + "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==" + }, "node_modules/events": { "version": "3.3.0", "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", @@ -4409,6 +4930,11 @@ "node": "^14.15.0 || ^16.10.0 || >=18.0.0" } }, + "node_modules/expr-eval": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/expr-eval/-/expr-eval-2.0.2.tgz", + "integrity": "sha512-4EMSHGOPSwAfBiibw3ndnP0AvjDWLsMvGOvWEZ2F96IGk0bIVdjQisOHxReSkE13mHcfbuCiXw+G4y0zv6N8Eg==" + }, "node_modules/express": { "version": "4.18.2", "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", @@ -4676,6 +5202,14 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/flat": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", + "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", + "bin": { + "flat": "cli.js" + } + }, "node_modules/flat-cache": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", @@ -4823,7 +5357,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", - "dev": true, "dependencies": { "asynckit": "^0.4.0", "combined-stream": "^1.0.8", @@ -4833,6 +5366,31 @@ "node": ">= 6" } }, + "node_modules/form-data-encoder": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/form-data-encoder/-/form-data-encoder-1.7.2.tgz", + "integrity": "sha512-qfqtYan3rxrnCk1VYaA4H+Ms9xdpPqvLZa6xmMgFvhO32x7/3J/ExcTd6qpxM0vH2GdMI+poehyBZvqfMTto8A==" + }, + "node_modules/formdata-node": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/formdata-node/-/formdata-node-4.4.1.tgz", + "integrity": "sha512-0iirZp3uVDjVGt9p49aTaqjk84TrglENEDuqfdlZQ1roC9CWlPk6Avf8EEnZNcAqPonwkG35x4n3ww/1THYAeQ==", + "dependencies": { + "node-domexception": "1.0.0", + "web-streams-polyfill": "4.0.0-beta.3" + }, + "engines": { + "node": ">= 12.20" + } + }, + "node_modules/formdata-node/node_modules/web-streams-polyfill": { + "version": "4.0.0-beta.3", + "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-4.0.0-beta.3.tgz", + "integrity": "sha512-QW95TCTaHmsYfHDybGMwO5IJIM93I/6vTRk+daHTWFPhwh+C8Cg7j7XyKrwrj8Ib6vYXe0ocYNrmzY4xAAN6ug==", + "engines": { + "node": ">= 14" + } + }, "node_modules/formidable": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/formidable/-/formidable-2.1.2.tgz", @@ -5163,6 +5721,14 @@ "node": ">=10.17.0" } }, + "node_modules/humanize-ms": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/humanize-ms/-/humanize-ms-1.2.1.tgz", + "integrity": "sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ==", + "dependencies": { + "ms": "^2.0.0" + } + }, "node_modules/iconv-lite": { "version": "0.4.24", "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", @@ -5198,7 +5764,7 @@ "version": "5.3.0", "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.0.tgz", "integrity": "sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg==", - "dev": true, + "devOptional": true, "engines": { "node": ">= 4" } @@ -5305,6 +5871,11 @@ "node": ">= 0.10" } }, + "node_modules/is-any-array": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-any-array/-/is-any-array-2.0.1.tgz", + "integrity": "sha512-UtilS7hLRu++wb/WBAw9bNuP1Eg04Ivn1vERJck8zJthEvXCBEBpGR/33u/xLKWEQf95803oalHrVDptcAvFdQ==" + }, "node_modules/is-arrayish": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", @@ -5323,6 +5894,11 @@ "node": ">=8" } }, + "node_modules/is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" + }, "node_modules/is-core-module": { "version": "2.13.1", "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", @@ -6207,6 +6783,14 @@ "url": "https://github.com/chalk/supports-color?sponsor=1" } }, + "node_modules/js-tiktoken": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/js-tiktoken/-/js-tiktoken-1.0.10.tgz", + "integrity": "sha512-ZoSxbGjvGyMT13x6ACo9ebhDha/0FHdKA+OsQcMOWcm1Zs7r90Rhk5lhERLzji+3rA7EKpXCgwXcM5fF3DMpdA==", + "dependencies": { + "base64-js": "^1.5.1" + } + }, "node_modules/js-tokens": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", @@ -6290,6 +6874,14 @@ "graceful-fs": "^4.1.6" } }, + "node_modules/jsonpointer": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/jsonpointer/-/jsonpointer-5.0.1.tgz", + "integrity": "sha512-p/nXbhSEcu3pZRdkW1OfJhpsVtW1gd4Wa1fnQc9YLiTfAjn0312eMKimbdIQzuZl9aa9xUGaRlP9T/CJE/ditQ==", + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/jsonwebtoken": { "version": "9.0.2", "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz", @@ -6348,6 +6940,273 @@ "node": ">=6" } }, + "node_modules/langchain": { + "version": "0.1.9", + "resolved": "https://registry.npmjs.org/langchain/-/langchain-0.1.9.tgz", + "integrity": "sha512-4Gm2j8gsT43d4sgpjM7JMSoB83dwxbiLYdcPx23Xi6RfLQ60QB86bogPYqn84ZW9HjrW8IVMXvVyC6DAHNCyIg==", + "dependencies": { + "@anthropic-ai/sdk": "^0.9.1", + "@langchain/community": "~0.0.20", + "@langchain/core": "~0.1.16", + "@langchain/openai": "~0.0.12", + "binary-extensions": "^2.2.0", + "expr-eval": "^2.0.2", + "js-tiktoken": "^1.0.7", + "js-yaml": "^4.1.0", + "jsonpointer": "^5.0.1", + "langchainhub": "~0.0.6", + "langsmith": "~0.0.59", + "ml-distance": "^4.0.0", + "openapi-types": "^12.1.3", + "p-retry": "4", + "uuid": "^9.0.0", + "yaml": "^2.2.1", + "zod": "^3.22.4", + "zod-to-json-schema": "^3.22.3" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@aws-sdk/client-s3": "^3.310.0", + "@aws-sdk/client-sagemaker-runtime": "^3.310.0", + "@aws-sdk/client-sfn": "^3.310.0", + "@aws-sdk/credential-provider-node": "^3.388.0", + "@azure/storage-blob": "^12.15.0", + "@gomomento/sdk": "^1.51.1", + "@gomomento/sdk-core": "^1.51.1", + "@gomomento/sdk-web": "^1.51.1", + "@google-ai/generativelanguage": "^0.2.1", + "@google-cloud/storage": "^6.10.1", + "@notionhq/client": "^2.2.10", + "@pinecone-database/pinecone": "*", + "@supabase/supabase-js": "^2.10.0", + "@vercel/kv": "^0.2.3", + "@xata.io/client": "^0.28.0", + "apify-client": "^2.7.1", + "assemblyai": "^4.0.0", + "axios": "*", + "cheerio": "^1.0.0-rc.12", + "chromadb": "*", + "convex": "^1.3.1", + "d3-dsv": "^2.0.0", + "epub2": "^3.0.1", + "fast-xml-parser": "^4.2.7", + "google-auth-library": "^8.9.0", + "googleapis": "^126.0.1", + "handlebars": "^4.7.8", + "html-to-text": "^9.0.5", + "ignore": "^5.2.0", + "ioredis": "^5.3.2", + "jsdom": "*", + "mammoth": "^1.6.0", + "mongodb": "^5.2.0", + "node-llama-cpp": "*", + "notion-to-md": "^3.1.0", + "officeparser": "^4.0.4", + "pdf-parse": "1.1.1", + "peggy": "^3.0.2", + "playwright": "^1.32.1", + "puppeteer": "^19.7.2", + "pyodide": "^0.24.1", + "redis": "^4.6.4", + "sonix-speech-recognition": "^2.1.1", + "srt-parser-2": "^1.2.3", + "typeorm": "^0.3.12", + "vectordb": "^0.1.4", + "weaviate-ts-client": "^1.4.0", + "web-auth-library": "^1.0.3", + "ws": "^8.14.2", + "youtube-transcript": "^1.0.6", + "youtubei.js": "^5.8.0" + }, + "peerDependenciesMeta": { + "@aws-sdk/client-s3": { + "optional": true + }, + "@aws-sdk/client-sagemaker-runtime": { + "optional": true + }, + "@aws-sdk/client-sfn": { + "optional": true + }, + "@aws-sdk/credential-provider-node": { + "optional": true + }, + "@azure/storage-blob": { + "optional": true + }, + "@gomomento/sdk": { + "optional": true + }, + "@gomomento/sdk-core": { + "optional": true + }, + "@gomomento/sdk-web": { + "optional": true + }, + "@google-ai/generativelanguage": { + "optional": true + }, + "@google-cloud/storage": { + "optional": true + }, + "@notionhq/client": { + "optional": true + }, + "@pinecone-database/pinecone": { + "optional": true + }, + "@supabase/supabase-js": { + "optional": true + }, + "@vercel/kv": { + "optional": true + }, + "@xata.io/client": { + "optional": true + }, + "apify-client": { + "optional": true + }, + "assemblyai": { + "optional": true + }, + "axios": { + "optional": true + }, + "cheerio": { + "optional": true + }, + "chromadb": { + "optional": true + }, + "convex": { + "optional": true + }, + "d3-dsv": { + "optional": true + }, + "epub2": { + "optional": true + }, + "faiss-node": { + "optional": true + }, + "fast-xml-parser": { + "optional": true + }, + "google-auth-library": { + "optional": true + }, + "googleapis": { + "optional": true + }, + "handlebars": { + "optional": true + }, + "html-to-text": { + "optional": true + }, + "ignore": { + "optional": true + }, + "ioredis": { + "optional": true + }, + "jsdom": { + "optional": true + }, + "mammoth": { + "optional": true + }, + "mongodb": { + "optional": true + }, + "node-llama-cpp": { + "optional": true + }, + "notion-to-md": { + "optional": true + }, + "officeparser": { + "optional": true + }, + "pdf-parse": { + "optional": true + }, + "peggy": { + "optional": true + }, + "playwright": { + "optional": true + }, + "puppeteer": { + "optional": true + }, + "pyodide": { + "optional": true + }, + "redis": { + "optional": true + }, + "sonix-speech-recognition": { + "optional": true + }, + "srt-parser-2": { + "optional": true + }, + "typeorm": { + "optional": true + }, + "vectordb": { + "optional": true + }, + "weaviate-ts-client": { + "optional": true + }, + "web-auth-library": { + "optional": true + }, + "ws": { + "optional": true + }, + "youtube-transcript": { + "optional": true + }, + "youtubei.js": { + "optional": true + } + } + }, + "node_modules/langchainhub": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/langchainhub/-/langchainhub-0.0.6.tgz", + "integrity": "sha512-SW6105T+YP1cTe0yMf//7kyshCgvCTyFBMTgH2H3s9rTAR4e+78DA/BBrUL/Mt4Q5eMWui7iGuAYb3pgGsdQ9w==" + }, + "node_modules/langsmith": { + "version": "0.0.63", + "resolved": "https://registry.npmjs.org/langsmith/-/langsmith-0.0.63.tgz", + "integrity": "sha512-8KtbiltWP8Ta7xErfXRvLudKgIoc/yRb9oSU8Ozh2215rlz9tnYicl37lS/ZdyeSbpSX8Rh8XhLTN5zVQ+5euA==", + "dependencies": { + "@types/uuid": "^9.0.1", + "commander": "^10.0.1", + "p-queue": "^6.6.2", + "p-retry": "4", + "uuid": "^9.0.0" + }, + "bin": { + "langsmith": "dist/cli/main.cjs" + } + }, + "node_modules/langsmith/node_modules/commander": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-10.0.1.tgz", + "integrity": "sha512-y4Mg2tXshplEbSGzx7amzPwKKOCGuoSRP/CjEdwwk0FOGlUbq6lKuoyDZTNZkmxHdJtp54hdfY/JUrdL7Xfdug==", + "engines": { + "node": ">=14" + } + }, "node_modules/leven": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", @@ -6524,6 +7383,16 @@ "tmpl": "1.0.5" } }, + "node_modules/md5": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/md5/-/md5-2.3.0.tgz", + "integrity": "sha512-T1GITYmFaKuO91vxyoQMFETst+O71VUPEU3ze5GNzDm0OWdP8v1ziTaAEPUr/3kLsY3Sftgz242A1SetQiDL7g==", + "dependencies": { + "charenc": "0.0.2", + "crypt": "0.0.2", + "is-buffer": "~1.1.6" + } + }, "node_modules/media-typer": { "version": "0.3.0", "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", @@ -6679,6 +7548,46 @@ "mkdirp": "bin/cmd.js" } }, + "node_modules/ml-array-mean": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/ml-array-mean/-/ml-array-mean-1.1.6.tgz", + "integrity": "sha512-MIdf7Zc8HznwIisyiJGRH9tRigg3Yf4FldW8DxKxpCCv/g5CafTw0RRu51nojVEOXuCQC7DRVVu5c7XXO/5joQ==", + "dependencies": { + "ml-array-sum": "^1.1.6" + } + }, + "node_modules/ml-array-sum": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/ml-array-sum/-/ml-array-sum-1.1.6.tgz", + "integrity": "sha512-29mAh2GwH7ZmiRnup4UyibQZB9+ZLyMShvt4cH4eTK+cL2oEMIZFnSyB3SS8MlsTh6q/w/yh48KmqLxmovN4Dw==", + "dependencies": { + "is-any-array": "^2.0.0" + } + }, + "node_modules/ml-distance": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/ml-distance/-/ml-distance-4.0.1.tgz", + "integrity": "sha512-feZ5ziXs01zhyFUUUeZV5hwc0f5JW0Sh0ckU1koZe/wdVkJdGxcP06KNQuF0WBTj8FttQUzcvQcpcrOp/XrlEw==", + "dependencies": { + "ml-array-mean": "^1.1.6", + "ml-distance-euclidean": "^2.0.0", + "ml-tree-similarity": "^1.0.0" + } + }, + "node_modules/ml-distance-euclidean": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ml-distance-euclidean/-/ml-distance-euclidean-2.0.0.tgz", + "integrity": "sha512-yC9/2o8QF0A3m/0IXqCTXCzz2pNEzvmcE/9HFKOZGnTjatvBbsn4lWYJkxENkA4Ug2fnYl7PXQxnPi21sgMy/Q==" + }, + "node_modules/ml-tree-similarity": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/ml-tree-similarity/-/ml-tree-similarity-1.0.0.tgz", + "integrity": "sha512-XJUyYqjSuUQkNQHMscr6tcjldsOoAekxADTplt40QKfwW6nd++1wHWV9AArl0Zvw/TIHgNaZZNvr8QGvE8wLRg==", + "dependencies": { + "binary-search": "^1.3.5", + "num-sort": "^2.0.0" + } + }, "node_modules/moment": { "version": "2.30.1", "resolved": "https://registry.npmjs.org/moment/-/moment-2.30.1.tgz", @@ -6741,6 +7650,24 @@ "integrity": "sha512-AGK2yQKIjRuqnc6VkX2Xj5d+QW8xZ87pa1UK6yA6ouUyuxfHuMP6umE5QK7UmTeOAymo+Zx1Fxiuw9rVx8taHQ==", "dev": true }, + "node_modules/node-domexception": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/node-domexception/-/node-domexception-1.0.0.tgz", + "integrity": "sha512-/jKZoMpw0F8GRwl4/eLROPA3cfcXtLApP0QzLmUT/HuPCZWyB7IY9ZrMeKw2O/nFIqPQB3PVM9aYm0F312AXDQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/jimmywarting" + }, + { + "type": "github", + "url": "https://paypal.me/jimmywarting" + } + ], + "engines": { + "node": ">=10.5.0" + } + }, "node_modules/node-emoji": { "version": "1.11.0", "resolved": "https://registry.npmjs.org/node-emoji/-/node-emoji-1.11.0.tgz", @@ -6802,6 +7729,17 @@ "node": ">=8" } }, + "node_modules/num-sort": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/num-sort/-/num-sort-2.1.0.tgz", + "integrity": "sha512-1MQz1Ed8z2yckoBeSfkQHHO9K1yDRxxtotKSJ9yvcTUUxSvfvzEq5GwBrjjHEpMlq/k5gvXdmJ1SbYxWtpNoVg==", + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/oauth": { "version": "0.9.15", "resolved": "https://registry.npmjs.org/oauth/-/oauth-0.9.15.tgz", @@ -6858,6 +7796,38 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/openai": { + "version": "4.26.0", + "resolved": "https://registry.npmjs.org/openai/-/openai-4.26.0.tgz", + "integrity": "sha512-HPC7tgYdeP38F3uHA5WgnoXZyGbAp9jgcIo23p6It+q/07u4C+NZ8xHKlMShsPbDDmFRpPsa3vdbXYpbhJH3eg==", + "dependencies": { + "@types/node": "^18.11.18", + "@types/node-fetch": "^2.6.4", + "abort-controller": "^3.0.0", + "agentkeepalive": "^4.2.1", + "digest-fetch": "^1.3.0", + "form-data-encoder": "1.7.2", + "formdata-node": "^4.3.2", + "node-fetch": "^2.6.7", + "web-streams-polyfill": "^3.2.1" + }, + "bin": { + "openai": "bin/cli" + } + }, + "node_modules/openai/node_modules/@types/node": { + "version": "18.19.10", + "resolved": "https://registry.npmjs.org/@types/node/-/node-18.19.10.tgz", + "integrity": "sha512-IZD8kAM02AW1HRDTPOlz3npFava678pr8Ie9Vp8uRhBROXAv8MXT2pCnGZZAKYdromsNQLHQcfWQ6EOatVLtqA==", + "dependencies": { + "undici-types": "~5.26.4" + } + }, + "node_modules/openapi-types": { + "version": "12.1.3", + "resolved": "https://registry.npmjs.org/openapi-types/-/openapi-types-12.1.3.tgz", + "integrity": "sha512-N4YtSYJqghVu4iek2ZUvcN/0aqH1kRDuNqzcycDxhOUpg7GdvLa2F3DgS6yBNhInhv2r/6I0Flkn7CqL8+nIcw==" + }, "node_modules/optionator": { "version": "0.9.3", "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", @@ -6907,6 +7877,14 @@ "node": ">=0.10.0" } }, + "node_modules/p-finally": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", + "integrity": "sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==", + "engines": { + "node": ">=4" + } + }, "node_modules/p-limit": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", @@ -6937,6 +7915,44 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/p-queue": { + "version": "6.6.2", + "resolved": "https://registry.npmjs.org/p-queue/-/p-queue-6.6.2.tgz", + "integrity": "sha512-RwFpb72c/BhQLEXIZ5K2e+AhgNVmIejGlTgiB9MzZ0e93GRvqZ7uSi0dvRF7/XIXDeNkra2fNHBxTyPDGySpjQ==", + "dependencies": { + "eventemitter3": "^4.0.4", + "p-timeout": "^3.2.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-retry": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-4.6.2.tgz", + "integrity": "sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ==", + "dependencies": { + "@types/retry": "0.12.0", + "retry": "^0.13.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/p-timeout": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/p-timeout/-/p-timeout-3.2.0.tgz", + "integrity": "sha512-rhIwUycgwwKcP9yTOOFK/AKsAopjjCakVqLHePO3CC6Mir1Z99xT+R63jZxAT5lFZLa2inS5h+ZS2GvR99/FBg==", + "dependencies": { + "p-finally": "^1.0.0" + }, + "engines": { + "node": ">=8" + } + }, "node_modules/p-try": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", @@ -7593,6 +8609,14 @@ "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", "dev": true }, + "node_modules/retry": { + "version": "0.13.1", + "resolved": "https://registry.npmjs.org/retry/-/retry-0.13.1.tgz", + "integrity": "sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==", + "engines": { + "node": ">= 4" + } + }, "node_modules/reusify": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", @@ -8911,6 +9935,14 @@ "defaults": "^1.0.3" } }, + "node_modules/web-streams-polyfill": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-3.3.2.tgz", + "integrity": "sha512-3pRGuxRF5gpuZc0W+EpwQRmCD7gRqcDOMt688KmdlDAgAyaB1XlN0zq2njfDNm44XVdIouE7pZ6GzbdyH47uIQ==", + "engines": { + "node": ">= 8" + } + }, "node_modules/webidl-conversions": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", @@ -9107,6 +10139,14 @@ "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", "dev": true }, + "node_modules/yaml": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.4.tgz", + "integrity": "sha512-8aAvwVUSHpfEqTQ4w/KMlf3HcRdt50E5ODIQJBw1fQ5RL34xabzxtUlzTXVqc4rkZsPbvrXKWnABCD7kWSmocA==", + "engines": { + "node": ">= 14" + } + }, "node_modules/yargs": { "version": "17.7.2", "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", @@ -9154,6 +10194,22 @@ "funding": { "url": "https://github.com/sponsors/sindresorhus" } + }, + "node_modules/zod": { + "version": "3.22.4", + "resolved": "https://registry.npmjs.org/zod/-/zod-3.22.4.tgz", + "integrity": "sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==", + "funding": { + "url": "https://github.com/sponsors/colinhacks" + } + }, + "node_modules/zod-to-json-schema": { + "version": "3.22.4", + "resolved": "https://registry.npmjs.org/zod-to-json-schema/-/zod-to-json-schema-3.22.4.tgz", + "integrity": "sha512-2Ed5dJ+n/O3cU383xSY28cuVi0BCQhF8nYqWU5paEpl7fVdqdAmiLdqLyfblbNdfOFwFfi/mqU4O1pwc60iBhQ==", + "peerDependencies": { + "zod": "^3.22.4" + } } } } diff --git a/backend/package.json b/backend/package.json index 956b58e8..28d01b59 100644 --- a/backend/package.json +++ b/backend/package.json @@ -21,6 +21,8 @@ "test:e2e": "jest --config ./test/jest-e2e.json" }, "dependencies": { + "@langchain/community": "^0.0.21", + "@langchain/core": "^0.1.18", "@nestjs/common": "^10.0.0", "@nestjs/config": "^3.1.1", "@nestjs/core": "^10.0.0", @@ -31,6 +33,7 @@ "@prisma/client": "^5.8.1", "class-transformer": "^0.5.1", "class-validator": "^0.14.1", + "langchain": "^0.1.9", "moment": "^2.30.1", "passport-github": "^1.1.0", "passport-jwt": "^4.0.1", From c1bd9dc23a64611f154177c42aba4d3c5854132a Mon Sep 17 00:00:00 2001 From: devleejb Date: Mon, 29 Jan 2024 16:29:53 +0900 Subject: [PATCH 02/10] Add `intelligence` module --- backend/src/app.module.ts | 2 ++ .../intelligence.controller.spec.ts | 18 ++++++++++++++++++ .../intelligence/intelligence.controller.ts | 4 ++++ .../src/intelligence/intelligence.module.ts | 9 +++++++++ .../intelligence/intelligence.service.spec.ts | 18 ++++++++++++++++++ .../src/intelligence/intelligence.service.ts | 4 ++++ 6 files changed, 55 insertions(+) create mode 100644 backend/src/intelligence/intelligence.controller.spec.ts create mode 100644 backend/src/intelligence/intelligence.controller.ts create mode 100644 backend/src/intelligence/intelligence.module.ts create mode 100644 backend/src/intelligence/intelligence.service.spec.ts create mode 100644 backend/src/intelligence/intelligence.service.ts diff --git a/backend/src/app.module.ts b/backend/src/app.module.ts index 2410d666..d44b65d0 100644 --- a/backend/src/app.module.ts +++ b/backend/src/app.module.ts @@ -10,6 +10,7 @@ import { WorkspaceUsersModule } from "./workspace-users/workspace-users.module"; import { WorkspaceDocumentsModule } from "./workspace-documents/workspace-documents.module"; import { DocumentsModule } from "./documents/documents.module"; import { CheckModule } from "./check/check.module"; +import { IntelligenceModule } from './intelligence/intelligence.module'; @Module({ imports: [ @@ -21,6 +22,7 @@ import { CheckModule } from "./check/check.module"; WorkspaceDocumentsModule, DocumentsModule, CheckModule, + IntelligenceModule, ], controllers: [], providers: [ diff --git a/backend/src/intelligence/intelligence.controller.spec.ts b/backend/src/intelligence/intelligence.controller.spec.ts new file mode 100644 index 00000000..bb601c15 --- /dev/null +++ b/backend/src/intelligence/intelligence.controller.spec.ts @@ -0,0 +1,18 @@ +import { Test, TestingModule } from '@nestjs/testing'; +import { IntelligenceController } from './intelligence.controller'; + +describe('IntelligenceController', () => { + let controller: IntelligenceController; + + beforeEach(async () => { + const module: TestingModule = await Test.createTestingModule({ + controllers: [IntelligenceController], + }).compile(); + + controller = module.get(IntelligenceController); + }); + + it('should be defined', () => { + expect(controller).toBeDefined(); + }); +}); diff --git a/backend/src/intelligence/intelligence.controller.ts b/backend/src/intelligence/intelligence.controller.ts new file mode 100644 index 00000000..38d67860 --- /dev/null +++ b/backend/src/intelligence/intelligence.controller.ts @@ -0,0 +1,4 @@ +import { Controller } from '@nestjs/common'; + +@Controller('intelligence') +export class IntelligenceController {} diff --git a/backend/src/intelligence/intelligence.module.ts b/backend/src/intelligence/intelligence.module.ts new file mode 100644 index 00000000..5e190975 --- /dev/null +++ b/backend/src/intelligence/intelligence.module.ts @@ -0,0 +1,9 @@ +import { Module } from '@nestjs/common'; +import { IntelligenceController } from './intelligence.controller'; +import { IntelligenceService } from './intelligence.service'; + +@Module({ + controllers: [IntelligenceController], + providers: [IntelligenceService] +}) +export class IntelligenceModule {} diff --git a/backend/src/intelligence/intelligence.service.spec.ts b/backend/src/intelligence/intelligence.service.spec.ts new file mode 100644 index 00000000..174adccb --- /dev/null +++ b/backend/src/intelligence/intelligence.service.spec.ts @@ -0,0 +1,18 @@ +import { Test, TestingModule } from '@nestjs/testing'; +import { IntelligenceService } from './intelligence.service'; + +describe('IntelligenceService', () => { + let service: IntelligenceService; + + beforeEach(async () => { + const module: TestingModule = await Test.createTestingModule({ + providers: [IntelligenceService], + }).compile(); + + service = module.get(IntelligenceService); + }); + + it('should be defined', () => { + expect(service).toBeDefined(); + }); +}); diff --git a/backend/src/intelligence/intelligence.service.ts b/backend/src/intelligence/intelligence.service.ts new file mode 100644 index 00000000..21976194 --- /dev/null +++ b/backend/src/intelligence/intelligence.service.ts @@ -0,0 +1,4 @@ +import { Injectable } from '@nestjs/common'; + +@Injectable() +export class IntelligenceService {} From 6c45bac0bad4359040f5a3722cb361f896f05aca Mon Sep 17 00:00:00 2001 From: devleejb Date: Mon, 29 Jan 2024 16:38:45 +0900 Subject: [PATCH 03/10] Fix format --- backend/src/app.module.ts | 2 +- .../intelligence.controller.spec.ts | 26 +++++++++---------- .../intelligence/intelligence.controller.ts | 4 +-- .../src/intelligence/intelligence.module.ts | 10 +++---- .../intelligence/intelligence.service.spec.ts | 26 +++++++++---------- .../src/intelligence/intelligence.service.ts | 2 +- 6 files changed, 35 insertions(+), 35 deletions(-) diff --git a/backend/src/app.module.ts b/backend/src/app.module.ts index d44b65d0..ef841679 100644 --- a/backend/src/app.module.ts +++ b/backend/src/app.module.ts @@ -10,7 +10,7 @@ import { WorkspaceUsersModule } from "./workspace-users/workspace-users.module"; import { WorkspaceDocumentsModule } from "./workspace-documents/workspace-documents.module"; import { DocumentsModule } from "./documents/documents.module"; import { CheckModule } from "./check/check.module"; -import { IntelligenceModule } from './intelligence/intelligence.module'; +import { IntelligenceModule } from "./intelligence/intelligence.module"; @Module({ imports: [ diff --git a/backend/src/intelligence/intelligence.controller.spec.ts b/backend/src/intelligence/intelligence.controller.spec.ts index bb601c15..47f0d914 100644 --- a/backend/src/intelligence/intelligence.controller.spec.ts +++ b/backend/src/intelligence/intelligence.controller.spec.ts @@ -1,18 +1,18 @@ -import { Test, TestingModule } from '@nestjs/testing'; -import { IntelligenceController } from './intelligence.controller'; +import { Test, TestingModule } from "@nestjs/testing"; +import { IntelligenceController } from "./intelligence.controller"; -describe('IntelligenceController', () => { - let controller: IntelligenceController; +describe("IntelligenceController", () => { + let controller: IntelligenceController; - beforeEach(async () => { - const module: TestingModule = await Test.createTestingModule({ - controllers: [IntelligenceController], - }).compile(); + beforeEach(async () => { + const module: TestingModule = await Test.createTestingModule({ + controllers: [IntelligenceController], + }).compile(); - controller = module.get(IntelligenceController); - }); + controller = module.get(IntelligenceController); + }); - it('should be defined', () => { - expect(controller).toBeDefined(); - }); + it("should be defined", () => { + expect(controller).toBeDefined(); + }); }); diff --git a/backend/src/intelligence/intelligence.controller.ts b/backend/src/intelligence/intelligence.controller.ts index 38d67860..0c645652 100644 --- a/backend/src/intelligence/intelligence.controller.ts +++ b/backend/src/intelligence/intelligence.controller.ts @@ -1,4 +1,4 @@ -import { Controller } from '@nestjs/common'; +import { Controller } from "@nestjs/common"; -@Controller('intelligence') +@Controller("intelligence") export class IntelligenceController {} diff --git a/backend/src/intelligence/intelligence.module.ts b/backend/src/intelligence/intelligence.module.ts index 5e190975..211e926f 100644 --- a/backend/src/intelligence/intelligence.module.ts +++ b/backend/src/intelligence/intelligence.module.ts @@ -1,9 +1,9 @@ -import { Module } from '@nestjs/common'; -import { IntelligenceController } from './intelligence.controller'; -import { IntelligenceService } from './intelligence.service'; +import { Module } from "@nestjs/common"; +import { IntelligenceController } from "./intelligence.controller"; +import { IntelligenceService } from "./intelligence.service"; @Module({ - controllers: [IntelligenceController], - providers: [IntelligenceService] + controllers: [IntelligenceController], + providers: [IntelligenceService], }) export class IntelligenceModule {} diff --git a/backend/src/intelligence/intelligence.service.spec.ts b/backend/src/intelligence/intelligence.service.spec.ts index 174adccb..8e2335d4 100644 --- a/backend/src/intelligence/intelligence.service.spec.ts +++ b/backend/src/intelligence/intelligence.service.spec.ts @@ -1,18 +1,18 @@ -import { Test, TestingModule } from '@nestjs/testing'; -import { IntelligenceService } from './intelligence.service'; +import { Test, TestingModule } from "@nestjs/testing"; +import { IntelligenceService } from "./intelligence.service"; -describe('IntelligenceService', () => { - let service: IntelligenceService; +describe("IntelligenceService", () => { + let service: IntelligenceService; - beforeEach(async () => { - const module: TestingModule = await Test.createTestingModule({ - providers: [IntelligenceService], - }).compile(); + beforeEach(async () => { + const module: TestingModule = await Test.createTestingModule({ + providers: [IntelligenceService], + }).compile(); - service = module.get(IntelligenceService); - }); + service = module.get(IntelligenceService); + }); - it('should be defined', () => { - expect(service).toBeDefined(); - }); + it("should be defined", () => { + expect(service).toBeDefined(); + }); }); diff --git a/backend/src/intelligence/intelligence.service.ts b/backend/src/intelligence/intelligence.service.ts index 21976194..4716ecd3 100644 --- a/backend/src/intelligence/intelligence.service.ts +++ b/backend/src/intelligence/intelligence.service.ts @@ -1,4 +1,4 @@ -import { Injectable } from '@nestjs/common'; +import { Injectable } from "@nestjs/common"; @Injectable() export class IntelligenceService {} From 1ca376e047b52eb94874723d609f9bdc02d72dea Mon Sep 17 00:00:00 2001 From: devleejb Date: Mon, 29 Jan 2024 17:15:44 +0900 Subject: [PATCH 04/10] Add LangChain Module --- backend/src/app.module.ts | 2 ++ backend/src/intelligence/intelligence.module.ts | 2 ++ backend/src/intelligence/intelligence.service.ts | 7 +++++-- backend/src/langchain/langchain.module.ts | 14 ++++++++++++++ 4 files changed, 23 insertions(+), 2 deletions(-) create mode 100644 backend/src/langchain/langchain.module.ts diff --git a/backend/src/app.module.ts b/backend/src/app.module.ts index ef841679..a904f62a 100644 --- a/backend/src/app.module.ts +++ b/backend/src/app.module.ts @@ -11,6 +11,7 @@ import { WorkspaceDocumentsModule } from "./workspace-documents/workspace-docume import { DocumentsModule } from "./documents/documents.module"; import { CheckModule } from "./check/check.module"; import { IntelligenceModule } from "./intelligence/intelligence.module"; +import { LangchainModule } from "./langchain/langchain.module"; @Module({ imports: [ @@ -23,6 +24,7 @@ import { IntelligenceModule } from "./intelligence/intelligence.module"; DocumentsModule, CheckModule, IntelligenceModule, + LangchainModule, ], controllers: [], providers: [ diff --git a/backend/src/intelligence/intelligence.module.ts b/backend/src/intelligence/intelligence.module.ts index 211e926f..471ff922 100644 --- a/backend/src/intelligence/intelligence.module.ts +++ b/backend/src/intelligence/intelligence.module.ts @@ -1,8 +1,10 @@ import { Module } from "@nestjs/common"; import { IntelligenceController } from "./intelligence.controller"; import { IntelligenceService } from "./intelligence.service"; +import { LangchainModule } from "src/langchain/langchain.module"; @Module({ + imports: [LangchainModule], controllers: [IntelligenceController], providers: [IntelligenceService], }) diff --git a/backend/src/intelligence/intelligence.service.ts b/backend/src/intelligence/intelligence.service.ts index 4716ecd3..c9142d88 100644 --- a/backend/src/intelligence/intelligence.service.ts +++ b/backend/src/intelligence/intelligence.service.ts @@ -1,4 +1,7 @@ -import { Injectable } from "@nestjs/common"; +import { Inject, Injectable } from "@nestjs/common"; +import { BaseChatModel } from "@langchain/core/language_models/chat_models"; @Injectable() -export class IntelligenceService {} +export class IntelligenceService { + constructor(@Inject("BaseChatModel") private chatModel: BaseChatModel) {} +} diff --git a/backend/src/langchain/langchain.module.ts b/backend/src/langchain/langchain.module.ts new file mode 100644 index 00000000..a88441c1 --- /dev/null +++ b/backend/src/langchain/langchain.module.ts @@ -0,0 +1,14 @@ +import { Module } from "@nestjs/common"; +import { ChatOpenAI } from "@langchain/openai"; +import { BaseChatModel } from "@langchain/core/language_models/chat_models"; + +const chatModelFactory = { + provide: "BaseChatModel", + useFactory: () => new ChatOpenAI({}) as BaseChatModel, +}; + +@Module({ + providers: [chatModelFactory], + exports: [chatModelFactory], +}) +export class LangchainModule {} From 8ff4150ee54c5479d60be5c9dff17cdfe115c129 Mon Sep 17 00:00:00 2001 From: devleejb Date: Mon, 29 Jan 2024 17:21:33 +0900 Subject: [PATCH 05/10] Update .env --- backend/.env | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/backend/.env b/backend/.env index 405055c4..396a9adc 100644 --- a/backend/.env +++ b/backend/.env @@ -1,6 +1,14 @@ -DATABASE_URL="DATABASE_URL" -GITHUB_CLIENT_ID="GITHUB_CLIENT_ID" -GITHUB_CLIENT_SECRET="GITHUB_CLIENT_SECRET" -GITHUB_CALLBACK_URL="/auth/login/github" -JWT_AUTH_SECRET="JWT_AUTH_SECRET" -FRONTEND_BASE_URL="FRONTEND_BASE_URL" \ No newline at end of file +DATABASE_URL="" +GITHUB_CLIENT_ID="" +GITHUB_CLIENT_SECRET="" +GITHUB_CALLBACK_URL="" +JWT_AUTH_SECRET="" +FRONTEND_BASE_URL="" +YORKIE_API_ADDR="" +YORKIE_PROJECT_NAME="" +YORKIE_PROJECT_SECRET_KEY="" +OPENAI_API_KEY="" +LANGCHAIN_TRACING_V2="true" +LANGCHAIN_ENDPOINT="https://api.smith.langchain.com" +LANGCHAIN_API_KEY="" +LANGCHAIN_PROJECT="" From c94d8ee50c0ce9ded576b1bfed0d84ce31e5f3e9 Mon Sep 17 00:00:00 2001 From: devleejb Date: Mon, 29 Jan 2024 17:32:43 +0900 Subject: [PATCH 06/10] Add intelligence feature controller --- .../intelligence/intelligence.controller.ts | 25 +++++++++++++++++-- .../src/intelligence/intelligence.service.ts | 2 +- backend/src/langchain/langchain.module.ts | 2 +- 3 files changed, 25 insertions(+), 4 deletions(-) diff --git a/backend/src/intelligence/intelligence.controller.ts b/backend/src/intelligence/intelligence.controller.ts index 0c645652..b3e77b18 100644 --- a/backend/src/intelligence/intelligence.controller.ts +++ b/backend/src/intelligence/intelligence.controller.ts @@ -1,4 +1,25 @@ -import { Controller } from "@nestjs/common"; +import { Controller, Get, Req } from "@nestjs/common"; +import { ApiBearerAuth, ApiOkResponse, ApiOperation, ApiParam, ApiTags } from "@nestjs/swagger"; +import { IntelligenceService } from "./intelligence.service"; +import { AuthroizedRequest } from "src/utils/types/req.type"; +@ApiTags("Intelligences") +@ApiBearerAuth() @Controller("intelligence") -export class IntelligenceController {} +export class IntelligenceController { + constructor(private intelligenceService: IntelligenceService) {} + + @Get(":feature") + @ApiOperation({ + summary: "Run the Yorkie Intelligence Feature", + description: "Run the selected yorkie intelligence", + }) + @ApiParam({ + name: "feature", + description: "Feature of intelligence to run", + }) + @ApiOkResponse({ type: String }) + async runFeature(@Req() req: AuthroizedRequest): Promise { + return "Test"; + } +} diff --git a/backend/src/intelligence/intelligence.service.ts b/backend/src/intelligence/intelligence.service.ts index c9142d88..4919e902 100644 --- a/backend/src/intelligence/intelligence.service.ts +++ b/backend/src/intelligence/intelligence.service.ts @@ -3,5 +3,5 @@ import { BaseChatModel } from "@langchain/core/language_models/chat_models"; @Injectable() export class IntelligenceService { - constructor(@Inject("BaseChatModel") private chatModel: BaseChatModel) {} + constructor(@Inject("ChatModel") private chatModel: BaseChatModel) {} } diff --git a/backend/src/langchain/langchain.module.ts b/backend/src/langchain/langchain.module.ts index a88441c1..a0e18936 100644 --- a/backend/src/langchain/langchain.module.ts +++ b/backend/src/langchain/langchain.module.ts @@ -3,7 +3,7 @@ import { ChatOpenAI } from "@langchain/openai"; import { BaseChatModel } from "@langchain/core/language_models/chat_models"; const chatModelFactory = { - provide: "BaseChatModel", + provide: "ChatModel", useFactory: () => new ChatOpenAI({}) as BaseChatModel, }; From 4521d3eb389fdc1cc678fac8fad9689a6201d4c0 Mon Sep 17 00:00:00 2001 From: devleejb Date: Mon, 29 Jan 2024 17:39:38 +0900 Subject: [PATCH 07/10] Add controller for run feature API --- backend/src/intelligence/dto/run-feature.dto.ts | 6 ++++++ backend/src/intelligence/intelligence.controller.ts | 12 ++++++++++-- backend/src/intelligence/intelligence.service.ts | 5 +++++ backend/src/intelligence/types/feature.type.ts | 4 ++++ 4 files changed, 25 insertions(+), 2 deletions(-) create mode 100644 backend/src/intelligence/dto/run-feature.dto.ts create mode 100644 backend/src/intelligence/types/feature.type.ts diff --git a/backend/src/intelligence/dto/run-feature.dto.ts b/backend/src/intelligence/dto/run-feature.dto.ts new file mode 100644 index 00000000..d8bd7828 --- /dev/null +++ b/backend/src/intelligence/dto/run-feature.dto.ts @@ -0,0 +1,6 @@ +import { ApiProperty } from "@nestjs/swagger"; + +export class RunFeatureDto { + @ApiProperty({ type: String, description: "Content to run feature" }) + content: string; +} diff --git a/backend/src/intelligence/intelligence.controller.ts b/backend/src/intelligence/intelligence.controller.ts index b3e77b18..a6049729 100644 --- a/backend/src/intelligence/intelligence.controller.ts +++ b/backend/src/intelligence/intelligence.controller.ts @@ -1,7 +1,9 @@ -import { Controller, Get, Req } from "@nestjs/common"; +import { Body, Controller, Get, Param, Req } from "@nestjs/common"; import { ApiBearerAuth, ApiOkResponse, ApiOperation, ApiParam, ApiTags } from "@nestjs/swagger"; import { IntelligenceService } from "./intelligence.service"; import { AuthroizedRequest } from "src/utils/types/req.type"; +import { Feature } from "./types/feature.type"; +import { RunFeatureDto } from "./dto/run-feature.dto"; @ApiTags("Intelligences") @ApiBearerAuth() @@ -17,9 +19,15 @@ export class IntelligenceController { @ApiParam({ name: "feature", description: "Feature of intelligence to run", + enum: Feature, }) @ApiOkResponse({ type: String }) - async runFeature(@Req() req: AuthroizedRequest): Promise { + async runFeature( + @Req() req: AuthroizedRequest, + @Param("feature") feature: Feature, + @Body() runFeatureDto: RunFeatureDto + ): Promise { + await this.intelligenceService.runFeature(feature, runFeatureDto.content); return "Test"; } } diff --git a/backend/src/intelligence/intelligence.service.ts b/backend/src/intelligence/intelligence.service.ts index 4919e902..f27dbbd6 100644 --- a/backend/src/intelligence/intelligence.service.ts +++ b/backend/src/intelligence/intelligence.service.ts @@ -1,7 +1,12 @@ import { Inject, Injectable } from "@nestjs/common"; import { BaseChatModel } from "@langchain/core/language_models/chat_models"; +import { Feature } from "./types/feature.type"; @Injectable() export class IntelligenceService { constructor(@Inject("ChatModel") private chatModel: BaseChatModel) {} + + async runFeature(feature: Feature, content: string) { + console.log(feature, content); + } } diff --git a/backend/src/intelligence/types/feature.type.ts b/backend/src/intelligence/types/feature.type.ts new file mode 100644 index 00000000..f04a7678 --- /dev/null +++ b/backend/src/intelligence/types/feature.type.ts @@ -0,0 +1,4 @@ +export enum Feature { + GITHUB_ISSUE = "github-issue", + GITHUB_PR = "github-pr", +} From d8568dea6e0414c32ec55515bc36b230e8af6cbb Mon Sep 17 00:00:00 2001 From: devleejb Date: Mon, 29 Jan 2024 18:47:47 +0900 Subject: [PATCH 08/10] Add github issue intelligence --- .../intelligence/intelligence.controller.ts | 19 +++-- .../src/intelligence/intelligence.service.ts | 23 +++++- .../src/intelligence/prompt/github-issue.ts | 82 +++++++++++++++++++ 3 files changed, 117 insertions(+), 7 deletions(-) create mode 100644 backend/src/intelligence/prompt/github-issue.ts diff --git a/backend/src/intelligence/intelligence.controller.ts b/backend/src/intelligence/intelligence.controller.ts index a6049729..2fa4d98c 100644 --- a/backend/src/intelligence/intelligence.controller.ts +++ b/backend/src/intelligence/intelligence.controller.ts @@ -1,9 +1,11 @@ -import { Body, Controller, Get, Param, Req } from "@nestjs/common"; +import { Body, Controller, Get, Param, Post, Req, Res } from "@nestjs/common"; import { ApiBearerAuth, ApiOkResponse, ApiOperation, ApiParam, ApiTags } from "@nestjs/swagger"; import { IntelligenceService } from "./intelligence.service"; import { AuthroizedRequest } from "src/utils/types/req.type"; import { Feature } from "./types/feature.type"; import { RunFeatureDto } from "./dto/run-feature.dto"; +import { Public } from "src/utils/decorators/auth.decorator"; +import { Response } from "express"; @ApiTags("Intelligences") @ApiBearerAuth() @@ -11,7 +13,8 @@ import { RunFeatureDto } from "./dto/run-feature.dto"; export class IntelligenceController { constructor(private intelligenceService: IntelligenceService) {} - @Get(":feature") + @Public() + @Post(":feature") @ApiOperation({ summary: "Run the Yorkie Intelligence Feature", description: "Run the selected yorkie intelligence", @@ -24,10 +27,16 @@ export class IntelligenceController { @ApiOkResponse({ type: String }) async runFeature( @Req() req: AuthroizedRequest, + @Res() res: Response, @Param("feature") feature: Feature, @Body() runFeatureDto: RunFeatureDto - ): Promise { - await this.intelligenceService.runFeature(feature, runFeatureDto.content); - return "Test"; + ): Promise { + const stream = await this.intelligenceService.runFeature(feature, runFeatureDto.content); + + for await (const chunk of stream) { + res.write(chunk); + } + + res.end(); } } diff --git a/backend/src/intelligence/intelligence.service.ts b/backend/src/intelligence/intelligence.service.ts index f27dbbd6..6264433e 100644 --- a/backend/src/intelligence/intelligence.service.ts +++ b/backend/src/intelligence/intelligence.service.ts @@ -1,12 +1,31 @@ -import { Inject, Injectable } from "@nestjs/common"; +import { Inject, Injectable, NotFoundException } from "@nestjs/common"; import { BaseChatModel } from "@langchain/core/language_models/chat_models"; import { Feature } from "./types/feature.type"; +import { githubIssuePromptTemplate } from "./prompt/github-issue"; +import { StringOutputParser } from "@langchain/core/output_parsers"; @Injectable() export class IntelligenceService { constructor(@Inject("ChatModel") private chatModel: BaseChatModel) {} + private selectPromptTemplate(feature: Feature) { + const promptTemplates = { + [Feature.GITHUB_ISSUE]: githubIssuePromptTemplate, + }; + const selectedPrompt = promptTemplates[feature]; + + if (!selectedPrompt) throw new NotFoundException(); + + return selectedPrompt; + } + async runFeature(feature: Feature, content: string) { - console.log(feature, content); + const promptTemplate = this.selectPromptTemplate(feature); + const prompt = await promptTemplate.format({ + content, + }); + const parser = new StringOutputParser(); + + return this.chatModel.pipe(parser).stream(prompt); } } diff --git a/backend/src/intelligence/prompt/github-issue.ts b/backend/src/intelligence/prompt/github-issue.ts new file mode 100644 index 00000000..76f59827 --- /dev/null +++ b/backend/src/intelligence/prompt/github-issue.ts @@ -0,0 +1,82 @@ +import { ChatPromptTemplate, FewShotChatMessagePromptTemplate } from "langchain/prompts"; + +const examplePrompt = ChatPromptTemplate.fromTemplate( + "## Title\n{title}\n## Issue Type\n{issueType}\n## Content\n{content}" +); + +const examples = [ + { + title: "Error with `qemu` when launching `yorkie` project using `yorkieteam/yorkie` image on Apple M1", + issueType: "bug 🐞", + content: ` + +**What happened**: +When launch \`yorkie\` project using \`yorkieteam/yorkie\` image. got error about \`qemu\` like below. + +\`\`\`sh +yorkie | qemu: uncaught target signal 11 (Segmentation fault) - core dumped +\`\`\` + +this is known issue on \`QEMU\` and I can not find how to resolve. but I attached related urls. + +**What you expected to happen**: +\`yorkie\` work properly. + +**How to reproduce it (as minimally and precisely as possible)**: +referenced [this issue](https://gitlab.com/qemu-project/qemu/-/issues/340) which gitlab, \`QEMU\`'s original repository. +**Rechardson Dx** said try to edit \`dockerfile\` and \`docker-compose\`. I do not tested. + +**Anything else we need to know?**: +I attached related urls below + + - [QEMU issue](https://gitlab.com/qemu-project/qemu/-/issues/340) + - [stackoverflow answer about qemu](https://stackoverflow.com/questions/68862313/qemu-uncaught-target-signal-11-segmentation-fault-core-dumped-in-docker-con) + +**Environment**: +- Operating system: OSX Big Sur 11.5.2 apple m1 +- Browser and version: chrome, safari +- Yorkie version (use \`yorkie version\`): 0.1.6 +- Yorkie JS SDK version: 0.1.6 + `, + }, + { + title: "Introduce broadcast API for event sharing", + issueType: "enhancement 🌟", + content: ` +**What would you like to be added**: +Yorkie presently relies on the Publish-Subscribe model for sharing document and presence events (refer to: [pub-sub.md](https://github.com/yorkie-team/yorkie/blob/main/design/pub-sub.md)). +However, this lacks the capability to extend its scope to encompass additional event types, notably notifications for end users concerning new document updates or comments. +To address this limitation, the introduction of a "broadcast" feature is recommended. +This feature would enable users to define and share a wider range of general events beyond the existing document and presence events. +It's also related to #442, which extracts \`Room\` from \`Document\` and moves \`Presence\` from \`Client\` to \`Room\`. +**Why is this needed**: +Provide a more comprehensive event-sharing mechanism that satisfies various use cases.`, + }, + { + title: "Enhance Tree.Edit to manage Merge and Split scenarios", + issueType: "common issue 🐾", + content: ` + +**Description**: + +Move \`Client.Watch\` inside \`Client.Attach\` and hide it from the external interface. + +Go SDK is just used in integration tests of servers without other SDK installations. So it was OK to expose \`Client.Watch\` to the external interface. But by adding more and more features to the SDK, it is quite difficult to keep simple tests. + +Let's move Client.Watch inside Client.Attach and hide it from the external interface to maintain consistency with other SDKs and simplify testing. + +**Why**: + +Keep the product simple`, + }, +]; + +export const githubIssuePromptTemplate = new FewShotChatMessagePromptTemplate({ + prefix: `I want you to act as a GitHub Issue writer. I will provide brief information about the GitHub issue I want to create, and you should write the GitHub issue based on the examples I provide. + The types of issues you can write are bug 🐞 or enhancement 🌟. Please ensure that you follow the template used in each type of issue example provided. Please write your responses in English.`, + suffix: "Brief information about the GitHub issue: {content}", + examplePrompt, + examples, + inputVariables: ["content"], +}); From d474192079c97d26bafb2580450fd0d7dbac6c9e Mon Sep 17 00:00:00 2001 From: devleejb Date: Mon, 29 Jan 2024 18:55:28 +0900 Subject: [PATCH 09/10] Add langsmith tags for `runFeature` --- backend/src/intelligence/intelligence.controller.ts | 8 +++++--- backend/src/intelligence/intelligence.service.ts | 6 ++++-- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/backend/src/intelligence/intelligence.controller.ts b/backend/src/intelligence/intelligence.controller.ts index 2fa4d98c..cc3dd218 100644 --- a/backend/src/intelligence/intelligence.controller.ts +++ b/backend/src/intelligence/intelligence.controller.ts @@ -4,7 +4,6 @@ import { IntelligenceService } from "./intelligence.service"; import { AuthroizedRequest } from "src/utils/types/req.type"; import { Feature } from "./types/feature.type"; import { RunFeatureDto } from "./dto/run-feature.dto"; -import { Public } from "src/utils/decorators/auth.decorator"; import { Response } from "express"; @ApiTags("Intelligences") @@ -13,7 +12,6 @@ import { Response } from "express"; export class IntelligenceController { constructor(private intelligenceService: IntelligenceService) {} - @Public() @Post(":feature") @ApiOperation({ summary: "Run the Yorkie Intelligence Feature", @@ -31,7 +29,11 @@ export class IntelligenceController { @Param("feature") feature: Feature, @Body() runFeatureDto: RunFeatureDto ): Promise { - const stream = await this.intelligenceService.runFeature(feature, runFeatureDto.content); + const stream = await this.intelligenceService.runFeature( + req.user.id, + feature, + runFeatureDto.content + ); for await (const chunk of stream) { res.write(chunk); diff --git a/backend/src/intelligence/intelligence.service.ts b/backend/src/intelligence/intelligence.service.ts index 6264433e..8a564b94 100644 --- a/backend/src/intelligence/intelligence.service.ts +++ b/backend/src/intelligence/intelligence.service.ts @@ -19,13 +19,15 @@ export class IntelligenceService { return selectedPrompt; } - async runFeature(feature: Feature, content: string) { + async runFeature(userId: string, feature: Feature, content: string) { const promptTemplate = this.selectPromptTemplate(feature); const prompt = await promptTemplate.format({ content, }); const parser = new StringOutputParser(); - return this.chatModel.pipe(parser).stream(prompt); + return this.chatModel.pipe(parser).stream(prompt, { + tags: [feature, userId], + }); } } From 37da40786c1f7f4d0c12c028322d7d3e122ee17b Mon Sep 17 00:00:00 2001 From: devleejb Date: Tue, 30 Jan 2024 13:29:01 +0900 Subject: [PATCH 10/10] Fix lint --- backend/src/intelligence/intelligence.controller.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/backend/src/intelligence/intelligence.controller.ts b/backend/src/intelligence/intelligence.controller.ts index cc3dd218..bbbcd2f1 100644 --- a/backend/src/intelligence/intelligence.controller.ts +++ b/backend/src/intelligence/intelligence.controller.ts @@ -1,4 +1,4 @@ -import { Body, Controller, Get, Param, Post, Req, Res } from "@nestjs/common"; +import { Body, Controller, Param, Post, Req, Res } from "@nestjs/common"; import { ApiBearerAuth, ApiOkResponse, ApiOperation, ApiParam, ApiTags } from "@nestjs/swagger"; import { IntelligenceService } from "./intelligence.service"; import { AuthroizedRequest } from "src/utils/types/req.type";