Adding Files 
To include additional files in your Caido plugins, you can add the assets property key to either the frontend or backend component objects in the caido.config.ts file. The key value is an array that stores the locations of any files accessible to the plugin.
In this guide we'll cover how to add a file to a plugin named myfile.txt.
Shared Steps 
In the root directory of your plugin package, create a new directory named assets. Within this directory, create the myfile.txt file, write content to it, and save it. The file can now be referenced with:
assets : ["./assets/myfile.txt"]TIPS
Glob syntax (*) is supported to reference multiple files:
- /path/*.txt: Will include all- .txtfiles in the path directory.
- /**/file.txt: Will include any- file.txtwithin any directory.
Files and directories are included differently:
- For a file, it will copy it at the root of the output assets directory.
- For a directory, it will copy it recursively in the output assets directory.
INFO
The assets key can also be added to a plugin's manifest.json file. However, multiple locations can not be defined with this method.
Adding Files to the Frontend Component 
Open the caido.config.ts file and add the property to the frontend component object:

/packages/frontend/src/index.ts 
To read the file, the sdk.assets.get() method can be called.
const file = await sdk.assets.get("myfile.txt");TIP
To view the entire frontend script, expand the following:
Full Script
import "./styles/index.css";
import type { FrontendSDK } from "./types";
// Note that the init function is async to account for fetching the files.
export const init = async (sdk: FrontendSDK) => {
  const root = document.createElement("div");
  Object.assign(root.style, {
    height: "100%",
    width: "100%",
  });
  root.id = `plugin--frontend-vanilla`;
  const parent = document.createElement("div");
  parent.classList.add("h-full", "flex", "justify-center", "items-center");
  const container = document.createElement("div");
  container.classList.add("flex", "flex-col", "gap-1", "p-4");
  const file = await sdk.assets.get("myfile.txt");
  // For large files or to process in chunks, use file.asReadableStream() instead.
  const content = await file.asString();
  container.textContent = content;
  parent.appendChild(container);
  root.appendChild(parent);
  sdk.navigation.addPage("/view-file-plugin", {
    body: root,
  });
  sdk.sidebar.registerItem("View File Plugin", "/view-file-plugin");
};Adding Files to the Backend Component 
Open the caido.config.ts file and add the property to the backend component object:

/packages/backend/src/index.ts 
By creating a custom backend function to read the file, we can later call it from the frontend:
import type { DefineAPI, SDK } from "caido:plugin";
import { readFile } from 'fs/promises';
import path from "path";
const readMyFile = async (sdk: SDK) => {
  try {
    const filePath = path.join(sdk.meta.assetsPath(), "myfile.txt");
    const contents = await readFile(filePath, { encoding: 'utf8' });
    sdk.console.log(contents);
    return contents;
  } catch (err: any) {
    sdk.console.error(err.message);
    throw err;
  }
};
export type API = DefineAPI<{
  readMyFile: typeof readMyFile;
}>;
export function init(sdk: SDK<API>) {
  sdk.api.register("readMyFile", readMyFile);
}TIP
To view the entire frontend script, expand the following:
Full Script
import "./styles/index.css";
import type { FrontendSDK } from "./types";
export const init = async (sdk: FrontendSDK) => {
  const root = document.createElement("div");
  Object.assign(root.style, {
    height: "100%",
    width: "100%",
  });
  root.id = `plugin--frontend-vanilla`;
  const parent = document.createElement("div");
  parent.classList.add("h-full", "flex", "justify-center", "items-center");
  const container = document.createElement("div");
  container.classList.add("flex", "flex-col", "gap-1", "p-4");
  try {
    // Call the backend readMyFile() function to read myfile.txt.
    const content = await sdk.backend.readMyFile();
    container.textContent = content;
  } catch (error: any) {
    container.textContent = `Error reading file: ${error.message}`;
  }
  parent.appendChild(container);
  root.appendChild(parent);
  sdk.navigation.addPage("/view-file-plugin", {
    body: root,
  });
  sdk.sidebar.registerItem("View File Plugin", "/view-file-plugin");
};The Result 

