This is related to my first question. Somehow I think I make some improvement about my codes.
I updated all of my codes. In my bot.js is:
require('dotenv').config();
let ver = process.env.DISCORD_BOT;
client.once("ready", async ()=> {
if(ver === "production") {
client.user.setActivity(`in code land`, {type: "PLAYING"});
}else{
client.user.setActivity(`over ${client.guilds.cache.size} server(s)`, {
type:"WATCHING",
status:"IDLE"
});
}
console.log(`Logged in as ${client.user.tag}!`);
console.log(`the prefix is ` prefix);
});
Procfile:
worker: node bot.js
package.json:
"scripts": {
"start": "node .",
"test": "echo \"Error: no test specified\" && exit 1",
"production": "NODE_ENV=production&&npm start",
"development": "set NODE_ENV=development&&npm start"
}
.env:
DISCORD_BOT= TOKEN
When I checked the heroku application logs here's what it said.
2021-12-22T03:13:05.436081 00:00 app[worker.1]: agent ??= new https.Agent({ ...this.client.options.http.agent, keepAlive: true });
2021-12-22T03:13:05.436082 00:00 app[worker.1]: ^^^
2021-12-22T03:13:05.436082 00:00 app[worker.1]:
2021-12-22T03:13:05.436082 00:00 app[worker.1]: SyntaxError: Unexpected token '??='
I've searched some about Unexpected token all result is updating node.js to v16-17 but I already using Latest Version both Discord.js and Node.js.
CodePudding user response:
The error is coming from discord.js and it's because you're using an older version of Node.js. The logical nullish assignment operator (??=
) is only available in node v15 .
You might think that you're using the latest version of Node.js, but Heroku says that "if a Node version isn't specified in the engine, the 14.x release will be used". You can add an engines
prop to your package.json
file to specify the version you need. As discord.js v13 requires node.js v16.6 , you can add the following:
"engines": {
"node": "16.6"
}
Or to request the latest v16, add this:
"engines": {
"node": "16.x"
}