Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
AgenticJS is a JavaScript-native framework for building and managing multi-agent 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 key as an environment variable:
export ANTHROPIC_API_KEY='your-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
});
// Start the team: This initiates the sequence of tasks as defined, leading to the generation of the final deliverable.
team.start();
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 41 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
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.