@zibby/core 0.4.2 → 0.4.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +140 -140
- package/dist/package.json +1 -1
- package/dist/register-built-in-strategies.js +48 -48
- package/dist/skills/session/index.js +1 -1
- package/dist/skills/session/session-skill.js +1 -1
- package/dist/skills/session/session-store.js +1 -0
- package/dist/strategies/claude-strategy.js +2 -2
- package/dist/strategies/index.js +53 -53
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
var
|
|
1
|
+
var S=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-8][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/i;function b(e){return typeof e=="string"&&S.test(e)}var m=b;function A(e){if(!m(e))throw TypeError("Invalid UUID");let r;return Uint8Array.of((r=parseInt(e.slice(0,8),16))>>>24,r>>>16&255,r>>>8&255,r&255,(r=parseInt(e.slice(9,13),16))>>>8,r&255,(r=parseInt(e.slice(14,18),16))>>>8,r&255,(r=parseInt(e.slice(19,23),16))>>>8,r&255,(r=parseInt(e.slice(24,36),16))/1099511627776&255,r/4294967296&255,r>>>24&255,r>>>16&255,r>>>8&255,r&255)}var c=A;var s=[];for(let e=0;e<256;++e)s.push((e+256).toString(16).slice(1));function w(e,r=0){return(s[e[r+0]]+s[e[r+1]]+s[e[r+2]]+s[e[r+3]]+"-"+s[e[r+4]]+s[e[r+5]]+"-"+s[e[r+6]]+s[e[r+7]]+"-"+s[e[r+8]]+s[e[r+9]]+"-"+s[e[r+10]]+s[e[r+11]]+s[e[r+12]]+s[e[r+13]]+s[e[r+14]]+s[e[r+15]]).toLowerCase()}function E(e){e=unescape(encodeURIComponent(e));let r=new Uint8Array(e.length);for(let o=0;o<e.length;++o)r[o]=e.charCodeAt(o);return r}var g="6ba7b810-9dad-11d1-80b4-00c04fd430c8",v="6ba7b811-9dad-11d1-80b4-00c04fd430c8";function d(e,r,o,t,n,i){let l=typeof o=="string"?E(o):o,p=typeof t=="string"?c(t):t;if(typeof t=="string"&&(t=c(t)),t?.length!==16)throw TypeError("Namespace must be array-like (16 iterable integer values, 0-255)");let f=new Uint8Array(16+l.length);if(f.set(p),f.set(l,p.length),f=r(f),f[6]=f[6]&15|e,f[8]=f[8]&63|128,n){if(i=i||0,i<0||i+16>n.length)throw new RangeError(`UUID byte range ${i}:${i+15} is out of buffer bounds`);for(let a=0;a<16;++a)n[i+a]=f[a];return n}return w(f)}import{createHash as T}from"crypto";function $(e){return Array.isArray(e)?e=Buffer.from(e):typeof e=="string"&&(e=Buffer.from(e,"utf8")),T("sha1").update(e).digest()}var U=$;function x(e,r,o,t){return d(80,U,e,r,o,t)}x.DNS=g;x.URL=v;var h=x;var I="@zibby/core ZibbySessionStore/1",u=class{constructor({apiUrl:r,apiKey:o,workflowUuid:t,fetchImpl:n=globalThis.fetch}){if(!r)throw new Error("ZibbySessionStore: apiUrl is required");if(!o)throw new Error("ZibbySessionStore: apiKey is required");if(!t)throw new Error("ZibbySessionStore: workflowUuid is required");this._apiUrl=String(r).replace(/\/+$/,""),this._apiKey=o,this._workflowUuid=t,this._fetch=n}async append(r,o){if(!Array.isArray(o)||o.length===0)return;let t=`${this._apiUrl}/workflows/${encodeURIComponent(this._workflowUuid)}/sessions/${encodeURIComponent(r.sessionId)}/append`,n=await this._fetch(t,{method:"POST",headers:{Authorization:`Bearer ${this._apiKey}`,"Content-Type":"application/json","User-Agent":I},body:JSON.stringify({entries:o})});if(!n.ok)throw new Error(`ZibbySessionStore.append HTTP ${n.status}`)}async load(r){let o=`${this._apiUrl}/workflows/${encodeURIComponent(this._workflowUuid)}/sessions/${encodeURIComponent(r.sessionId)}`,t;try{t=await this._fetch(o,{method:"GET",headers:{Authorization:`Bearer ${this._apiKey}`,"User-Agent":I}})}catch{return null}if(t.status===404||!t.ok)return null;let n;try{n=await t.json()}catch{return null}let i=Array.isArray(n?.entries)?n.entries:null;return i&&i.length>0?i:null}};var R="6ba7b810-9dad-11d1-80b4-00c04fd430c8",y=new Set;function k(){return(process.env.PROGRESS_API_URL||process.env.ZIBBY_API_BASE||"").replace(/\/executions\/?$/,"").replace(/\/+$/,"")}function F({namespace:e=R}={}){return{id:"session",description:"Persist agent conversation state across invocations (Claude-only in v1)",envKeys:[],tools:[],invokeAgentOptions(r,o){let t=r?.conversationId,n=r?.workflowUuid;if(!t||!n)return null;let i=o?.agentType;if(i&&i!=="claude")return y.has(i)||(console.warn(`[SKILLS.SESSION] agent type '${i}' does not support native sessions \u2014 node running stateless`),y.add(i)),null;let l=h(`${n}:${t}`,e),p=k(),f=process.env.PROJECT_API_TOKEN||process.env.ZIBBY_USER_TOKEN,a=null;if(p&&f)try{a=new u({apiUrl:p,apiKey:f,workflowUuid:n})}catch(_){console.warn(`[SKILLS.SESSION] failed to build SessionStore: ${_.message}`),a=null}return r.resetConversation?{sessionId:l,resume:l,forkSession:!0,...a&&{sessionStore:a}}:{sessionId:l,...a&&{sessionStore:a}}}}}function Q(){y.clear()}export{Q as __resetSessionSkillWarnings,F as sessionSkill};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var i="@zibby/core ZibbySessionStore/1",n=class{constructor({apiUrl:o,apiKey:r,workflowUuid:e,fetchImpl:t=globalThis.fetch}){if(!o)throw new Error("ZibbySessionStore: apiUrl is required");if(!r)throw new Error("ZibbySessionStore: apiKey is required");if(!e)throw new Error("ZibbySessionStore: workflowUuid is required");this._apiUrl=String(o).replace(/\/+$/,""),this._apiKey=r,this._workflowUuid=e,this._fetch=t}async append(o,r){if(!Array.isArray(r)||r.length===0)return;let e=`${this._apiUrl}/workflows/${encodeURIComponent(this._workflowUuid)}/sessions/${encodeURIComponent(o.sessionId)}/append`,t=await this._fetch(e,{method:"POST",headers:{Authorization:`Bearer ${this._apiKey}`,"Content-Type":"application/json","User-Agent":i},body:JSON.stringify({entries:r})});if(!t.ok)throw new Error(`ZibbySessionStore.append HTTP ${t.status}`)}async load(o){let r=`${this._apiUrl}/workflows/${encodeURIComponent(this._workflowUuid)}/sessions/${encodeURIComponent(o.sessionId)}`,e;try{e=await this._fetch(r,{method:"GET",headers:{Authorization:`Bearer ${this._apiKey}`,"User-Agent":i}})}catch{return null}if(e.status===404||!e.ok)return null;let t;try{t=await e.json()}catch{return null}let s=Array.isArray(t?.entries)?t.entries:null;return s&&s.length>0?s:null}};export{n as ZibbySessionStore};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{AgentStrategy as
|
|
1
|
+
import{AgentStrategy as re,getSkill as ie}from"@zibby/agent-workflow";import{query as ce}from"@anthropic-ai/claude-agent-sdk";import{zodToJsonSchema as le}from"zod-to-json-schema";import{writeFileSync as x,mkdirSync as P,existsSync as Q,readFileSync as V}from"fs";import{homedir as ee}from"os";import{join as A}from"path";import C from"chalk";var f={debug:0,info:1,warn:2,error:3,silent:4},v=class{constructor(){this._level=this._getLogLevel()}_getLogLevel(){if(process.env.ZIBBY_DEBUG==="true")return f.debug;if(process.env.ZIBBY_VERBOSE==="true")return f.info;let e=process.env.LOG_LEVEL?.toLowerCase();return e&&e in f?f[e]:f.info}_shouldLog(e){return f[e]>=this._level}_formatMessage(e,n,r={}){let s=new Date().toISOString(),a=`${this._getPrefix(e)} ${n}`;return Object.keys(r).length>0&&(a+=C.dim(` ${JSON.stringify(r)}`)),a}_getPrefix(e){return{debug:C.gray("[DEBUG]"),info:C.cyan("[INFO]"),warn:C.yellow("[WARN]"),error:C.red("\u274C [ERROR]")}[e]||""}debug(e,n){this._shouldLog("debug")&&console.log(this._formatMessage("debug",e,n))}info(e,n){this._shouldLog("info")&&console.log(this._formatMessage("info",e,n))}warn(e,n){this._shouldLog("warn")&&console.warn(this._formatMessage("warn",e,n))}error(e,n){this._shouldLog("error")&&console.error(this._formatMessage("error",e,n))}setLevel(e){e in f&&(this._level=f[e])}getLevel(){return Object.keys(f).find(e=>f[e]===this._level)}},i=new v;import{timeline as I,Timeline as _e,WORKFLOW_GRAPH_LOG_MARKER_PREFIX as Oe}from"@zibby/agent-workflow";var b={ASSISTANT:"gpt-5.4-nano-2026-03-17",CLAUDE:"claude-sonnet-4-6",CURSOR:"auto",CODEX:"o4-mini",GEMINI:"gemini-2.5-pro",OPENAI_POSTPROCESSING:"gpt-4o-mini"};var $={auto:"claude-sonnet-4-6","sonnet-4.6":"claude-sonnet-4-6","sonnet-4-6":"claude-sonnet-4-6","opus-4.6":"claude-opus-4-6","opus-4-6":"claude-opus-4-6","sonnet-4.5":"claude-sonnet-4-5-20250929","sonnet-4-5":"claude-sonnet-4-5-20250929","opus-4.5":"claude-opus-4-20250514","opus-4-5":"claude-opus-4-20250514","claude-sonnet-4-6":"claude-sonnet-4-6","claude-opus-4-6":"claude-opus-4-6","claude-sonnet-4-5-20250929":"claude-sonnet-4-5-20250929","claude-opus-4-20250514":"claude-opus-4-20250514"};var he={CURSOR_AGENT_DEFAULT:1200*1e3,OPENAI_REQUEST:18e4};function D(l){let e=`${l}_POOL`,n=process.env[e];if(!n||typeof n!="string")return{picked:null,count:0,dispose:()=>{}};let r=n.split(/[,\n]+/).map(a=>a.trim()).filter(Boolean);if(r.length===0)return{picked:null,count:0,dispose:()=>{}};let s=r[Math.floor(Math.random()*r.length)],o=process.env[l];return process.env[l]=s,i.debug(`[auth-pool] ${l}: picked 1 of ${r.length} from pool (***${s.slice(-4)})`),{picked:s,count:r.length,dispose(){o===void 0?delete process.env[l]:process.env[l]=o}}}var z=class extends re{constructor(){super("claude","Claude (Anthropic API)",50)}canHandle(e){let n=!!process.env.ANTHROPIC_API_KEY||!!process.env.ANTHROPIC_API_KEY_POOL,r=!!process.env.CLAUDE_CODE_OAUTH_TOKEN||!!process.env.CLAUDE_CODE_OAUTH_TOKEN_POOL,s=!!process.env.ANTHROPIC_AUTH_TOKEN||!!process.env.ANTHROPIC_AUTH_TOKEN_POOL,o=n||r||s;return o||i.debug("ClaudeAgentStrategy: no credentials. Set one of ANTHROPIC_API_KEY / CLAUDE_CODE_OAUTH_TOKEN / ANTHROPIC_AUTH_TOKEN (or a *_POOL variant for multi-token rotation)."),o}async invoke(e,n={}){let{model:r,workspace:s=process.cwd(),schema:o=null,images:a=[],skills:d=null,sessionPath:m=null,nodeName:N=null,timeout:R,config:M={},signal:E=null,sessionId:U,resume:K,forkSession:te,sessionStore:J}=n,g=r;(!g||g==="auto")&&(i.debug(`Model is '${g||"undefined"}', using default: ${b.CLAUDE}`),g=b.CLAUDE);let S=$[g]||g;$[g]&&g!==S&&i.debug(`Mapped model: ${g} \u2192 ${S}`);let oe=[D("ANTHROPIC_API_KEY"),D("CLAUDE_CODE_OAUTH_TOKEN"),D("ANTHROPIC_AUTH_TOKEN")];try{i.debug(`Invoking Claude Agent SDK with model: ${S}, skills: ${JSON.stringify(d)}`);let O=process.env.CLAUDE_CODE_OAUTH_TOKEN,F=process.env.ANTHROPIC_API_KEY,H=process.env.ANTHROPIC_AUTH_TOKEN;process.env.CLAUDE_CODE_CREDENTIALS_JSON?de(process.env.CLAUDE_CODE_CREDENTIALS_JSON):O&&ae(O,process.env.__ZIBBY_CLAUDE_PLAN);let k=process.env.__ZIBBY_CLAUDE_PLAN,B=k?k.charAt(0).toUpperCase()+k.slice(1):null,T;O?T=B?`Claude ${B} plan \xB7 ***${O.slice(-4)}`:`Subscription \xB7 ***${O.slice(-4)}`:F?T=`API key \xB7 ***${F.slice(-4)}`:H?T=`Bearer \xB7 ***${H.slice(-4)}`:T="NONE \u2014 request will fail";let _=(await import("chalk")).default;console.log(""),console.log(` ${_.cyan("\u25C6")} ${_.bold(S)}`),console.log(` ${_.dim("Auth: ")}${T}`),console.log(` ${_.dim("Workdir: ")}${s}`),console.log(""),console.log(_.bold("Prompt sent to LLM:")),console.log(_.dim("\u2500".repeat(60))),console.log(_.dim(e)),console.log(_.dim("\u2500".repeat(60)));let{allowedTools:G,mcpServers:j}=this._resolveSkills(d,{sessionPath:m,workspace:s,nodeName:N});try{let p={cwd:s,allowedTools:G,settings:{permissions:{allow:["Bash(*)","Read(*)","Write(*)","Edit(*)","MultiEdit(*)","NotebookEdit(*)","Grep(*)","Glob(*)","WebFetch(*)","WebSearch(*)","Task(*)","TodoWrite(*)","Skill(*)"]}},model:S,...Object.keys(j).length>0&&{mcpServers:j},...U&&{sessionId:U},...K&&{resume:K},...te&&{forkSession:!0},...J&&{sessionStore:J}};if(o){let h=typeof o.parse=="function"?le(o,{target:"openApi3"}):o;p.outputFormat={type:"json_schema",schema:h},i.debug("Structured output enforced via SDK outputFormat")}i.debug(`Agent SDK options: ${JSON.stringify({cwd:p.cwd,toolCount:G.length,permissionMode:p.permissionMode,model:p.model,hasOutputFormat:!!p.outputFormat})}`);let L="",W=0,Y=[];i.debug("Starting Claude Agent SDK query stream");let Z;try{Z=ce({prompt:e,options:p})}catch(t){throw i.error(`Failed to initialize Claude Agent SDK: ${t.message}`),t}let q=null,w=0,ne=3;if(E?.aborted){let t=new Error("Aborted via signal");throw t.name="AbortError",t}try{for await(let t of Z){if(E?.aborted){let u=new Error("Aborted via signal");throw u.name="AbortError",u}if(Y.push(t),t.type==="error"||t.error){let u=t.error?.message||t.error||t.message||"Unknown API error";try{i.error("SDK error event raw payload",{fullMessage:JSON.stringify(t,null,2)})}catch{}throw new Error(typeof u=="string"?u:JSON.stringify(u))}let h=JSON.stringify(t.message?.content||t.text||"").slice(0,200);if(h===q){if(w++,w>=ne){let u=(t.message?.content?.[0]?.text||t.text||"unknown").slice(0,100);throw new Error(`API stuck in loop (${w}x repeated): ${u}`)}}else q=h,w=1;if(t.type==="assistant"||t.constructor?.name==="AssistantMessage"){let u=t.message?.content||t.content||[];for(let c of u)if(c.type==="thinking"&&c.thinking)console.log(`${c.thinking.substring(0,200)}${c.thinking.length>200?"...":""}`);else if(c.type==="text"&&c.text)L+=c.text,c.text.length<500?console.log(`${c.text}`):console.log(`${c.text.substring(0,200)}... (${c.text.length} chars)`);else if(c.type==="tool_use"){W++,c.name.includes("memory")?I.stepMemory(`Tool: ${c.name}`):I.stepTool(`Tool: ${c.name}`);let se=JSON.stringify(c.input).substring(0,100);console.log(` Input: ${se}${JSON.stringify(c.input).length>100?"...":""}`)}}else if(!(t.type==="user"&&t.tool_use_result)){if(t.type==="result"||t.constructor?.name==="ResultMessage"){let u=t.result||t.text||t.content||L;try{ue({message:t,sessionPath:m,nodeName:N,model:g,toolCallCount:W})}catch(c){i.debug(`usage.json write failed: ${c.message}`)}if(o){if(t.structured_output){i.debug("Using SDK native structured_output");let X=typeof o.parse=="function"?o.parse(t.structured_output):t.structured_output;return{raw:u,structured:X}}if(u){let c=this._extractJson(u,o);if(c)return{raw:u,structured:c}}i.warn(`Could not extract structured output \u2014 returning raw text (${(u||"").length} chars)`)}return u||""}}}if(i.warn(`Agent SDK ended without result. Collected ${Y.length} messages`),L.length>0)return i.debug("Returning accumulated text from messages"),L;throw new Error("Claude Agent SDK query ended without result")}catch(t){let h={message:t?.message,name:t?.name,code:t?.code,cause:t?.cause?.message||t?.cause,stack:t?.stack?.split(`
|
|
2
2
|
`).slice(0,5).join(`
|
|
3
|
-
`),stringified:(()=>{try{return JSON.stringify(t,Object.getOwnPropertyNames(Object(t)))}catch{return String(t)}})()};throw i.error(`Error during query stream: ${t?.message||t}`,h),t}}catch(p){throw i.error("Claude Agent SDK call failed",{message:p?.message,name:p?.name,code:p?.code,cause:p?.cause?.message||p?.cause}),p}}finally{for(let O of
|
|
3
|
+
`),stringified:(()=>{try{return JSON.stringify(t,Object.getOwnPropertyNames(Object(t)))}catch{return String(t)}})()};throw i.error(`Error during query stream: ${t?.message||t}`,h),t}}catch(p){throw i.error("Claude Agent SDK call failed",{message:p?.message,name:p?.name,code:p?.code,cause:p?.cause?.message||p?.cause}),p}}finally{for(let O of oe)O.dispose()}}_resolveSkills(e,n){let r=["Read","Write","Edit","Bash","Grep","Glob"];if(e===null)return i.debug("No skills \u2014 pure LLM mode"),{allowedTools:[],mcpServers:{}};if(!Array.isArray(e)||e.length===0)return i.debug("Default IDE skills for code generation"),{allowedTools:[...r],mcpServers:{}};let s=[...r],o={};for(let a of e){let d=ie(a);if(!d){i.warn(`Unknown skill "${a}" \u2014 skipping`);continue}if(d.allowedTools&&s.push(...d.allowedTools),typeof d.resolve=="function"){let m=d.resolve(n);m&&(o[d.serverName]=m,i.debug(`MCP: ${d.serverName} \u2192 ${m.command} ${m.args[0]}`))}}return{allowedTools:s,mcpServers:o}}_extractJson(e,n){let r=[()=>{if(e.includes("===JSON_START===")){let s=e.indexOf("===JSON_START===")+16,o=e.indexOf("===JSON_END===");return e.substring(s,o).trim()}},()=>e.match(/```json\s*\n([\s\S]*?)\n```/)?.[1]?.trim(),()=>{if(!e.startsWith("{"))return e.match(/```\s*\n([\s\S]*?)\n```/)?.[1]?.trim()},()=>e.trim(),()=>{let s=e.indexOf("{"),o=e.lastIndexOf("}");if(s!==-1&&o>s)return e.substring(s,o+1)}];for(let s of r)try{let o=s();if(!o)continue;let a=JSON.parse(o);if(typeof a!="object"||a===null)continue;return typeof n.parse=="function"?n.parse(a):a}catch{}return null}};function ue({message:l,sessionPath:e,nodeName:n,model:r,toolCallCount:s}){if(!e||!n)return;let o=l?.usage||l?.message?.usage||{},a=y(o.input_tokens,o.inputTokens),d=y(o.output_tokens,o.outputTokens),m=y(o.cache_read_input_tokens,o.cacheReadInputTokens),N=y(o.cache_creation_input_tokens,o.cacheCreationInputTokens),R=y(l?.duration_ms,l?.durationMs),M={model:r||null,input_tokens:a,output_tokens:d,cache_read_tokens:m,cache_creation_tokens:N,tool_call_count:typeof s=="number"?s:null,duration_ms:R,captured_at:new Date().toISOString()},E=A(e,n);try{P(E,{recursive:!0})}catch{}x(A(E,"usage.json"),JSON.stringify(M,null,2),"utf-8")}function y(...l){for(let e of l){if(typeof e=="number"&&Number.isFinite(e))return e;if(typeof e=="string"&&e.trim()!==""&&!isNaN(Number(e)))return Number(e)}return null}function ae(l,e){let n=A(ee(),".claude"),r=A(n,".credentials.json"),s={claudeAiOauth:{accessToken:l,...e?{subscriptionType:String(e).toLowerCase()}:{}}};try{if(Q(r)&&JSON.parse(V(r,"utf-8"))?.claudeAiOauth?.accessToken===l)return;P(n,{recursive:!0}),x(r,JSON.stringify(s,null,2),"utf-8"),i.debug(`Wrote Claude Code OAuth credentials to ${r}`)}catch(o){i.warn(`Could not write ${r}: ${o.message} \u2014 Claude SDK may fail to authenticate.`)}}function de(l){let e=A(ee(),".claude"),n=A(e,".credentials.json"),r;try{r=JSON.parse(l)}catch(s){i.warn(`CLAUDE_CODE_CREDENTIALS_JSON not valid JSON: ${s.message}`);return}if(!r?.claudeAiOauth?.accessToken){i.warn("CLAUDE_CODE_CREDENTIALS_JSON missing claudeAiOauth.accessToken \u2014 skipping write.");return}try{if(Q(n)){let s=JSON.parse(V(n,"utf-8"));if(s?.claudeAiOauth?.accessToken===r.claudeAiOauth.accessToken&&s?.claudeAiOauth?.expiresAt===r.claudeAiOauth.expiresAt)return}P(e,{recursive:!0}),x(n,JSON.stringify(r,null,2),"utf-8"),i.debug(`Wrote full Claude Code credentials blob to ${n}`)}catch(s){i.warn(`Could not write ${n}: ${s.message} \u2014 Claude SDK may fail to authenticate.`)}}export{z as ClaudeAgentStrategy};
|