Some checks failed
Release Gate / gate (push) Has been cancelled
- 도구 동등화: task/todo/tool-search + plan/worktree/team/cron 도구군 추가 및 ToolRegistry 등록\n- claw-code CamelCase 별칭 정규화 확장: EnterPlanMode/EnterWorktree/TeamCreate/CronCreate 등 -> 내부 snake_case 매핑\n- AgentLoop 런타임 강화: Code 탭 전용 도구 토글(CodeSettings) 반영, 비활성 도구 자동 차단\n- Worktree 상태 복원 연결: .ax/worktree_state.json 기반 루트 탐색/활성 worktree 복원 및 BuildContext 연동\n- 권한/플러그인 하드닝 기존 반영분 유지: target 기반 권한 판정 + internal 모드 플러그인 경로/manifest 검증\n- 설정 연동(UI): SettingsWindow Code 패널에 Plan/Worktree/Team/Cron 도구 on/off 토글 추가\n- 테스트 보강: AgentParityTools/AgentLoopE2E에 worktree 지속성, alias 정규화, 설정 차단 시나리오 추가\n- 검증 완료: dotnet build(경고0/오류0), ParityBenchmark 11/11, ReplayStability 12/12, 전체 371/371, release-gate 통과\n- 문서 동기화: AGENT_ROADMAP/NEXT_ROADMAP/CLAW_CODE_PARITY_PLAN 수치 및 기준 최신화
37 lines
1.2 KiB
C#
37 lines
1.2 KiB
C#
using System.IO;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Text.Json;
|
|
|
|
namespace AxCopilot.Services.Agent;
|
|
|
|
public sealed class CronListTool : IAgentTool
|
|
{
|
|
public string Name => "cron_list";
|
|
public string Description => "List local cron-like jobs.";
|
|
|
|
public ToolParameterSchema Parameters => new()
|
|
{
|
|
Properties = new(),
|
|
Required = []
|
|
};
|
|
|
|
public Task<ToolResult> ExecuteAsync(JsonElement args, AgentContext context, CancellationToken ct = default)
|
|
{
|
|
if (string.IsNullOrWhiteSpace(context.WorkFolder) || !Directory.Exists(context.WorkFolder))
|
|
return Task.FromResult(ToolResult.Fail("valid WorkFolder is required."));
|
|
|
|
var jobs = CronStore.Load(context.WorkFolder)
|
|
.OrderByDescending(j => j.CreatedAt)
|
|
.ToList();
|
|
if (jobs.Count == 0)
|
|
return Task.FromResult(ToolResult.Ok("No cron jobs."));
|
|
|
|
var sb = new StringBuilder();
|
|
sb.AppendLine($"cron jobs: {jobs.Count}");
|
|
foreach (var j in jobs)
|
|
sb.AppendLine($"- {j.Id} | {j.Name} | {j.Schedule} | enabled={j.Enabled} | {j.Command}");
|
|
return Task.FromResult(ToolResult.Ok(sb.ToString()));
|
|
}
|
|
}
|