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
- Local appwrite run functions --user-id n...
Hi, I'm running into an issue when testing Appwrite functions locally with user impersonation. I'm using a self-hosted Appwrite instance and running functions ...
- Selfhosted Github App installation
I've followed this guide: https://appwrite.io/docs/advanced/self-hosting/configuration/version-control to connect GitHub to my self-hosted Appwrite instance (1....
- User ID case sensitivity
I see that through REST (and SDK as well), getting a user is not case sensitive. And even though documentation does not clearly state that it is, the wording "V...