UNPKG

shipdeck

Version:

Ship MVPs in 48 hours. Fix bugs in 30 seconds. The command deck for developers who ship.

157 lines (131 loc) 3.67 kB
/** * DevOpsAutomator Agent * Automates CI/CD and deployment processes */ const BaseAgent = require('./base-agent'); const { AnthropicClient } = require('../anthropic/client'); /** * DevOpsAutomator - Automates CI/CD and deployment processes */ class DevOpsAutomatorAgent extends BaseAgent { constructor(config = {}) { super('DevOpsAutomatorAgent', { ...config, description: 'Automates CI/CD and deployment processes', version: '1.0.0' }); this.capabilities = ["ci-cd","deployment","automation","monitoring","infrastructure"]; this.anthropicClient = config.anthropicClient || new AnthropicClient(); } /** * Get agent capabilities * @returns {Array} List of capabilities */ getCapabilities() { return this.capabilities; } /** * Get system prompt for the agent * @returns {string} System prompt */ getSystemPrompt() { return `You are DevOpsAutomatorAgent, an AI agent specialized in ci-cd, deployment, automation, monitoring, infrastructure. Your core responsibilities: - ci-cd - deployment - automation - monitoring - infrastructure Always provide practical, production-ready solutions.`; } /** * Execute agent task * @param {Object} task - Task to execute * @param {Object} context - Execution context * @returns {Promise<Object>} Execution result */ async execute(task, context = {}) { try { this.validateTask(task); const systemPrompt = this.getSystemPrompt(); const userPrompt = this.createPrompt(task, context); const response = await this.anthropicClient.createMessage( `${systemPrompt} ${userPrompt}`, { maxTokens: 4096, temperature: 0.7 } ); return this.parseResponse(response, task.type); } catch (error) { this.emit('error', error); throw new Error(`DevOpsAutomatorAgent execution failed: ${error.message}`); } } /** * Create prompt for the task * @param {Object} task - Task object * @param {Object} context - Context object * @returns {string} Generated prompt */ createPrompt(task, context) { const { type, description, requirements = [] } = task; return `Task Type: ${type} Description: ${description} Requirements: ${requirements.join(', ')} Please provide a comprehensive solution.`; } /** * Parse agent response * @param {Object} response - API response * @param {string} type - Task type * @returns {Object} Parsed result */ parseResponse(response, type) { const content = response.content?.[0]?.text || ''; return { success: true, type: type, content: content, timestamp: new Date().toISOString() }; } /** * setupCICD implementation * @param {Object} params - Method parameters * @returns {Promise<Object>} Method result */ async setupCICD(params = {}) { const task = { type: 'setupCICD', ...params }; return this.execute(task); } /** * automateDeployment implementation * @param {Object} params - Method parameters * @returns {Promise<Object>} Method result */ async automateDeployment(params = {}) { const task = { type: 'automateDeployment', ...params }; return this.execute(task); } /** * configureMonitoring implementation * @param {Object} params - Method parameters * @returns {Promise<Object>} Method result */ async configureMonitoring(params = {}) { const task = { type: 'configureMonitoring', ...params }; return this.execute(task); } } module.exports = DevOpsAutomatorAgent;