Skip to content

YepCode JavaScript Code Rules

This file provides guidelines for LLMs to write JavaScript code compatible with YepCode platform and ready to use its specific helpers.

Download this file

  • Use NodeJS v20 features
  • Wrap code in async function for await support
  • Export functions using module.exports for modules
  • Use ES6+ features when appropriate
async function main() {
// Access input parameters
const { parameters } = yepcode.context;
// Your code here
// Return result
return { message: "Success!" };
}
module.exports = { main };
  • Access execution info: const { id, comment } = yepcode.execution;
  • Access process info: const { id: processId, name: processName } = yepcode.execution.process;
  • Access schedule info: const { id: scheduleId, comment: scheduleComment } = yepcode.execution.schedule;
  • Access team timezone: const timezone = yepcode.execution.timezone;
  • Use environment variables: const apiKey = process.env.API_KEY // (or yepcode.env.API_KEY);
  • Import YepCode modules: const { myFunc } = yepcode.import("module-name");
    • Caution: you can’t use variables as module names, just hardcoded strings
  • Import YepCode modules with specific version: const { myFunc } = yepcode.import("module-name", "v1.0");
  • Run another process: await yepcode.processes.run("process-identifier", options);
console.log("INFO message");
console.debug("DEBUG message");
console.info("INFO message");
console.warn("WARNING message");
console.error("ERROR message");
  • You may use external npm packages
  • Just add the require statement to the code and the package will be installed automatically
  • If package import name is different than the package name, you must use the the add-package comment:
// @add-package axios
const axios = require("axios");
const path = require("path");
// Calculate the path to the temporary file
const filePath = path.join(process.env.TMP_DATA_DIR, "myfile.txt");
// Writing a file
const fs = require("fs");
fs.writeFileSync(filePath, "Hello from YepCode!");
// Setting a value
await yepcode.datastore.set("key", "value");
// Setting a object value
await yepcode.datastore.set("key", JSON.stringify({ name: "John", age: 30 }));
// Getting a value
const value = await yepcode.datastore.get("key");
// Deleting a value
await yepcode.datastore.del("key");
const path = require("node:path");
const localPath = path.join(process.env.TMP_DATA_DIR, "localfile.txt");
// Uploading a file
await yepcode.storage.upload("path/myfile.txt", fs.createReadStream(localPath));
// Listing files
const files = await yepcode.storage.list();
// Downloading a file
const stream = await yepcode.storage.download("path/myfile.txt");
stream.pipe(fs.createWriteStream(localPath));
// Deleting a file
await yepcode.storage.delete("path/myfile.txt");
return { message: "Success!" };
  • This is the format for custom HTTP status codes:
return {
status: 404,
body: { "message": "Not found" },
headers: { "Content-Type": "application/json" }
return {
transient: true,
data: sensitiveData,
};