NodeJS function throws error `Error [ERR_REQUIRE_ESM]: require() of ES Module...`
- 1
- Self Hosted
- Functions
@Meldiron @loks0n Some of my nodejs functions throw the following error on execution:
Error [ERR_REQUIRE_ESM]: require() of ES Module /usr/code-start/src/index.js from /usr/local/src/server.js not supported.
Instead change the require of index.js in /usr/local/src/server.js to a dynamic import() which is available in all CommonJS modules.
at Hook._require.Module.require (/usr/local/lib/node_modules/pm2/node_modules/require-in-the-middle/index.js:101:39)
at /usr/local/src/server.js:55:28
Example that works: appwrite.json
{
"$id": "cleanup_kas_sessions",
"name": "cleanup_kas_sessions",
"runtime": "node-18.0",
"execute": [],
"events": [],
"schedule": "",
"timeout": 15,
"enabled": true,
"logging": true,
"entrypoint": "src/main.js",
"commands": "npm install",
"ignore": [
"node_modules",
".npm"
],
"path": "functions/cleanup_kas_sessions"
}
main.js (function file)
import { Client, Databases, Query } from 'node-appwrite';
export default async ({ req, res, log, error }) => {
log('run function cleanup_kas_sessions');
// do some stuff
...
Example that doesn't work: appwrite.json
{
"$id": "authenticate_kas",
"name": "authenticate_kas",
"runtime": "node-18.0",
"path": "functions/authenticate_kas",
"entrypoint": "src/index.js",
"commands": "npm install",
"ignore": [
"node_modules",
".npm"
],
"execute": [],
"events": [],
"schedule": "",
"timeout": 15,
"enabled": true,
"logging": true
},
index.js (function file)
import { Client, Databases } from "node-appwrite";
import { v4 as uuidv4 } from "uuid";
import * as superagent from "superagent"; // even if I comment this out it doesn't work
export default async ({ req, res, log, error }) => {
log("run function authenticate_kas"); // this is never being called
// do some stuff
In both functions package.json I have the entry "type": "module",.
Tried to put appwrite container down and up. Deployed several times.
What if you change the file name and the entrypoint in the appwrite.json to src/main.js?
@Steven I just tried that. Didn't help.
I also see this in the settings menu of the function where the error occurs. I updated the code regarding this list https://appwrite.io/docs/functions-develop#upgrade I don't know what else could be "not up to date".
lol, I created a new function nodetest and copied the complete codefile and the dependencies to the new function, deployed and it works 😄
So whats going on? 🙂
Ohhhh ya. Your old function must stay in the old format...
what do you mean by format?
function main(req, res)
Can you create an issue for clarifying how to upgrade functions?
Yea of course. Here or in github?
GitHub please
ok
Recommended threads
- Immediate function execution seems to be...
Whenever I try to execute a function manually I get an error that the schedule is a required field (even though Now is selected). Not a huge deal, I can obvious...
- MCP server not able to do list documents...
I recommend the MCP server be updated. I know there are a lot of changes to the API but SOTA models have hard time doing a simple list documents with a simple q...
- Why TablesDB ListRows function does not ...
When I try to list the rows with queries, there is no column data included in the returned value with forced me to fetch the items one-by-one with ID (which was...