Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
AgenticJS is a JavaScript-native framework for building multi-agent AI systems.
Powered by Claude
AgenticJS utilizes Claude, the cutting-edge LLM from Anthropic, across all examples. This integration allows AgenticJS to offer advanced AI agent functionalities and decision-making capabilities, making every interaction smarter. Discover how we use Claude to bring innovative AI solutions to life in our interactive playground.
In a landscape dominated by Python frameworks, JavaScript developers have often found themselves at a disadvantage. AgenticJS is here to change that by providing a robust, easy-to-use AI multi-agent framework tailored for the JavaScript ecosystem.
Install AgenticJS via npm:
npm install agenticjs --save
Set your LLM API keys as environment variables:
# For Anthropic
export ANTHROPIC_API_KEY='your-api-key'
# For OpenAI
export OPENAI_API_KEY='your-openai-api-key'
Import AgenticJS in your JavaScript file:
import { Agent, Task, Team } from 'agenticjs';
Define agents, tasks, and a team to manage them:
import { Agent, Task, Team } from 'agenticjs';
// ╔══════════════════════════════════════════════════════╗
// ║ How to Use AgenticJS: ║
// ║ 1. Define your Agents with specific roles and goals ║
// ║ 2. Define the Tasks each Agent will perform ║
// ║ 3. Create the Team and assign Agents and their Tasks ║
// ║ 4. Start the Team to execute the defined tasks ║
// ╚══════════════════════════════════════════════════════╝
// ──── Agents ────────────────────────────────────────────
// ─ Agents are autonomous entities designed to perform
// ─ specific roles and achieve goals based on the
// ─ tasks assigned to them.
// ────────────────────────────────────────────────────────
const profileAnalyst = new Agent({
name: 'Ivy',
role: 'Profile Analyst',
goal: 'Extract structured information from conversational user input.',
background: 'Data Processor',
tools: [], // Tools are omitted for now
llmConfig: {
provider: "anthropic", // or "openai"
model: "claude-3-5-sonnet-20240620",
temperature: 0.9,
maxTokens: 1024,
anthropicApiUrl: "https://www.agenticjs.com/proxy/anthropic",
}
});
const formatter = new Agent({
name: 'Formy',
role: 'Formatter',
goal: 'Format structured information into a professional resume.',
background: 'Document Formatter',
tools: [],
llmConfig: {
provider: "anthropic", // or "openai"
model: "claude-3-5-sonnet-20240620",
temperature: 0.9,
maxTokens: 1024,
anthropicApiUrl: "https://www.agenticjs.com/proxy/anthropic",
}
});
const reviewer = new Agent({
name: 'Revy',
role: 'Reviewer',
goal: 'Review and polish the final resume.',
background: 'Quality Assurance Specialist',
tools: [],
llmConfig: {
provider: "anthropic", // or "openai"
model: "claude-3-5-sonnet-20240620",
temperature: 0.9,
maxTokens: 1024,
anthropicApiUrl: "https://www.agenticjs.com/proxy/anthropic",
}
});
// ──── Tasks ─────────────────────────────────────────────
// ─ Tasks define the specific actions each agent must
// ─ take, their expected outputs, and mark critical
// ─ outputs as deliverables if they are the final
// ─ products.
// ────────────────────────────────────────────────────────
const processingTask = new Task({
description: `Extract relevant details such as name, experience, skills, and job history from the user's 'aboutMe' input.
aboutMe: {aboutMe}`,
expectedOutput: 'Structured data ready for formatting.',
agent: profileAnalyst
});
const formattingTask = new Task({
description: `Use the extracted information to create a clean, professional resume layout tailored for a JavaScript Developer.`,
expectedOutput: 'A well-formatted resume in PDF format.',
agent: formatter
});
const reviewTask = new Task({
description: `Ensure the resume is error-free, engaging, and meets professional standards.`,
expectedOutput: 'A polished, final resume ready for job applications. Please do not give any feedback on the resume. Just the final resume.',
agent: reviewer
});
// ──── Team ────────────────────────────────────────────
// ─ The Team coordinates the agents and their tasks.
// ─ It starts with an initial input and manages the
// ─ flow of information between tasks.
// ──────────────────────────────────────────────────────
const team = new Team({
name: 'Resume Creation Team',
agents: [profileAnalyst, formatter, reviewer],
tasks: [processingTask, formattingTask, reviewTask],
inputs: { aboutMe: 'My name is Will, I have been a Javascript Developer for 3 years. I know React, NextJS, and REDUX. My latest job was as a Junior Developer at Disney creating UIs for the main landing page.' }, // Initial input for the first task
});
// ──── Listening to Changes────────────────────────────────────────────
//
// Listening to changes in the team's state is crucial for dynamic updates.
// Yup...AgenticJS utilizes a store similar to Redux for state management.
//
// You can subscribe to specific fields or any field on the store.
//──────────────────────────────────────────────────────────────────────
const unsubscribe = team.subscribeToChanges((updatedFields) => {
console.log("Workflow Status Updated:", updatedFields);
}, ['teamWorkflowStatus']);
// ──── Start Team Workflow ───────────────────────────────────────
//
// Begins the predefined team process, producing the final result.
//─────────────────────────────────────────────────────────────────
const result = await team.start();
console.log("Final Output:", result);
AgenticJS is compatible with major front-end frameworks like React, Vue, Angular, and NextJS, making it a versatile choice for developers.
Join our Discord community to connect with other developers and get support. Follow us on Twitter for the latest updates.
We welcome contributions from the community. Please read our contributing guidelines before submitting pull requests.
AgenticJS is MIT licensed.
FAQs
AI Multi-Agent library for Javascript Developers.
The npm package agenticjs receives a total of 24 weekly downloads. As such, agenticjs popularity was classified as not popular.
We found that agenticjs demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.