awaitly-visualizer 1.0.0
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.browser.cjs +1677 -0
- package/dist/index.browser.cjs.map +1 -0
- package/dist/index.browser.d.cts +166 -0
- package/dist/index.browser.d.ts +166 -0
- package/dist/index.browser.js +1677 -0
- package/dist/index.browser.js.map +1 -0
- package/dist/index.cjs +1680 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +242 -0
- package/dist/index.d.ts +242 -0
- package/dist/index.js +1680 -0
- package/dist/index.js.map +1 -0
- package/dist/kroki/fetch.cjs +3 -0
- package/dist/kroki/fetch.cjs.map +1 -0
- package/dist/kroki/fetch.d.cts +86 -0
- package/dist/kroki/fetch.d.ts +86 -0
- package/dist/kroki/fetch.js +3 -0
- package/dist/kroki/fetch.js.map +1 -0
- package/dist/notifiers/discord.cjs +3 -0
- package/dist/notifiers/discord.cjs.map +1 -0
- package/dist/notifiers/discord.d.cts +70 -0
- package/dist/notifiers/discord.d.ts +70 -0
- package/dist/notifiers/discord.js +3 -0
- package/dist/notifiers/discord.js.map +1 -0
- package/dist/notifiers/slack.cjs +38 -0
- package/dist/notifiers/slack.cjs.map +1 -0
- package/dist/notifiers/slack.d.cts +95 -0
- package/dist/notifiers/slack.d.ts +95 -0
- package/dist/notifiers/slack.js +38 -0
- package/dist/notifiers/slack.js.map +1 -0
- package/dist/notifiers/webhook.cjs +3 -0
- package/dist/notifiers/webhook.cjs.map +1 -0
- package/dist/notifiers/webhook.d.cts +115 -0
- package/dist/notifiers/webhook.d.ts +115 -0
- package/dist/notifiers/webhook.js +3 -0
- package/dist/notifiers/webhook.js.map +1 -0
- package/dist/performance-analyzer-B5VF5b1F.d.ts +663 -0
- package/dist/performance-analyzer-BNwE4AiO.d.cts +663 -0
- package/dist/types-BIZSmXif.d.ts +350 -0
- package/dist/types-BnWc9Wlr.d.cts +350 -0
- package/dist/url-PkfQz4V5.d.cts +750 -0
- package/dist/url-PkfQz4V5.d.ts +750 -0
- package/package.json +105 -0
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";var Te=Object.create;var B=Object.defineProperty;var Oe=Object.getOwnPropertyDescriptor;var De=Object.getOwnPropertyNames;var ve=Object.getPrototypeOf,We=Object.prototype.hasOwnProperty;var _e=(e,r)=>{for(var n in r)B(e,n,{get:r[n],enumerable:!0})},Y=(e,r,n,c)=>{if(r&&typeof r=="object"||typeof r=="function")for(let d of De(r))!We.call(e,d)&&d!==n&&B(e,d,{get:()=>r[d],enumerable:!(c=Oe(r,d))||c.enumerable});return e};var Ce=(e,r,n)=>(n=e!=null?Te(ve(e)):{},Y(r||!e||!e.__esModule?B(n,"default",{value:e,enumerable:!0}):n,e)),Pe=e=>Y(B({},"__esModule",{value:!0}),e);var wt={};_e(wt,{createWebhookNotifier:()=>kt});module.exports=Pe(wt);var q=require("awaitly");function Z(e){function r(n){let c=0;for(let d of n)if(d.type==="step")c++;else if(d.type==="decision"&&d.branches)for(let s of d.branches)s.taken&&(c+=r(s.children));else"children"in d&&d.children&&(c+=r(d.children));return c}return r(e.root.children)}var oe=require("awaitly");function X(e){return e.type==="step"}function Q(e){return e.type==="parallel"}function ee(e){return e.type==="race"}function te(e){return e.type==="decision"}function re(e){return e.type==="stream"}function W(e){if(e<1e3)return`${Math.round(e)}ms`;if(e<6e4)return`${(e/1e3).toFixed(1).replace(/\.0$/,"")}s`;let r=Math.floor(e/6e4),n=Math.round(e%6e4/1e3);return n>=60&&(r+=1,n=0),n===0?`${r}m`:`${r}m ${n}s`}function H(){return`node_${Date.now()}_${Math.random().toString(36).slice(2,8)}`}var Le="\x1B[2m",Ue="\x1B[31m",Ae="\x1B[32m",Fe="\x1B[33m",Be="\x1B[34m",ne="\x1B[90m",He="\x1B[37m";var _={pending:He,running:Fe,success:Ae,error:Ue,aborted:ne,cached:Be,skipped:Le+ne};var G=require("awaitly");function se(e){return e<.2?"cold":e<.4?"cool":e<.6?"neutral":e<.8?"warm":e<.95?"hot":"critical"}function Ke(){return[" classDef pending fill:#f3f4f6,stroke:#9ca3af,stroke-width:2px,color:#374151"," classDef running fill:#fef3c7,stroke:#f59e0b,stroke-width:3px,color:#92400e"," classDef success fill:#d1fae5,stroke:#10b981,stroke-width:3px,color:#065f46"," classDef error fill:#fee2e2,stroke:#ef4444,stroke-width:3px,color:#991b1b"," classDef aborted fill:#f3f4f6,stroke:#6b7280,stroke-width:2px,color:#4b5563,stroke-dasharray: 5 5"," classDef cached fill:#dbeafe,stroke:#3b82f6,stroke-width:3px,color:#1e40af"," classDef skipped fill:#f9fafb,stroke:#d1d5db,stroke-width:2px,color:#6b7280,stroke-dasharray: 5 5"," classDef stream fill:#ede9fe,stroke:#8b5cf6,stroke-width:3px,color:#5b21b6"," classDef streamActive fill:#ddd6fe,stroke:#7c3aed,stroke-width:3px,color:#4c1d95"," classDef streamError fill:#fce7f3,stroke:#db2777,stroke-width:3px,color:#9d174d"]}function ze(){return[" classDef heat_cold fill:#dbeafe,stroke:#3b82f6,stroke-width:2px,color:#1e40af"," classDef heat_cool fill:#ccfbf1,stroke:#14b8a6,stroke-width:2px,color:#0f766e"," classDef heat_neutral fill:#f3f4f6,stroke:#6b7280,stroke-width:2px,color:#374151"," classDef heat_warm fill:#fef3c7,stroke:#f59e0b,stroke-width:2px,color:#92400e"," classDef heat_hot fill:#fed7aa,stroke:#f97316,stroke-width:3px,color:#c2410c"," classDef heat_critical fill:#fecaca,stroke:#ef4444,stroke-width:3px,color:#b91c1c"]}function Ge(e){return`heat_${e}`}function je(){return[" classDef hook_success fill:#e0f2fe,stroke:#0284c7,stroke-width:2px,color:#0c4a6e"," classDef hook_error fill:#fef2f2,stroke:#dc2626,stroke-width:2px,color:#7f1d1d"]}function Ve(e){try{return(0,G.ok)(JSON.stringify(e,(n,c)=>{if(typeof c!="bigint")return c;let d=Number(c);return Number.isSafeInteger(d)?d:c.toString()}))}catch{return(0,G.err)("STRINGIFY_ERROR")}}function ie(e){let r=Ve(e);return r.ok?r.value:"[unserializable]"}function qe(e,r,n){let c;if(e.shouldRun){let d="hook_shouldRun",s=e.shouldRun.state==="success"?"hook_success":"hook_error",h=e.shouldRun.state==="success"?"\u2699":"\u26A0",m=n.showTimings&&e.shouldRun.durationMs!==void 0?` ${W(e.shouldRun.durationMs)}`:"",g=e.shouldRun.context?.skipped?"\\nskipped workflow":e.shouldRun.context?.result===!0?"\\nproceed":"";r.push(` ${d}[["${h} shouldRun${g}${m}"]]:::${s}`),c=d}if(e.onBeforeStart){let d="hook_beforeStart",s=e.onBeforeStart.state==="success"?"hook_success":"hook_error",h=e.onBeforeStart.state==="success"?"\u2699":"\u26A0",m=n.showTimings&&e.onBeforeStart.durationMs!==void 0?` ${W(e.onBeforeStart.durationMs)}`:"",g=e.onBeforeStart.context?.skipped?"\\nskipped workflow":"";r.push(` ${d}[["${h} onBeforeStart${g}${m}"]]:::${s}`),c&&r.push(` ${c} --> ${d}`),c=d}return{lastHookId:c}}var ae=0,K=new Set,z=new Set;function L(e="node"){return`${e}_${++ae}`}function Je(){ae=0,K.clear(),z.clear()}function O(e){return e.replace(/"/g,"#quot;").replace(/</g,"<").replace(/>/g,">").trim()}function ce(e){return O(e).replace(/[{}[\]()]/g,"")}function C(){return{name:"mermaid",supportsLive:!1,render(e,r){Je();let n=[],c=r;n.push("flowchart TD");let d;e.hooks&&(d=qe(e.hooks,n,r).lastHookId);let s="start";n.push(` ${s}(("\u25B6 Start"))`),d&&n.push(` ${d} --> ${s}`);let h=s;for(let g of e.root.children){let i=j(g,r,n,c,e.hooks);n.push(` ${h} --> ${i.entryId}`),h=i.exitId}if(["success","error","aborted"].includes(e.root.state)){let g="finish",i=e.root.state==="success"?"\u2713":e.root.state==="error"?"\u2717":"\u2298",l=e.root.state==="success"?"Done":e.root.state==="error"?"Failed":"Cancelled",b=`(("${i} ${l}"))`,u=e.root.state==="success"?":::success":e.root.state==="error"?":::error":":::aborted";n.push(` ${g}${b}${u}`),n.push(` ${h} --> ${g}`)}return n.push(""),n.push(...Ke()),c.showHeatmap&&n.push(...ze()),e.hooks&&n.push(...je()),n.join(`
|
|
2
|
+
`)}}}function j(e,r,n,c,d){if(X(e))return Ye(e,r,n,c,d);if(Q(e))return Ze(e,r,n,c,d);if(ee(e))return Xe(e,r,n,c,d);if(te(e))return Qe(e,r,n,c,d);if(re(e))return et(e,r,n);let s=L("unknown");return n.push(` ${s}["Unknown Node"]`),{entryId:s,exitId:s}}function Ye(e,r,n,c,d){let s=r,h=s.showRetryEdges??!0,m=s.showErrorEdges??!0,g=s.showTimeoutEdges??!0,i=e.key?`step_${e.key.replace(/[^a-zA-Z0-9]/g,"_")}`:L("step");if(z.has(i)){let y=2;for(;z.has(`${i}_${y}`);)y++;i=`${i}_${y}`}z.add(i);let l=e.name??e.key??"Step",b=r.showKeys&&e.key&&e.name?`${l} [${e.key}]`:l,u=O(b),p=r.showTimings&&e.durationMs!==void 0?` ${W(e.durationMs)}`:"",f="";switch(e.state){case"success":f="\u2713 ";break;case"error":f="\u2717 ";break;case"cached":f="\u{1F4BE} ";break;case"running":f="\u23F3 ";break;case"skipped":f="\u2298 ";break}let w="";if(e.input!==void 0){let y=typeof e.input=="string"?O(e.input):O(ie(e.input).slice(0,20));w+=`\\nin: ${y}`}if(e.output!==void 0&&e.state==="success"){let y=typeof e.output=="string"?O(e.output):O(ie(e.output).slice(0,20));w+=`\\nout: ${y}`}let S="",R=e.key??e.id;if(d&&R&&d.onAfterStep.has(R)){let y=d.onAfterStep.get(R),N=y.state==="success"?"\u2699":"\u26A0",M=r.showTimings&&y.durationMs!==void 0?` ${W(y.durationMs)}`:"";S=`\\n${N} hook${M}`}let x=(f+u+w+S+p).trim(),k,I=c?.showHeatmap&&c.heatmapData?c.heatmapData.heat.get(e.key??"")??c.heatmapData.heat.get(e.name??"")??c.heatmapData.heat.get(e.id):void 0;if(I!==void 0){let y=se(I);k=Ge(y)}else k=e.state;let T;switch(e.state){case"error":T=`{{"${x}"}}`;break;case"cached":T=`[("${x}")]`;break;case"skipped":T=`["${x}"]`;break;default:T=`["${x}"]`}if(n.push(` ${i}${T}:::${k}`),h&&e.retryCount!==void 0&&e.retryCount>0){let y=`\u21BB ${e.retryCount} retr${e.retryCount===1?"y":"ies"}`;n.push(` ${i} -.->|"${y}"| ${i}`)}if(m&&e.state==="error"&&e.error!==void 0){let y=`ERR_${i}`,N=O(String(e.error)).slice(0,30);n.push(` ${y}{{"${N}"}}`),n.push(` ${i} -->|error| ${y}`),n.push(` style ${y} fill:#fee2e2,stroke:#dc2626`)}if(g&&e.timedOut){let y=`TO_${i}`,N=e.timeoutMs!==void 0?`${e.timeoutMs}ms`:"";n.push(` ${y}{{"\u23F1 Timeout ${N}"}}`),n.push(` ${i} -.->|timeout| ${y}`),n.push(` style ${y} fill:#fef3c7,stroke:#f59e0b`)}return{entryId:i,exitId:i}}function Ze(e,r,n,c,d){let s=L("parallel"),h=`${s}_fork`,m=`${s}_join`,g=ce(e.name??"Parallel"),i=e.mode==="allSettled"?" (allSettled)":"";if(e.children.length===0){let u=s,p=O(`${g}${i}`),f="operations not individually tracked",w=r.showTimings&&e.durationMs!==void 0?` ${W(e.durationMs)}`:"";return n.push(` ${u}["${p}${w}\\n${f}"]:::${e.state}`),{entryId:u,exitId:u}}n.push(` subgraph ${s}["${g}${i}"]`),n.push(" direction TB"),n.push(` ${h}{"\u26A1 Fork"}`);let l=[];for(let u of e.children){let p=j(u,r,n,c,d);n.push(` ${h} --> ${p.entryId}`),l.push(p.exitId)}n.push(` ${m}{"\u2713 Join"}`);for(let u of l)n.push(` ${u} --> ${m}`);n.push(" end");let b=e.state;return n.push(` class ${s} ${b}`),{entryId:h,exitId:m}}function Xe(e,r,n,c,d){let s=L("race"),h=`${s}_start`,m=`${s}_end`,g=ce(e.name??"Race");if(e.children.length===0){let u=s,p=O(g),f="operations not individually tracked",w=r.showTimings&&e.durationMs!==void 0?` ${W(e.durationMs)}`:"";return n.push(` ${u}["\u26A1 ${p}${w}\\n${f}"]:::${e.state}`),{entryId:u,exitId:u}}n.push(` subgraph ${s}["\u26A1 ${g}"]`),n.push(" direction TB"),n.push(` ${h}(("\u{1F3C1} Start"))`);let i=[],l;for(let u of e.children){let p=j(u,r,n,c,d),f=e.winnerId===u.id;n.push(` ${h} --> ${p.entryId}`),f&&(l=p.exitId),i.push({exitId:p.exitId,isWinner:f})}n.push(` ${m}(("\u2713 First"))`);for(let{exitId:u,isWinner:p}of i)p&&l?n.push(` ${u} ==>|\u{1F3C6} Winner| ${m}`):e.winnerId?n.push(` ${u} -. cancelled .-> ${m}`):n.push(` ${u} --> ${m}`);n.push(" end");let b=e.state;return n.push(` class ${s} ${b}`),{entryId:h,exitId:m}}function Qe(e,r,n,c,d){let s=e.key?`decision_${e.key.replace(/[^a-zA-Z0-9]/g,"_")}`:L("decision");if(K.has(s)){let u=2;for(;K.has(`${s}_${u}`);)u++;s=`${s}_${u}`}K.add(s);let h=O(e.condition??"condition"),m=e.decisionValue!==void 0?` = ${O(String(e.decisionValue)).slice(0,30)}`:"",g=`${h}${m}`.trim();n.push(` ${s}{"${g}"}`);let i=[],l,b=new Set;for(let u of e.branches){let p=`${s}_${u.label.replace(/[^a-zA-Z0-9]/g,"_")}`;if(b.has(p)){let x=2;for(;b.has(`${p}_${x}`);)x++;p=`${p}_${x}`}b.add(p);let f=O(u.label),w=u.taken?`${f} \u2713`:`${f} skipped`,S=u.taken?":::success":":::skipped";n.push(` ${p}["${w}"]${S}`);let R=u.condition?`|${O(u.condition).replace(/\|/g,"")}|`:"";if(n.push(` ${s} -->${R} ${p}`),u.children.length>0){let x=p;for(let k of u.children){let I=j(k,r,n,c,d);n.push(` ${x} --> ${I.entryId}`),x=I.exitId}i.push(x),u.taken&&(l=x)}else i.push(p),u.taken&&(l=p)}return l?{entryId:s,exitId:l}:{entryId:s,exitId:s}}function et(e,r,n){let c=`stream_${e.namespace.replace(/[^a-zA-Z0-9]/g,"_")}_${L("")}`,d=`W:${e.writeCount} R:${e.readCount}`,s="";switch(e.streamState){case"active":s="\u27F3 ";break;case"closed":s="\u2713 ";break;case"error":s="\u2717 ";break}let h=r.showTimings&&e.durationMs!==void 0?` ${W(e.durationMs)}`:"",m=e.backpressureOccurred?"\\nbackpressure":"",g=`${s}stream:${O(e.namespace)}\\n${d}${m}${h}`,i;return e.streamState==="error"?i="streamError":e.streamState==="active"?i="streamActive":i="stream",n.push(` ${c}{{"${g}"}}:::${i}`),{entryId:c,exitId:c}}var de=Ce(require("pako"),1),tt=typeof globalThis<"u"&&"Buffer"in globalThis&&typeof globalThis.Buffer=="function";function rt(e){let r;if(tt)r=globalThis.Buffer.from(e).toString("base64");else{let n="";for(let c=0;c<e.length;c++)n+=String.fromCharCode(e[c]);r=btoa(n)}return r.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}function V(e){let n=new TextEncoder().encode(e),c=de.default.deflate(n);return rt(c)}var nt="https://kroki.io";function ot(e,r,n,c={}){let d=c.baseUrl??nt,s=V(n);return`${d}/${e}/${r}/${s}`}function st(e,r="svg",n={}){let c=C(),d={showTimings:!0,showKeys:!1,terminalWidth:80,colors:_},s=c.render(e,d);return ot("mermaid",r,s,n)}function le(e,r={}){return st(e,"svg",r)}var it="https://mermaid.ink";function at(e){return`pako:${V(e)}`}function ct(e){if("provider"in e){let r=e;return{theme:r.mermaidTheme,bgColor:r.background,scale:r.scale,fit:r.fit,width:r.width,height:r.height,paper:r.paper,imageType:"png"}}return e}function dt(e,r){let n=[];return r.bgColor&&n.push(`bgColor=${encodeURIComponent(r.bgColor)}`),r.theme&&n.push(`theme=${r.theme}`),r.width!==void 0&&n.push(`width=${r.width}`),r.height!==void 0&&n.push(`height=${r.height}`),r.scale!==void 0&&(r.width!==void 0||r.height!==void 0)&&n.push(`scale=${r.scale}`),e==="img"&&r.imageType&&r.imageType!=="jpeg"&&n.push(`type=${r.imageType}`),e==="pdf"&&(r.fit&&n.push("fit"),r.paper&&!r.fit&&n.push(`paper=${r.paper}`),r.landscape&&!r.fit&&n.push("landscape")),n.length>0?`?${n.join("&")}`:""}function lt(e,r,n={}){let c=ct(n),d=c.baseUrl??it,s=at(r),h=dt(e,c);return`${d}/${e}/${s}${h}`}function ut(e,r="svg",n={}){let c=C(),d={showTimings:!0,showKeys:!1,terminalWidth:80,colors:_},s=c.render(e,d);return lt(r,s,n)}function ue(e,r={}){return ut(e,"svg",r)}function pe(e){return{getDiagramUrl(r){if(e.provider==="mermaid-ink"){let{provider:n,...c}=e;return ue(r,c)}return le(r,{baseUrl:e.baseUrl})},countSteps(r){return Z(r)},formatDuration(r){return r.root.endTs!==void 0&&r.root.startTs!==void 0?`${r.root.endTs-r.root.startTs}ms`:r.root.durationMs!==void 0?`${r.root.durationMs}ms`:"In progress"}}}var U=require("awaitly");function pt(e){for(let r of e)if((r.type==="parallel"||r.type==="race"||r.type==="sequence")&&!r.id.startsWith("detected_")||r.type==="decision")return!0;return!1}function fe(e,r={}){if(pt(e))return e;let{minOverlapMs:n=0,maxGapMs:c=5}=r,d=[],s=[];for(let i=0;i<e.length;i++){let l=e[i];l.type==="step"&&l.startTs!==void 0?d.push({node:l,startTs:l.startTs,endTs:l.endTs??l.startTs+(l.durationMs??0),originalIndex:i}):s.push({node:l,originalIndex:i})}if(d.length<=1)return e;d.sort((i,l)=>i.startTs-l.startTs);let h=[],m=[d[0]];for(let i=1;i<d.length;i++){let l=d[i],b=Math.min(...m.map(S=>S.startTs)),u=Math.max(...m.map(S=>S.endTs)),p=l.startTs<=b+c,f=l.startTs<u;if(!p&&!f){h.push(m),m=[l];continue}let w=f?Math.min(l.endTs,u)-l.startTs:0;p||w>=n?m.push(l):(h.push(m),m=[l])}h.push(m);let g=[];for(let i of h){let l=Math.min(...i.map(b=>b.originalIndex));if(i.length===1)g.push({node:i[0].node,position:l});else{let b=i.map(w=>w.node),u=Math.min(...i.map(w=>w.startTs)),p=Math.max(...i.map(w=>w.endTs)),f={type:"parallel",id:`detected_parallel_${u}`,name:`${b.length} parallel steps`,state:ft(b),mode:"all",children:b,startTs:u,endTs:p,durationMs:p-u};g.push({node:f,position:l})}}for(let{node:i,originalIndex:l}of s)g.push({node:i,position:l});return g.sort((i,l)=>i.position-l.position),g.map(i=>i.node)}function ft(e){return e.some(s=>s.state==="error")?"error":e.some(s=>s.state==="running")?"running":e.some(s=>s.state==="pending")?"pending":(e.every(s=>s.state==="success"||s.state==="cached"),"success")}function me(e={}){let{detectParallel:r=!0,parallelDetection:n,enableSnapshots:c=!1,maxSnapshots:d=1e3}=e,s=c,h=H(),m,g,i,l="pending",b,u,p=new Map,f=[],w=[],S=new Map,R=[],x=Date.now(),k=x,I={onAfterStep:new Map},T,y=[],N=0;function M(t){return t.stepId??t.stepKey??t.name??H()}function D(t){if(f.length>0){f[f.length-1].children.push(t),k=Date.now();return}if(w.length>0){let a=w[w.length-1];for(let o of a.branches.values())if(o.taken){o.children.push(t),k=Date.now();return}a.pendingChildren.push(t),k=Date.now();return}R.push(t),k=Date.now()}function we(t){if(!s)return;let a=J(),o=new Map;for(let[$,v]of p)o.set($,{id:v.id,name:v.name,key:v.key,startTs:v.startTs,retryCount:v.retryCount,timedOut:v.timedOut,timeoutMs:v.timeoutMs});let E={id:`snapshot_${N}`,eventIndex:N,event:structuredClone(t),ir:structuredClone(a),timestamp:Date.now(),activeSteps:o};y.push(E),y.length>d&&y.shift(),N++}function be(t){switch(t.type){case"workflow_start":{R=[],i=void 0,u=void 0,b=void 0,p.clear(),f.length=0,w.length=0,S.clear(),m=t.workflowId,g=t.ts,l="running",x=Date.now(),k=x,T!==void 0&&T!==t.workflowId&&(I.shouldRun=void 0,I.onBeforeStart=void 0),T=t.workflowId,I.onAfterStep=new Map;break}case"workflow_success":l="success",i=t.ts,u=t.durationMs,k=Date.now();break;case"workflow_error":l="error",i=t.ts,b=t.error,u=t.durationMs,k=Date.now();break;case"workflow_cancelled":l="aborted",i=t.ts,u=t.durationMs,k=Date.now();break;case"step_start":{let a=M(t);p.set(a,{id:a,name:t.name,key:t.stepKey,startTs:t.ts,retryCount:0,timedOut:!1}),k=Date.now();break}case"step_success":{let a=M(t),o=p.get(a);if(o){let E={type:"step",id:o.id,name:o.name,key:o.key,state:"success",startTs:o.startTs,endTs:t.ts,durationMs:t.durationMs,...o.retryCount>0&&{retryCount:o.retryCount},...o.timedOut&&{timedOut:!0,timeoutMs:o.timeoutMs}};D(E),p.delete(a)}break}case"step_error":{let a=M(t),o=p.get(a);if(o){let E={type:"step",id:o.id,name:o.name,key:o.key,state:"error",startTs:o.startTs,endTs:t.ts,durationMs:t.durationMs,error:t.error,...o.retryCount>0&&{retryCount:o.retryCount},...o.timedOut&&{timedOut:!0,timeoutMs:o.timeoutMs}};D(E),p.delete(a)}break}case"step_aborted":{let a=M(t),o=p.get(a);if(o){let E={type:"step",id:o.id,name:o.name,key:o.key,state:"aborted",startTs:o.startTs,endTs:t.ts,durationMs:t.durationMs,...o.retryCount>0&&{retryCount:o.retryCount},...o.timedOut&&{timedOut:!0,timeoutMs:o.timeoutMs}};D(E),p.delete(a)}break}case"step_cache_hit":{let o={type:"step",id:M(t),name:t.name,key:t.stepKey,state:"cached",startTs:t.ts,endTs:t.ts,durationMs:0};D(o);break}case"step_cache_miss":break;case"step_complete":break;case"step_timeout":{let a=M(t),o=p.get(a);o&&(o.timedOut=!0,o.timeoutMs=t.timeoutMs),k=Date.now();break}case"step_retry":{let a=M(t),o=p.get(a);o&&(o.retryCount=(t.attempt??1)-1),k=Date.now();break}case"step_retries_exhausted":k=Date.now();break;case"step_skipped":{let o={type:"step",id:M(t),name:t.name,key:t.stepKey,state:"skipped",startTs:t.ts,endTs:t.ts,durationMs:0};D(o);break}case"hook_should_run":{let a={type:"shouldRun",state:"success",ts:t.ts,durationMs:t.durationMs,context:{result:t.result,skipped:t.skipped}};I.shouldRun=a,T=t.workflowId,k=Date.now();break}case"hook_should_run_error":{let a={type:"shouldRun",state:"error",ts:t.ts,durationMs:t.durationMs,error:t.error};I.shouldRun=a,T=t.workflowId,k=Date.now();break}case"hook_before_start":{let a={type:"onBeforeStart",state:"success",ts:t.ts,durationMs:t.durationMs,context:{result:t.result,skipped:t.skipped}};I.onBeforeStart=a,T=t.workflowId,k=Date.now();break}case"hook_before_start_error":{let a={type:"onBeforeStart",state:"error",ts:t.ts,durationMs:t.durationMs,error:t.error};I.onBeforeStart=a,T=t.workflowId,k=Date.now();break}case"hook_after_step":{let a={type:"onAfterStep",state:"success",ts:t.ts,durationMs:t.durationMs,context:{stepKey:t.stepKey}};I.onAfterStep.set(t.stepKey,a),k=Date.now();break}case"hook_after_step_error":{let a={type:"onAfterStep",state:"error",ts:t.ts,durationMs:t.durationMs,error:t.error,context:{stepKey:t.stepKey}};I.onAfterStep.set(t.stepKey,a),k=Date.now();break}case"stream_created":{let a=`${t.workflowId}:${t.namespace}`;S.set(a,{id:H(),namespace:t.namespace,startTs:t.ts,writeCount:0,readCount:0,streamState:"active",backpressureOccurred:!1,finalPosition:0}),k=Date.now();break}case"stream_write":{let a=`${t.workflowId}:${t.namespace}`,o=S.get(a);o&&(o.writeCount++,o.finalPosition=Math.max(o.finalPosition,t.position)),k=Date.now();break}case"stream_read":{let a=`${t.workflowId}:${t.namespace}`,o=S.get(a);o&&o.readCount++,k=Date.now();break}case"stream_close":{let a=`${t.workflowId}:${t.namespace}`,o=S.get(a);if(o){o.streamState="closed",o.finalPosition=t.finalPosition;let E={type:"stream",id:o.id,namespace:o.namespace,state:"success",startTs:o.startTs,endTs:t.ts,durationMs:t.ts-o.startTs,writeCount:o.writeCount,readCount:o.readCount,finalPosition:t.finalPosition,streamState:"closed",backpressureOccurred:o.backpressureOccurred};D(E),S.delete(a)}k=Date.now();break}case"stream_error":{let a=`${t.workflowId}:${t.namespace}`,o=S.get(a);if(o){o.streamState="error";let E={type:"stream",id:o.id,namespace:o.namespace,state:"error",error:t.error,startTs:o.startTs,endTs:t.ts,durationMs:t.ts-o.startTs,writeCount:o.writeCount,readCount:o.readCount,finalPosition:t.position,streamState:"error",backpressureOccurred:o.backpressureOccurred};D(E),S.delete(a)}k=Date.now();break}case"stream_backpressure":{let a=`${t.workflowId}:${t.namespace}`,o=S.get(a);o&&(o.backpressureOccurred=!0),k=Date.now();break}}we(t)}function ye(t){if(t.type==="scope_start")f.push({id:t.scopeId,name:t.name,type:t.scopeType,startTs:t.ts,children:[]}),k=Date.now();else if(t.type==="scope_end"){let a=f.findIndex($=>$.id===t.scopeId);if(a===-1)return;for(;f.length>a+1;){let $=f.pop(),v=$.type==="race"?{type:"race",id:$.id,name:$.name,state:A($.children),startTs:$.startTs,endTs:t.ts,children:$.children}:{type:"parallel",id:$.id,name:$.name,state:A($.children),startTs:$.startTs,endTs:t.ts,children:$.children,mode:$.type==="allSettled"?"allSettled":"all"};f[f.length-1].children.push(v)}let[o]=f.splice(a,1),E=o.type==="race"?{type:"race",id:o.id,name:o.name,state:A(o.children),startTs:o.startTs,endTs:t.ts,durationMs:t.durationMs,children:o.children,winnerId:t.winnerId}:{type:"parallel",id:o.id,name:o.name,state:A(o.children),startTs:o.startTs,endTs:t.ts,durationMs:t.durationMs,children:o.children,mode:o.type==="allSettled"?"allSettled":"all"};D(E)}}function Se(t){if(t.type==="decision_start")w.push({id:t.decisionId,name:t.name,condition:t.condition,decisionValue:t.decisionValue,startTs:t.ts,branches:new Map,pendingChildren:[]}),k=Date.now();else if(t.type==="decision_branch"){let a=w.find(o=>o.id===t.decisionId);if(a){let o=t.branchLabel,E=a.branches.get(o);if(E)E.taken=t.taken,t.taken&&a.pendingChildren.length>0&&(E.children.unshift(...a.pendingChildren),a.pendingChildren=[]);else{let $=t.taken?[...a.pendingChildren]:[];t.taken&&(a.pendingChildren=[]),a.branches.set(o,{label:t.branchLabel,condition:t.condition,taken:t.taken,children:$})}k=Date.now()}}else if(t.type==="decision_end"){let a=w.findIndex(o=>o.id===t.decisionId);if(a!==-1){let[o]=w.splice(a,1),E=w.splice(a),$=Array.from(o.branches.values());$.length===0&&o.pendingChildren.length>0&&($=[{label:"default",taken:!0,children:[...o.pendingChildren]}]);let v=$.find(F=>F.taken)?.label,Ee={type:"decision",id:o.id,name:o.name,state:A($.flatMap(F=>F.taken?F.children:[])),startTs:o.startTs,endTs:t.ts,durationMs:t.durationMs,condition:o.condition,decisionValue:o.decisionValue,branchTaken:t.branchTaken??v,branches:$};D(Ee),w.push(...E),k=Date.now()}}}function A(t){return t.length===0?"success":t.some($=>$.state==="error")?"error":t.every($=>$.state==="success"||$.state==="cached")?"success":t.some($=>$.state==="running")?"running":"pending"}function $e(){let t=[...R];for(let[,a]of p)t.push({type:"step",id:a.id,name:a.name,key:a.key,state:"running",startTs:a.startTs,...a.retryCount>0&&{retryCount:a.retryCount},...a.timedOut&&{timedOut:!0,timeoutMs:a.timeoutMs}});for(let[,a]of S)t.push({type:"stream",id:a.id,namespace:a.namespace,state:"running",startTs:a.startTs,writeCount:a.writeCount,readCount:a.readCount,finalPosition:a.finalPosition,streamState:a.streamState,backpressureOccurred:a.backpressureOccurred});return t}function J(){let t=$e();r&&(t=fe(t,n));let a={type:"workflow",id:m??h,workflowId:m??h,state:l,startTs:g,endTs:i,durationMs:u,children:t,error:b},o=I.shouldRun!==void 0||I.onBeforeStart!==void 0||I.onAfterStep.size>0;return{root:a,metadata:{createdAt:x,lastUpdatedAt:k},...o&&{hooks:I}}}function xe(){m=void 0,g=void 0,i=void 0,l="pending",b=void 0,u=void 0,p.clear(),f.length=0,w.length=0,S.clear(),R=[],x=Date.now(),k=x,I={onAfterStep:new Map},T=void 0,y.length=0,N=0}function Re(){return[...y]}function Ie(t){return y[t]}function Ne(t){return y[t]?.ir}function Me(){y.length=0,N=0}return{handleEvent:be,handleScopeEvent:ye,handleDecisionEvent:Se,getIR:J,reset:xe,getSnapshots:Re,getSnapshotAt:Ie,getIRAt:Ne,clearSnapshots:Me,get hasActiveSteps(){return p.size>0},get state(){return l},get snapshotCount(){return y.length},get snapshotsEnabled(){return s},setSnapshotsEnabled(t){s=t}}}var mt=500,gt=5e3;function ge(e,r){let{title:n,debounceMs:c=mt,maxWaitMs:d=gt}=e,s,h=!0,m,g,i,l,b,u,p=(0,U.ok)(void 0),f=me({detectParallel:!0});function w(){i&&(clearTimeout(i),i=void 0),l&&(clearTimeout(l),l=void 0)}async function S(){if(!m||!h)return(0,U.ok)(void 0);let N=m;g=N,m=void 0,w();try{return s?await r.updateExisting(s,N,n):s=await r.postNew(N,n),b=Date.now(),p=(0,U.ok)(void 0),p}catch{return p=(0,U.err)("CALLBACK_ERROR"),p}}function R(){i&&clearTimeout(i),i=setTimeout(()=>{S()},c);let N=b??u;if(!l&&N!==void 0){let M=Date.now()-N,D=Math.max(0,d-M);l=setTimeout(()=>{l=void 0,S()},D)}}function x(N){if(h){if(u===void 0&&(u=Date.now()),"root"in N)m=N,g=N;else{let M=N;M.type==="scope_start"||M.type==="scope_end"?f.handleScopeEvent(M):M.type==="decision_start"||M.type==="decision_branch"||M.type==="decision_end"?f.handleDecisionEvent(M):f.handleEvent(M),m=f.getIR(),g=m}R()}}async function k(N="completed"){if(!h)return;h=!1,w();let M=m??g??f.getIR();await r.finalize(s,M,n,N)}function I(){h&&(h=!1,w(),s&&r.cancel&&r.cancel(s))}function T(){return s}function y(){return h}return{update:x,finalize:k,cancel:I,getSessionId:T,isActive:y}}function ht(e){switch(e.root.state){case"success":return"completed";case"error":return"failed";case"aborted":return"cancelled";default:return"running"}}function he(e,r){let{diagramProvider:n,debounceMs:c=500,maxWaitMs:d=5e3}=e;if(!n)throw new Error(`${r.name}Notifier: diagramProvider is required. Pass { provider: 'kroki' } or { provider: 'mermaid-ink' }.`);let s=pe(n);async function h(g,i={}){let l=i.title??"Workflow",b=ht(g);try{let u=r.buildMessage({ir:g,title:l,status:b},s),p=await r.sendNew(u);return(0,q.ok)(p?.toString())}catch{return(0,q.err)("SEND_FAILED")}}function m(g){return ge({...g,debounceMs:g.debounceMs??c,maxWaitMs:g.maxWaitMs??d},{async postNew(i,l){let b=r.buildMessage({ir:i,title:l,status:"running"},s);return(await r.sendNew(b))?.toString()},async updateExisting(i,l,b){let u=r.buildMessage({ir:l,title:b,status:"running"},s);await r.sendUpdate(i,u)},async finalize(i,l,b,u){let p=r.buildMessage({ir:l,title:b,status:u},s);i?await r.sendUpdate(i,p):await r.sendNew(p)},async cancel(i){r.sendCancel&&i&&await r.sendCancel(i)}})}return{notify:h,createLive:m,getType:()=>r.name.toLowerCase()}}var P=require("awaitly");function ke(e){let{url:r,headers:n={},timeout:c=3e4,includeMermaid:d=!1,includeKrokiUrl:s,includeDiagramUrl:h=s??!0,providerName:m="kroki",metadata:g}=e,i=C(),l={showTimings:!0,showKeys:!1,terminalWidth:80,colors:_},b=0;async function u(f){let w=new AbortController,S=setTimeout(()=>w.abort(),c);try{let R=await fetch(r,{method:"POST",headers:{"Content-Type":"application/json",...n},body:JSON.stringify(f),signal:w.signal});if(!R.ok)return(0,P.err)("SEND_FAILED");try{let x=await R.json();return(0,P.ok)(x.messageId??x.id??f.messageId??"")}catch{return(0,P.ok)(f.messageId??"")}}catch(R){return R instanceof Error&&R.name==="AbortError"?(0,P.err)("TIMEOUT"):(0,P.err)("SEND_FAILED")}finally{clearTimeout(S)}}function p(){return`webhook-${++b}-${Date.now()}`}return{name:"Webhook",buildMessage({ir:f,title:w,status:S},R){let x;S==="running"?x="workflow.update":x="workflow.complete";let k={event:x,timestamp:new Date().toISOString(),title:w,status:S,ir:f,metadata:g};if(h){let I=R.getDiagramUrl(f);k.diagramUrl=I,k.diagramProvider=m,k.krokiUrl=I}return d&&(k.mermaid=i.render(f,l)),{payload:k}},async sendNew(f){let{payload:w}=f,S=p();w.messageId=S;let R=await u(w);if(!R.ok)throw new Error(`Webhook send failed: ${R.error}`);return S},async sendUpdate(f,w){let{payload:S}=w;S.messageId=f;let R=await u(S);if(!R.ok)throw new Error(`Webhook update failed: ${R.error}`)}}}function kt(e){let{url:r,headers:n,timeout:c,includeMermaid:d,includeKrokiUrl:s,includeDiagramUrl:h,diagramProvider:m,...g}=e,i=ke({url:r,headers:n,timeout:c,includeMermaid:d,includeKrokiUrl:s,includeDiagramUrl:h,providerName:m?.provider??"kroki"});return he({...g,diagramProvider:m},i)}0&&(module.exports={createWebhookNotifier});
|
|
3
|
+
//# sourceMappingURL=webhook.cjs.map
|