@uploadista/observability 0.0.8 → 0.0.9
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.cjs +1 -1
- package/dist/index.d.cts +50 -50
- package/dist/index.d.cts.map +1 -1
- package/dist/{index.d.ts → index.d.mts} +51 -51
- package/dist/index.d.mts.map +1 -0
- package/dist/{index.js → index.mjs} +1 -1
- package/dist/index.mjs.map +1 -0
- package/package.json +6 -6
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
package/dist/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var e=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,r=Object.getOwnPropertyNames,i=Object.getPrototypeOf,a=Object.prototype.hasOwnProperty,o=(e,i,o,s)=>{if(i&&typeof i==`object`||typeof i==`function`)for(var c=r(i),l=0,u=c.length,d;l<u;l++)d=c[l],!a.call(e,d)&&d!==o&&t(e,d,{get:(e=>i[e]).bind(null,d),enumerable:!(s=n(i,d))||s.enumerable});return e},s=(n,r,a)=>(a=n==null?{}:e(i(n)),o(r||!n||!n.__esModule?t(a,`default`,{value:n,enumerable:!0}):a,n));let c=require(`effect`);c=s(c);let l=require(`@effect/opentelemetry`);l=s(l);let u=require(`@opentelemetry/sdk-trace-base`);u=s(u);const d=e=>{if(!e||typeof e!=`object`)return`unknown_error`;let t=`code`in e?e.code:void 0,n=`name`in e?e.name:void 0,r=e instanceof Error?e.message.toLowerCase():``;return t===`NetworkError`||t===`ECONNRESET`||t===`ENOTFOUND`||t===`ETIMEDOUT`||r.indexOf(`network`)>=0||r.indexOf(`timeout`)>=0?`network_error`:t===`InvalidAccessKeyId`||t===`SignatureDoesNotMatch`||t===`TokenRefreshRequired`||t===`AuthenticationFailed`||n===`AuthenticationError`||r.indexOf(`authentication`)>=0||r.indexOf(`unauthorized`)>=0?`authentication_error`:t===`AccessDenied`||t===`AccountProblem`||t===`Forbidden`||n===`AuthorizationError`||r.indexOf(`forbidden`)>=0||r.indexOf(`permission`)>=0?`authorization_error`:t===`SlowDown`||t===`RequestTimeTooSkewed`||t===`TooManyRequests`||n===`ThrottlingError`||r.indexOf(`throttl`)>=0||r.indexOf(`rate limit`)>=0?`throttling_error`:t===`InternalError`||t===`ServiceUnavailable`||t===`InternalServerError`||n===`ServerError`||r.indexOf(`server error`)>=0||r.indexOf(`service unavailable`)>=0?`server_error`:t===`InvalidRequest`||t===`MalformedXML`||t===`RequestEntityTooLarge`||t===`BadRequest`||n===`ClientError`||r.indexOf(`bad request`)>=0||r.indexOf(`invalid`)>=0?`client_error`:`unknown_error`},ee=(e,t)=>e=>{if(t){let n=t(e);if(n!==null)return n}return d(e)},te=(e,t,n,r,i={},a=d)=>c.Effect.gen(function*(){let o=a(r);yield*t.uploadErrorsTotal.pipe(c.Metric.tagged(`operation`,n),c.Metric.tagged(`error_category`,o))(c.Effect.succeed(1));let s={storage_type:e,operation:n,error_category:o,error_type:typeof r,error_message:r instanceof Error?r.message:String(r),error_code:r&&typeof r==`object`&&`code`in r?r.code:void 0,error_name:r&&typeof r==`object`&&`name`in r?r.name:void 0,...i};yield*c.Effect.logError(`${e.toUpperCase()} ${n} failed`).pipe(c.Effect.annotateLogs(s))}),f=(e,t,n)=>{let r=ee(e,n);return(n,i,a={})=>te(e,t,n,i,a,r)};var p=class extends c.Context.Tag(`Observability`)(){},m=class extends c.Context.Tag(`StorageObservability`)(){},h=class extends c.Context.Tag(`UploadObservability`)(){},g=class extends c.Context.Tag(`FlowObservability`)(){};const ne=(e,t=!0)=>c.Layer.succeed(p,{serviceName:e,enabled:t}),re=(e,t,n=!0)=>c.Layer.succeed(m,{serviceName:`uploadista-${e}-store`,storageType:e,metrics:t,enabled:n}),_=(e=!0)=>c.Layer.succeed(h,{serviceName:`uploadista-upload-server`,enabled:e,metrics:{uploadCreated:c.Effect.void,uploadCompleted:c.Effect.void,uploadFailed:c.Effect.void,chunkUploaded:c.Effect.void}}),v=(e=!0)=>c.Layer.succeed(g,{serviceName:`uploadista-flow-engine`,enabled:e,metrics:{flowStarted:c.Effect.void,flowCompleted:c.Effect.void,flowFailed:c.Effect.void,nodeExecuted:c.Effect.void}}),ie=ne(`uploadista-disabled`,!1),ae=e=>re(e,{},!1),oe=_(!1),se=v(!1),y=c.Effect.gen(function*(){let e=yield*c.Effect.serviceOption(p);return c.Option.match(e,{onNone:()=>!1,onSome:e=>e.enabled})}),ce=e=>c.Effect.gen(function*(){if(yield*y){let t=yield*e;return c.Option.some(t)}return c.Option.none()}),b=(e,t)=>c.Effect.log(e).pipe(c.Effect.annotateLogs(t)),x=(e,t,n)=>b(`Upload progress`,{storage_type:e,upload_id:t,uploaded_bytes:n.uploadedBytes,total_bytes:n.totalBytes,progress_percentage:Math.round(n.uploadedBytes/n.totalBytes*100),...n.partNumber&&{part_number:n.partNumber},...n.speed&&{upload_speed_bps:n.speed}}),S=(e,t,n,r)=>b(`${e.toUpperCase()} ${t}`,{storage_type:e,operation:t,upload_id:n,...r}),C=(e,t,n)=>{let r=n.throughputBps?n.throughputBps/(1024*1024):0;return b(`${e.toUpperCase()} upload completed`,{storage_type:e,upload_id:t,file_size_bytes:n.fileSize,file_size_mb:Math.round(n.fileSize/(1024*1024)*100)/100,total_duration_ms:n.totalDurationMs,total_duration_seconds:Math.round(n.totalDurationMs/1e3*100)/100,throughput_bps:n.throughputBps,throughput_mbps:Math.round(r*100)/100,...n.partsCount&&{parts_count:n.partsCount},...n.averagePartSize&&{average_part_size_bytes:n.averagePartSize,average_part_size_mb:Math.round(n.averagePartSize/(1024*1024)*100)/100},...n.retryCount&&{retry_count:n.retryCount}})},w=e=>({uploadRequestsTotal:c.Metric.counter(`${e}_upload_requests_total`,{description:`Total number of upload requests for ${e}`}),uploadPartsTotal:c.Metric.counter(`${e}_upload_parts_total`,{description:`Total number of individual parts uploaded for ${e}`}),uploadSuccessTotal:c.Metric.counter(`${e}_upload_success_total`,{description:`Total number of successful uploads for ${e}`}),uploadErrorsTotal:c.Metric.counter(`${e}_upload_errors_total`,{description:`Total number of upload errors for ${e}`}),apiCallsTotal:c.Metric.counter(`${e}_api_calls_total`,{description:`Total number of API calls for ${e}`})}),T=e=>({uploadDurationHistogram:c.Metric.histogram(`${e}_upload_duration_seconds`,c.MetricBoundaries.exponential({start:.01,factor:2,count:20}),`Duration of upload operations in seconds for ${e}`),partUploadDurationHistogram:c.Metric.histogram(`${e}_part_upload_duration_seconds`,c.MetricBoundaries.exponential({start:.001,factor:2,count:15}),`Duration of individual part uploads in seconds for ${e}`),fileSizeHistogram:c.Metric.histogram(`${e}_file_size_bytes`,c.MetricBoundaries.exponential({start:1024,factor:2,count:25}),`Size of uploaded files in bytes for ${e}`),partSizeHistogram:c.Metric.histogram(`${e}_part_size_bytes`,c.MetricBoundaries.linear({start:5242880,width:1048576,count:20}),`Size of upload parts in bytes for ${e}`)}),le=e=>({activeUploadsGauge:c.Metric.gauge(`${e}_active_uploads`,{description:`Number of currently active uploads for ${e}`}),uploadThroughputGauge:c.Metric.gauge(`${e}_upload_throughput_bytes_per_second`,{description:`Current upload throughput in bytes per second for ${e}`})}),ue=e=>({uploadLatencySummary:c.Metric.summary({name:`${e}_upload_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Upload latency percentiles for ${e}`})}),E=e=>({...w(e),...T(e),...le(e),...ue(e)}),D=e=>{let t=E(e),n={serviceName:`test-${e}-store`,storageType:e,metrics:t,enabled:!0};return c.Layer.succeed(m,n)},O=()=>{let e={serviceName:`test-upload-server`,enabled:!0,metrics:{uploadCreated:c.Effect.void,uploadCompleted:c.Effect.void,uploadFailed:c.Effect.void,chunkUploaded:c.Effect.void}};return c.Layer.succeed(h,e)},k=()=>{let e={serviceName:`test-flow-engine`,enabled:!0,metrics:{flowStarted:c.Effect.void,flowCompleted:c.Effect.void,flowFailed:c.Effect.void,nodeExecuted:c.Effect.void}};return c.Layer.succeed(g,e)},de=e=>c.Effect.gen(function*(){let t=yield*e;return yield*c.Metric.snapshot,t}),fe=e=>c.Effect.gen(function*(){yield*c.Metric.snapshot;let t=yield*e;return yield*c.Metric.snapshot,t}),A=(e=`test-storage`)=>({storageObservability:D(e),uploadObservability:O(),flowObservability:k()}),pe=(e,t=`test-storage`)=>{let n=A(t);return e.pipe(c.Effect.provide(n.storageObservability),c.Effect.provide(n.uploadObservability),c.Effect.provide(n.flowObservability))},me=c.Context.GenericTag(`TracingService`),he=e=>{let t=e?.serviceName??`uploadista-storage`;return c.Layer.succeed(me,{serviceName:t})},j=e=>he({serviceName:`uploadista-${e}-store`}),M=(e,t,n)=>r=>r.pipe(c.Effect.withSpan(`${t}-${e}`,{attributes:{"storage.type":t,operation:e,...n}})),ge=l.WebSdk.layer(()=>({resource:{serviceName:`uploadista-storage`},spanProcessor:new u.BatchSpanProcessor(new u.ConsoleSpanExporter)})),_e=l.NodeSdk.layer(()=>({resource:{serviceName:`uploadista-storage`},spanProcessor:new u.BatchSpanProcessor(new u.ConsoleSpanExporter)})),ve=l.WebSdk.layer(()=>({resource:{serviceName:`uploadista-storage-workers`},spanProcessor:new u.BatchSpanProcessor(new u.ConsoleSpanExporter)})),N=(e,t,n)=>n.pipe(c.Effect.tap(()=>e.uploadRequestsTotal.pipe(c.Metric.tagged(`upload_id`,t))(c.Effect.succeed(1))),c.Effect.tapError(()=>e.uploadErrorsTotal.pipe(c.Metric.tagged(`upload_id`,t))(c.Effect.succeed(1))),c.Effect.tap(()=>e.uploadSuccessTotal.pipe(c.Metric.tagged(`upload_id`,t))(c.Effect.succeed(1)))),P=(e,t,n)=>n.pipe(c.Effect.tap(()=>e.apiCallsTotal.pipe(c.Metric.tagged(`operation`,t))(c.Effect.succeed(1)))),F=(e,t)=>c.Effect.gen(function*(){let n=yield*c.Effect.sync(()=>Date.now()),r=yield*t,i=((yield*c.Effect.sync(()=>Date.now()))-n)/1e3;return yield*e(c.Effect.succeed(i)),r}),I=(e,t,n)=>n.pipe(c.Effect.tap(()=>e.fileSizeHistogram(c.Effect.succeed(t)))),ye=(e,t,n)=>n.pipe(c.Effect.tap(()=>e.partSizeHistogram(c.Effect.succeed(t)))),L=(e,t)=>t.pipe(c.Effect.tap(()=>e.activeUploadsGauge(c.Effect.succeed(1))),c.Effect.ensuring(e.activeUploadsGauge(c.Effect.succeed(-1)))),R=(e,t,n)=>c.Effect.gen(function*(){let r=yield*c.Effect.sync(()=>Date.now()),i=yield*n,a=((yield*c.Effect.sync(()=>Date.now()))-r)/1e3,o=a>0?t/a:0;return yield*e.uploadThroughputGauge(c.Effect.succeed(o)),i}),z=(e,t,n,r,i)=>{let a=r.pipe(n=>P(e,t,n),t=>N(e,n,t),t=>F(e.uploadDurationHistogram,t),t=>L(e,t));return i!==void 0&&(a=a.pipe(t=>I(e,i,t),t=>R(e,i,t))),a},B=()=>({flowStartedTotal:c.Metric.counter(`flow_started_total`,{description:`Total number of flows started`}),flowCompletedTotal:c.Metric.counter(`flow_completed_total`,{description:`Total number of flows completed successfully`}),flowFailedTotal:c.Metric.counter(`flow_failed_total`,{description:`Total number of flows that failed`}),flowPausedTotal:c.Metric.counter(`flow_paused_total`,{description:`Total number of flows that were paused`}),flowResumedTotal:c.Metric.counter(`flow_resumed_total`,{description:`Total number of flows that were resumed`}),nodeExecutedTotal:c.Metric.counter(`node_executed_total`,{description:`Total number of nodes executed`}),nodeSuccessTotal:c.Metric.counter(`node_success_total`,{description:`Total number of nodes executed successfully`}),nodeFailedTotal:c.Metric.counter(`node_failed_total`,{description:`Total number of nodes that failed`}),nodeSkippedTotal:c.Metric.counter(`node_skipped_total`,{description:`Total number of nodes skipped (conditional)`}),flowDurationHistogram:c.Metric.histogram(`flow_duration_seconds`,c.MetricBoundaries.exponential({start:.1,factor:2,count:20}),`Duration of complete flow execution in seconds`),nodeDurationHistogram:c.Metric.histogram(`node_duration_seconds`,c.MetricBoundaries.exponential({start:.01,factor:2,count:18}),`Duration of individual node execution in seconds`),flowNodeCountHistogram:c.Metric.histogram(`flow_node_count`,c.MetricBoundaries.linear({start:1,width:5,count:20}),`Number of nodes in a flow`),parallelNodesHistogram:c.Metric.histogram(`parallel_nodes_count`,c.MetricBoundaries.linear({start:1,width:2,count:15}),`Number of nodes executed in parallel`),activeFlowsGauge:c.Metric.gauge(`active_flows`,{description:`Number of currently active flows`}),activeNodesGauge:c.Metric.gauge(`active_nodes`,{description:`Number of currently executing nodes`}),pausedFlowsGauge:c.Metric.gauge(`paused_flows`,{description:`Number of currently paused flows`}),flowLatencySummary:c.Metric.summary({name:`flow_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Flow execution latency percentiles`}),nodeLatencySummary:c.Metric.summary({name:`node_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Node execution latency percentiles`})}),be=B(),xe=(e,t)=>n=>n.pipe(c.Effect.withSpan(`flow-${e}`,{attributes:{"flow.operation":e,...t}})),Se=e=>c.Effect.annotateCurrentSpan({"flow.id":e.flowId??`unknown`,"flow.name":e.flowName??`unknown`,"flow.job_id":e.jobId??`unknown`,"flow.node_count":e.nodeCount?.toString()??`0`,"flow.storage_id":e.storageId??`unknown`}),Ce=e=>c.Effect.annotateCurrentSpan({"node.id":e.nodeId,"node.type":e.nodeType,"node.name":e.nodeName??`unknown`,"node.flow_id":e.flowId??`unknown`,"node.job_id":e.jobId??`unknown`}),we=e=>c.Effect.annotateCurrentSpan({"execution.order":e.executionOrder?.join(`,`)??``,"execution.current_index":e.currentIndex?.toString()??`0`,"execution.total_nodes":e.totalNodes?.toString()??`0`,"execution.parallel_count":e.parallelCount?.toString()??`0`}),V=(e=`uploadista-flow-engine`)=>{let t=B();return c.Layer.succeed(g,{serviceName:e,enabled:!0,metrics:{flowStarted:c.Metric.increment(t.flowStartedTotal),flowCompleted:c.Metric.increment(t.flowCompletedTotal),flowFailed:c.Metric.increment(t.flowFailedTotal),nodeExecuted:c.Metric.increment(t.nodeExecutedTotal)}})},Te=V(),Ee=v(!1),De=c.Effect.gen(function*(){return(yield*g).metrics}),Oe=e=>{let t=B();return c.Effect.gen(function*(){let n=Date.now(),r=yield*e,i=(Date.now()-n)/1e3;return yield*c.Metric.update(t.flowDurationHistogram,i),yield*c.Metric.update(t.flowLatencySummary,i),r}).pipe(c.Effect.withSpan(`flow-execution`))},ke=(e,t,n)=>{let r=B();return c.Effect.gen(function*(){let e=Date.now(),t=yield*n,i=(Date.now()-e)/1e3;return yield*c.Metric.update(r.nodeDurationHistogram,i),yield*c.Metric.update(r.nodeLatencySummary,i),t}).pipe(c.Effect.withSpan(`node-${t}`,{attributes:{"node.id":e,"node.type":t}}))},Ae=e=>{let t=B();return c.Effect.gen(function*(){return yield*c.Metric.increment(t.activeFlowsGauge),yield*c.Effect.acquireUseRelease(c.Effect.void,()=>e,()=>c.Metric.set(t.activeFlowsGauge,-1))})},je=e=>{let t=B();return c.Effect.gen(function*(){return yield*c.Metric.increment(t.activeNodesGauge),yield*c.Effect.acquireUseRelease(c.Effect.void,()=>e,()=>c.Metric.set(t.activeNodesGauge,-1))})},H=e=>{if(!e||typeof e!=`object`)return`unknown_flow_error`;let t=`code`in e?e.code:void 0;if(!t)return`unknown_flow_error`;switch(t){case`FLOW_VALIDATION_ERROR`:case`FLOW_INVALID_INPUT`:case`FLOW_INVALID_OUTPUT`:return`flow_validation_error`;case`FLOW_NODE_NOT_FOUND`:case`FLOW_EDGE_INVALID`:return`node_not_found_error`;case`FLOW_NODE_EXECUTION_FAILED`:case`FLOW_NODE_ERROR`:return`node_execution_error`;case`FLOW_TIMEOUT`:return`flow_timeout_error`;case`FLOW_CANCELLED`:case`ABORTED`:return`flow_cancelled_error`;default:return`unknown_flow_error`}},Me=e=>{let t=B(),n=H(e);return c.Effect.gen(function*(){yield*c.Metric.increment(t.flowFailedTotal),yield*c.Effect.logError(`Flow execution failed`).pipe(c.Effect.annotateLogs({"error.category":n,"error.message":String(e)}))})},Ne=(e,t,n)=>{let r=B(),i=H(n);return c.Effect.gen(function*(){yield*c.Metric.increment(r.nodeFailedTotal),yield*c.Effect.logError(`Node execution failed`).pipe(c.Effect.annotateLogs({"node.id":e,"node.type":t,"error.category":i,"error.message":String(n)}))})},U=()=>{let e={serviceName:`test-flow-engine`,enabled:!0,metrics:{flowStarted:c.Effect.void,flowCompleted:c.Effect.void,flowFailed:c.Effect.void,nodeExecuted:c.Effect.void}};return c.Layer.succeed(g,e)},Pe=e=>e.pipe(c.Effect.provide(U()));var W=class extends c.Context.Tag(`MetricsService`)(){};const Fe=c.Layer.succeed(W,{recordUpload:(e,t)=>c.Effect.void}),Ie=`s3`,G=E(`s3`),K=j(`s3`),Le=e=>{if(!e||typeof e!=`object`)return null;let t=`code`in e?e.code:void 0;if(!t)return null;switch(t){case`NoSuchKey`:case`NoSuchBucket`:case`NoSuchUpload`:return`client_error`;case`BucketAlreadyExists`:case`BucketNotEmpty`:return`client_error`;case`InvalidBucketName`:case`InvalidPart`:case`InvalidPartOrder`:return`client_error`;case`EntityTooSmall`:case`EntityTooLarge`:return`client_error`;case`ExpiredToken`:case`TokenRefreshRequired`:return`authentication_error`;case`RequestTimeTooSkewed`:case`SlowDown`:return`throttling_error`;default:return null}},Re=f(`s3`,G,Le),ze=c.Layer.mergeAll(K),Be=(e,t)=>N(G,e,t),Ve=(e,t)=>P(G,e,t),He=F,Ue=(e,t,n,r)=>z(G,e,t,n,r),We=(e,t)=>n=>M(e,`s3`,t)(n),Ge=S.bind(null,`s3`),Ke=x.bind(null,`s3`),qe=C.bind(null,`s3`),Je=b,{uploadRequestsTotal:Ye,uploadPartsTotal:Xe,uploadSuccessTotal:Ze,uploadErrorsTotal:Qe,apiCallsTotal:$e,uploadDurationHistogram:et,partUploadDurationHistogram:tt,fileSizeHistogram:nt,partSizeHistogram:rt,activeUploadsGauge:it,uploadThroughputGauge:at,uploadLatencySummary:ot}=G,q=`azure`,J=E(q),st=j(q),ct=e=>{if(!e||typeof e!=`object`)return null;let t=`code`in e?e.code:`statusCode`in e?e.statusCode:void 0;if(!t)return null;switch(t){case`BlobNotFound`:case`ContainerNotFound`:case`InvalidBlobOrBlock`:return`client_error`;case`ContainerAlreadyExists`:case`BlobAlreadyExists`:return`client_error`;case`InvalidBlockId`:case`InvalidBlockList`:case`InvalidBlobType`:return`client_error`;case`RequestBodyTooLarge`:case`InvalidHeaderValue`:return`client_error`;case`AuthenticationFailed`:case`InvalidAuthenticationInfo`:return`authentication_error`;case`AccountIsDisabled`:return`authorization_error`;case`InsufficientAccountPermissions`:return`authorization_error`;case`OperationTimedOut`:case`ServerBusy`:case`InternalError`:return`server_error`;default:if(typeof t==`number`){if(t>=500)return`server_error`;if(t===429)return`throttling_error`;if(t===403)return`authorization_error`;if(t===401)return`authentication_error`;if(t>=400)return`client_error`}return null}},lt=f(q,J,ct),ut=c.Layer.mergeAll(st),dt=(e,t)=>N(J,e,t),ft=(e,t)=>P(J,e,t),pt=F,mt=(e,t,n,r)=>z(J,e,t,n,r),ht=(e,t)=>n=>M(e,q,t)(n),gt=S.bind(null,q),_t=x.bind(null,q),vt=C.bind(null,q),yt=b,{uploadRequestsTotal:bt,uploadPartsTotal:xt,uploadSuccessTotal:St,uploadErrorsTotal:Ct,apiCallsTotal:wt,uploadDurationHistogram:Tt,partUploadDurationHistogram:Et,fileSizeHistogram:Dt,partSizeHistogram:Ot,activeUploadsGauge:kt,uploadThroughputGauge:At,uploadLatencySummary:jt}=J,Mt=`gcs`,Y=E(`gcs`),Nt=j(`gcs`),Pt=e=>{if(!e||typeof e!=`object`)return null;let t=`code`in e?e.code:`status`in e?e.status:void 0;if(!t)return null;switch(t){case`NoSuchBucket`:case`NoSuchKey`:case`NoSuchUpload`:return`client_error`;case`BucketAlreadyOwnedByYou`:case`BucketNotEmpty`:return`client_error`;case`InvalidBucketName`:case`InvalidArgument`:case`InvalidPart`:case`InvalidPartOrder`:return`client_error`;case`EntityTooSmall`:case`EntityTooLarge`:return`client_error`;case`MalformedPolicy`:return`client_error`;case`Unauthorized`:case`AuthenticationRequired`:return`authentication_error`;case`Forbidden`:case`AccessDenied`:return`authorization_error`;case`TooManyRequests`:case`RateLimitExceeded`:return`throttling_error`;case`InternalError`:case`ServiceUnavailable`:case`BackendError`:return`server_error`;default:if(typeof t==`number`){if(t>=500)return`server_error`;if(t===429)return`throttling_error`;if(t===403)return`authorization_error`;if(t===401)return`authentication_error`;if(t>=400)return`client_error`}return null}},Ft=f(`gcs`,Y,Pt),It=c.Layer.mergeAll(Nt),Lt=(e,t)=>N(Y,e,t),Rt=(e,t)=>P(Y,e,t),zt=F,Bt=(e,t,n,r)=>z(Y,e,t,n,r),Vt=(e,t)=>n=>M(e,`gcs`,t)(n),Ht=S.bind(null,`gcs`),Ut=x.bind(null,`gcs`),Wt=C.bind(null,`gcs`),Gt=b,{uploadRequestsTotal:Kt,uploadPartsTotal:qt,uploadSuccessTotal:Jt,uploadErrorsTotal:Yt,apiCallsTotal:Xt,uploadDurationHistogram:Zt,partUploadDurationHistogram:Qt,fileSizeHistogram:$t,partSizeHistogram:en,activeUploadsGauge:tn,uploadThroughputGauge:nn,uploadLatencySummary:rn}=Y,X=`filesystem`,Z=E(X),an=j(X),on=e=>{if(!e||typeof e!=`object`)return null;let t=`code`in e?e.code:void 0;if(!t)return null;switch(t){case`ENOENT`:case`ENOTDIR`:return`client_error`;case`EEXIST`:return`client_error`;case`EISDIR`:return`client_error`;case`EINVAL`:case`ENAMETOOLONG`:return`client_error`;case`EACCES`:case`EPERM`:return`authorization_error`;case`ENOSPC`:case`EDQUOT`:return`server_error`;case`EIO`:case`EROFS`:case`EMFILE`:case`ENFILE`:return`server_error`;case`EBUSY`:return`throttling_error`;default:return null}},sn=f(X,Z,on),cn=c.Layer.mergeAll(an),ln=(e,t)=>N(Z,e,t),un=(e,t)=>P(Z,e,t),dn=F,fn=(e,t,n,r)=>z(Z,e,t,n,r),pn=(e,t)=>n=>M(e,X,t)(n),mn=S.bind(null,X),hn=x.bind(null,X),gn=C.bind(null,X),_n=b,{uploadRequestsTotal:vn,uploadPartsTotal:yn,uploadSuccessTotal:bn,uploadErrorsTotal:xn,apiCallsTotal:Sn,uploadDurationHistogram:Cn,partUploadDurationHistogram:wn,fileSizeHistogram:Tn,partSizeHistogram:En,activeUploadsGauge:Dn,uploadThroughputGauge:On,uploadLatencySummary:kn}=Z,Q=()=>({uploadCreatedTotal:c.Metric.counter(`upload_created_total`,{description:`Total number of uploads created`}),uploadCompletedTotal:c.Metric.counter(`upload_completed_total`,{description:`Total number of uploads completed successfully`}),uploadFailedTotal:c.Metric.counter(`upload_failed_total`,{description:`Total number of uploads that failed`}),chunkUploadedTotal:c.Metric.counter(`chunk_uploaded_total`,{description:`Total number of chunks uploaded`}),uploadFromUrlTotal:c.Metric.counter(`upload_from_url_total`,{description:`Total number of URL-based uploads`}),uploadFromUrlSuccessTotal:c.Metric.counter(`upload_from_url_success_total`,{description:`Total number of successful URL-based uploads`}),uploadFromUrlFailedTotal:c.Metric.counter(`upload_from_url_failed_total`,{description:`Total number of failed URL-based uploads`}),uploadDurationHistogram:c.Metric.histogram(`upload_duration_seconds`,c.MetricBoundaries.exponential({start:.01,factor:2,count:20}),`Duration of complete upload operations in seconds`),chunkUploadDurationHistogram:c.Metric.histogram(`chunk_upload_duration_seconds`,c.MetricBoundaries.exponential({start:.001,factor:2,count:15}),`Duration of individual chunk uploads in seconds`),uploadFileSizeHistogram:c.Metric.histogram(`upload_file_size_bytes`,c.MetricBoundaries.exponential({start:1024,factor:2,count:25}),`Size of uploaded files in bytes`),chunkSizeHistogram:c.Metric.histogram(`chunk_size_bytes`,c.MetricBoundaries.linear({start:262144,width:262144,count:20}),`Size of uploaded chunks in bytes`),activeUploadsGauge:c.Metric.gauge(`active_uploads`,{description:`Number of currently active uploads`}),uploadThroughputGauge:c.Metric.gauge(`upload_throughput_bytes_per_second`,{description:`Current upload throughput in bytes per second`}),uploadLatencySummary:c.Metric.summary({name:`upload_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Upload operation latency percentiles`}),chunkLatencySummary:c.Metric.summary({name:`chunk_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Chunk upload latency percentiles`})}),An=Q(),jn=(e,t)=>n=>n.pipe(c.Effect.withSpan(`upload-${e}`,{attributes:{"upload.operation":e,...t}})),Mn=e=>c.Effect.annotateCurrentSpan({"upload.id":e.uploadId??`unknown`,"upload.file_name":e.fileName??`unknown`,"upload.file_size":e.fileSize?.toString()??`0`,"upload.storage_id":e.storageId??`unknown`,"upload.mime_type":e.mimeType??`unknown`}),Nn=e=>c.Effect.annotateCurrentSpan({"chunk.upload_id":e.uploadId,"chunk.size":e.chunkSize.toString(),"chunk.offset":e.offset.toString(),"chunk.total_size":e.totalSize?.toString()??`0`,"chunk.progress":e.totalSize&&e.totalSize>0?(e.offset/e.totalSize*100).toFixed(2):`0`}),Pn=(e=`uploadista-upload-server`)=>{let t=Q();return c.Layer.succeed(h,{serviceName:e,enabled:!0,metrics:{uploadCreated:c.Effect.succeed(t.uploadCreatedTotal).pipe(c.Effect.flatMap(e=>c.Metric.increment(e))),uploadCompleted:c.Effect.succeed(t.uploadCompletedTotal).pipe(c.Effect.flatMap(e=>c.Metric.increment(e))),uploadFailed:c.Effect.succeed(t.uploadFailedTotal).pipe(c.Effect.flatMap(e=>c.Metric.increment(e))),chunkUploaded:c.Effect.succeed(t.chunkUploadedTotal).pipe(c.Effect.flatMap(e=>c.Metric.increment(e)))}})},Fn=Pn(),In=_(!1),Ln=c.Effect.gen(function*(){return(yield*h).metrics}),Rn=e=>{let t=Q();return c.Effect.gen(function*(){let n=Date.now(),r=yield*e,i=(Date.now()-n)/1e3;return yield*c.Metric.update(t.uploadDurationHistogram,i),r}).pipe(c.Effect.withSpan(`upload-operation`))},zn=e=>{let t=Q();return c.Effect.gen(function*(){let n=Date.now(),r=yield*e,i=(Date.now()-n)/1e3;return yield*c.Metric.update(t.chunkUploadDurationHistogram,i),r}).pipe(c.Effect.withSpan(`chunk-upload`))},$=e=>{if(!e||typeof e!=`object`)return`unknown_error`;let t=`code`in e?e.code:void 0,n=`name`in e?e.name:void 0,r=e instanceof Error?e.message.toLowerCase():``;return t===`ABORTED`||n===`AbortError`||r.includes(`abort`)?`abort_error`:t===`FILE_TOO_LARGE`||t===`LIMIT_FILE_SIZE`||t===`RequestEntityTooLarge`||r.includes(`too large`)||r.includes(`size limit`)||r.includes(`max size`)?`size_limit_error`:t===`INVALID_FILE`||t===`INVALID_METADATA`||t===`VALIDATION_ERROR`||r.includes(`validation`)||r.includes(`invalid`)?`validation_error`:t===`NetworkError`||t===`ECONNRESET`||t===`ENOTFOUND`||t===`ETIMEDOUT`||r.includes(`network`)||r.includes(`timeout`)?`network_error`:t===`UNAUTHORIZED`||t===`AuthenticationFailed`||n===`AuthenticationError`||r.includes(`authentication`)||r.includes(`unauthorized`)?`authentication_error`:t===`FORBIDDEN`||t===`AccessDenied`||n===`AuthorizationError`||r.includes(`forbidden`)||r.includes(`permission`)?`authorization_error`:t===`FILE_WRITE_ERROR`||t===`STORAGE_ERROR`||r.includes(`storage`)||r.includes(`write error`)?`storage_error`:`unknown_error`},Bn=(e,t,n,r={})=>c.Effect.gen(function*(){let i=$(n);yield*e.uploadFailedTotal.pipe(c.Metric.tagged(`operation`,t),c.Metric.tagged(`error_category`,i))(c.Effect.succeed(1));let a={operation:t,error_category:i,error_type:typeof n,error_message:n instanceof Error?n.message:String(n),error_code:n&&typeof n==`object`&&`code`in n?String(n.code):void 0,error_name:n&&typeof n==`object`&&`name`in n?String(n.name):void 0,...r};yield*c.Effect.logError(`Upload ${t} failed`).pipe(c.Effect.annotateLogs(a))}),Vn=e=>t=>{if(e){let n=e(t);if(n!==null)return n}return $(t)},Hn=c.Layer.succeed(h,{serviceName:`uploadista-upload-server-test`,enabled:!0,metrics:{uploadCreated:()=>Promise.resolve(),uploadCompleted:()=>Promise.resolve(),uploadFailed:()=>Promise.resolve(),chunkUploaded:()=>Promise.resolve()}}),Un=()=>Q(),Wn=()=>{let e=Un(),t=[`uploadCreatedTotal`,`uploadCompletedTotal`,`uploadFailedTotal`,`chunkUploadedTotal`,`uploadFromUrlTotal`,`uploadFromUrlSuccessTotal`,`uploadFromUrlFailedTotal`,`uploadDurationHistogram`,`chunkUploadDurationHistogram`,`uploadFileSizeHistogram`,`chunkSizeHistogram`,`activeUploadsGauge`,`uploadThroughputGauge`,`uploadLatencySummary`,`chunkLatencySummary`].filter(t=>!(t in e));if(t.length>0)throw Error(`Missing required metrics: ${t.join(`, `)}`);return!0};exports.AzureObservabilityLayer=ut,exports.AzureTracingLayer=st,exports.FilesystemObservabilityLayer=cn,exports.FilesystemTracingLayer=an,exports.FlowObservability=g,exports.FlowObservabilityDisabled=se,exports.FlowObservabilityLive=Te,exports.GCSObservabilityLayer=It,exports.GCSTracingLayer=Nt,exports.MetricsService=W,exports.NoOpMetricsServiceLive=Fe,exports.NodeSdkLive=_e,exports.Observability=p,exports.ObservabilityDisabled=ie,exports.S3ObservabilityLayer=ze,exports.S3TracingLayer=K,exports.StorageObservability=m,exports.StorageObservabilityDisabled=ae,exports.TracingService=me,exports.UploadObservability=h,exports.UploadObservabilityDisabled=oe,exports.UploadObservabilityLive=Fn,exports.UploadObservabilityTest=Hn,exports.WebSdkLive=ge,exports.WorkersSdkLive=ve,exports.azureActiveUploadsGauge=kt,exports.azureApiCallsTotal=wt,exports.azureFileSizeHistogram=Dt,exports.azureMetrics=J,exports.azurePartSizeHistogram=Ot,exports.azurePartUploadDurationHistogram=Et,exports.azureUploadDurationHistogram=Tt,exports.azureUploadErrorsTotal=Ct,exports.azureUploadLatencySummary=jt,exports.azureUploadPartsTotal=xt,exports.azureUploadRequestsTotal=bt,exports.azureUploadSuccessTotal=St,exports.azureUploadThroughputGauge=At,exports.captureMetrics=de,exports.classifyFlowError=H,exports.classifyStorageError=d,exports.classifyUploadError=$,exports.createFlowMetrics=B,exports.createStorageErrorClassifier=ee,exports.createStorageErrorTracker=f,exports.createStorageMetrics=E,exports.createStorageTracingLayer=j,exports.createTestFixture=A,exports.createTracingLayer=he,exports.createUploadErrorClassifier=Vn,exports.createUploadGauges=le,exports.createUploadHistograms=T,exports.createUploadMetrics=w,exports.createUploadServerMetrics=Q,exports.createUploadSummaries=ue,exports.filesystemActiveUploadsGauge=Dn,exports.filesystemApiCallsTotal=Sn,exports.filesystemFileSizeHistogram=Tn,exports.filesystemMetrics=Z,exports.filesystemPartSizeHistogram=En,exports.filesystemPartUploadDurationHistogram=wn,exports.filesystemUploadDurationHistogram=Cn,exports.filesystemUploadErrorsTotal=xn,exports.filesystemUploadLatencySummary=kn,exports.filesystemUploadPartsTotal=yn,exports.filesystemUploadRequestsTotal=vn,exports.filesystemUploadSuccessTotal=bn,exports.filesystemUploadThroughputGauge=On,exports.flowMetrics=be,exports.gcsActiveUploadsGauge=tn,exports.gcsApiCallsTotal=Xt,exports.gcsFileSizeHistogram=$t,exports.gcsMetrics=Y,exports.gcsPartSizeHistogram=en,exports.gcsPartUploadDurationHistogram=Qt,exports.gcsUploadDurationHistogram=Zt,exports.gcsUploadErrorsTotal=Yt,exports.gcsUploadLatencySummary=rn,exports.gcsUploadPartsTotal=qt,exports.gcsUploadRequestsTotal=Kt,exports.gcsUploadSuccessTotal=Jt,exports.gcsUploadThroughputGauge=nn,exports.getFlowMetrics=De,exports.getTestMetrics=Un,exports.getUploadMetrics=Ln,exports.isObservabilityEnabled=y,exports.logAzureContext=yt,exports.logAzureOperation=gt,exports.logAzureUploadCompletion=vt,exports.logAzureUploadProgress=_t,exports.logFilesystemContext=_n,exports.logFilesystemOperation=mn,exports.logFilesystemUploadCompletion=gn,exports.logFilesystemUploadProgress=hn,exports.logGCSContext=Gt,exports.logGCSOperation=Ht,exports.logGCSUploadCompletion=Wt,exports.logGCSUploadProgress=Ut,exports.logS3Context=Je,exports.logS3Operation=Ge,exports.logS3UploadCompletion=qe,exports.logS3UploadProgress=Ke,exports.logStorageOperation=S,exports.logUploadCompletion=C,exports.logUploadProgress=x,exports.logWithContext=b,exports.makeFlowObservabilityLayer=v,exports.makeFlowObservabilityLive=V,exports.makeObservabilityLayer=ne,exports.makeStorageObservabilityLayer=re,exports.makeTestFlowObservability=k,exports.makeTestFlowObservabilityUtil=U,exports.makeTestStorageObservability=D,exports.makeTestUploadObservability=O,exports.makeUploadObservabilityLayer=_,exports.makeUploadObservabilityLive=Pn,exports.runWithTestFlowObservability=Pe,exports.runWithTestObservability=pe,exports.s3ActiveUploadsGauge=it,exports.s3ApiCallsTotal=$e,exports.s3FileSizeHistogram=nt,exports.s3Metrics=G,exports.s3PartSizeHistogram=rt,exports.s3PartUploadDurationHistogram=tt,exports.s3UploadDurationHistogram=et,exports.s3UploadErrorsTotal=Qe,exports.s3UploadLatencySummary=ot,exports.s3UploadPartsTotal=Xe,exports.s3UploadRequestsTotal=Ye,exports.s3UploadSuccessTotal=Ze,exports.s3UploadThroughputGauge=at,exports.trackActiveFlow=Ae,exports.trackActiveNode=je,exports.trackAzureError=lt,exports.trackFileSize=I,exports.trackFilesystemError=sn,exports.trackFlowError=Me,exports.trackGCSError=Ft,exports.trackNodeError=Ne,exports.trackPartSize=ye,exports.trackS3Error=Re,exports.trackStorageError=te,exports.trackUploadError=Bn,exports.uploadServerMetrics=An,exports.validateMetricsExist=Wn,exports.whenObservabilityEnabled=ce,exports.withActiveUploadTracking=L,exports.withApiMetrics=P,exports.withAzureApiMetrics=ft,exports.withAzureOperationMetrics=mt,exports.withAzureSpan=ht,exports.withAzureTimingMetrics=pt,exports.withAzureUploadMetrics=dt,exports.withChunkContext=Nn,exports.withChunkDuration=zn,exports.withExecutionContext=we,exports.withFilesystemApiMetrics=un,exports.withFilesystemOperationMetrics=fn,exports.withFilesystemSpan=pn,exports.withFilesystemTimingMetrics=dn,exports.withFilesystemUploadMetrics=ln,exports.withFlowContext=Se,exports.withFlowDuration=Oe,exports.withFlowSpan=xe,exports.withGCSApiMetrics=Rt,exports.withGCSOperationMetrics=Bt,exports.withGCSSpan=Vt,exports.withGCSTimingMetrics=zt,exports.withGCSUploadMetrics=Lt,exports.withMetricTracking=fe,exports.withNodeContext=Ce,exports.withNodeDuration=ke,exports.withS3ApiMetrics=Ve,exports.withS3OperationMetrics=Ue,exports.withS3Span=We,exports.withS3TimingMetrics=He,exports.withS3UploadMetrics=Be,exports.withStorageOperationMetrics=z,exports.withStorageSpan=M,exports.withThroughputTracking=R,exports.withTimingMetrics=F,exports.withUploadContext=Mn,exports.withUploadDuration=Rn,exports.withUploadMetrics=N,exports.withUploadSpan=jn;
|
|
1
|
+
let e=require(`effect`),t=require(`@effect/opentelemetry`),n=require(`@opentelemetry/sdk-trace-base`);const r=e=>{if(!e||typeof e!=`object`)return`unknown_error`;let t=`code`in e?e.code:void 0,n=`name`in e?e.name:void 0,r=e instanceof Error?e.message.toLowerCase():``;return t===`NetworkError`||t===`ECONNRESET`||t===`ENOTFOUND`||t===`ETIMEDOUT`||r.indexOf(`network`)>=0||r.indexOf(`timeout`)>=0?`network_error`:t===`InvalidAccessKeyId`||t===`SignatureDoesNotMatch`||t===`TokenRefreshRequired`||t===`AuthenticationFailed`||n===`AuthenticationError`||r.indexOf(`authentication`)>=0||r.indexOf(`unauthorized`)>=0?`authentication_error`:t===`AccessDenied`||t===`AccountProblem`||t===`Forbidden`||n===`AuthorizationError`||r.indexOf(`forbidden`)>=0||r.indexOf(`permission`)>=0?`authorization_error`:t===`SlowDown`||t===`RequestTimeTooSkewed`||t===`TooManyRequests`||n===`ThrottlingError`||r.indexOf(`throttl`)>=0||r.indexOf(`rate limit`)>=0?`throttling_error`:t===`InternalError`||t===`ServiceUnavailable`||t===`InternalServerError`||n===`ServerError`||r.indexOf(`server error`)>=0||r.indexOf(`service unavailable`)>=0?`server_error`:t===`InvalidRequest`||t===`MalformedXML`||t===`RequestEntityTooLarge`||t===`BadRequest`||n===`ClientError`||r.indexOf(`bad request`)>=0||r.indexOf(`invalid`)>=0?`client_error`:`unknown_error`},i=(e,t)=>e=>{if(t){let n=t(e);if(n!==null)return n}return r(e)},a=(t,n,i,a,o={},s=r)=>e.Effect.gen(function*(){let r=s(a);yield*n.uploadErrorsTotal.pipe(e.Metric.tagged(`operation`,i),e.Metric.tagged(`error_category`,r))(e.Effect.succeed(1));let c={storage_type:t,operation:i,error_category:r,error_type:typeof a,error_message:a instanceof Error?a.message:String(a),error_code:a&&typeof a==`object`&&`code`in a?a.code:void 0,error_name:a&&typeof a==`object`&&`name`in a?a.name:void 0,...o};yield*e.Effect.logError(`${t.toUpperCase()} ${i} failed`).pipe(e.Effect.annotateLogs(c))}),o=(e,t,n)=>{let r=i(e,n);return(n,i,o={})=>a(e,t,n,i,o,r)};var s=class extends e.Context.Tag(`Observability`)(){},c=class extends e.Context.Tag(`StorageObservability`)(){},l=class extends e.Context.Tag(`UploadObservability`)(){},u=class extends e.Context.Tag(`FlowObservability`)(){};const d=(t,n=!0)=>e.Layer.succeed(s,{serviceName:t,enabled:n}),ee=(t,n,r=!0)=>e.Layer.succeed(c,{serviceName:`uploadista-${t}-store`,storageType:t,metrics:n,enabled:r}),f=(t=!0)=>e.Layer.succeed(l,{serviceName:`uploadista-upload-server`,enabled:t,metrics:{uploadCreated:e.Effect.void,uploadCompleted:e.Effect.void,uploadFailed:e.Effect.void,chunkUploaded:e.Effect.void}}),p=(t=!0)=>e.Layer.succeed(u,{serviceName:`uploadista-flow-engine`,enabled:t,metrics:{flowStarted:e.Effect.void,flowCompleted:e.Effect.void,flowFailed:e.Effect.void,nodeExecuted:e.Effect.void}}),te=d(`uploadista-disabled`,!1),ne=e=>ee(e,{},!1),re=f(!1),ie=p(!1),m=e.Effect.gen(function*(){let t=yield*e.Effect.serviceOption(s);return e.Option.match(t,{onNone:()=>!1,onSome:e=>e.enabled})}),ae=t=>e.Effect.gen(function*(){if(yield*m){let n=yield*t;return e.Option.some(n)}return e.Option.none()}),h=(t,n)=>e.Effect.log(t).pipe(e.Effect.annotateLogs(n)),g=(e,t,n)=>h(`Upload progress`,{storage_type:e,upload_id:t,uploaded_bytes:n.uploadedBytes,total_bytes:n.totalBytes,progress_percentage:Math.round(n.uploadedBytes/n.totalBytes*100),...n.partNumber&&{part_number:n.partNumber},...n.speed&&{upload_speed_bps:n.speed}}),_=(e,t,n,r)=>h(`${e.toUpperCase()} ${t}`,{storage_type:e,operation:t,upload_id:n,...r}),v=(e,t,n)=>{let r=n.throughputBps?n.throughputBps/(1024*1024):0;return h(`${e.toUpperCase()} upload completed`,{storage_type:e,upload_id:t,file_size_bytes:n.fileSize,file_size_mb:Math.round(n.fileSize/(1024*1024)*100)/100,total_duration_ms:n.totalDurationMs,total_duration_seconds:Math.round(n.totalDurationMs/1e3*100)/100,throughput_bps:n.throughputBps,throughput_mbps:Math.round(r*100)/100,...n.partsCount&&{parts_count:n.partsCount},...n.averagePartSize&&{average_part_size_bytes:n.averagePartSize,average_part_size_mb:Math.round(n.averagePartSize/(1024*1024)*100)/100},...n.retryCount&&{retry_count:n.retryCount}})},y=t=>({uploadRequestsTotal:e.Metric.counter(`${t}_upload_requests_total`,{description:`Total number of upload requests for ${t}`}),uploadPartsTotal:e.Metric.counter(`${t}_upload_parts_total`,{description:`Total number of individual parts uploaded for ${t}`}),uploadSuccessTotal:e.Metric.counter(`${t}_upload_success_total`,{description:`Total number of successful uploads for ${t}`}),uploadErrorsTotal:e.Metric.counter(`${t}_upload_errors_total`,{description:`Total number of upload errors for ${t}`}),apiCallsTotal:e.Metric.counter(`${t}_api_calls_total`,{description:`Total number of API calls for ${t}`})}),b=t=>({uploadDurationHistogram:e.Metric.histogram(`${t}_upload_duration_seconds`,e.MetricBoundaries.exponential({start:.01,factor:2,count:20}),`Duration of upload operations in seconds for ${t}`),partUploadDurationHistogram:e.Metric.histogram(`${t}_part_upload_duration_seconds`,e.MetricBoundaries.exponential({start:.001,factor:2,count:15}),`Duration of individual part uploads in seconds for ${t}`),fileSizeHistogram:e.Metric.histogram(`${t}_file_size_bytes`,e.MetricBoundaries.exponential({start:1024,factor:2,count:25}),`Size of uploaded files in bytes for ${t}`),partSizeHistogram:e.Metric.histogram(`${t}_part_size_bytes`,e.MetricBoundaries.linear({start:5242880,width:1048576,count:20}),`Size of upload parts in bytes for ${t}`)}),x=t=>({activeUploadsGauge:e.Metric.gauge(`${t}_active_uploads`,{description:`Number of currently active uploads for ${t}`}),uploadThroughputGauge:e.Metric.gauge(`${t}_upload_throughput_bytes_per_second`,{description:`Current upload throughput in bytes per second for ${t}`})}),oe=t=>({uploadLatencySummary:e.Metric.summary({name:`${t}_upload_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Upload latency percentiles for ${t}`})}),S=e=>({...y(e),...b(e),...x(e),...oe(e)}),C=t=>{let n=S(t),r={serviceName:`test-${t}-store`,storageType:t,metrics:n,enabled:!0};return e.Layer.succeed(c,r)},w=()=>{let t={serviceName:`test-upload-server`,enabled:!0,metrics:{uploadCreated:e.Effect.void,uploadCompleted:e.Effect.void,uploadFailed:e.Effect.void,chunkUploaded:e.Effect.void}};return e.Layer.succeed(l,t)},T=()=>{let t={serviceName:`test-flow-engine`,enabled:!0,metrics:{flowStarted:e.Effect.void,flowCompleted:e.Effect.void,flowFailed:e.Effect.void,nodeExecuted:e.Effect.void}};return e.Layer.succeed(u,t)},se=t=>e.Effect.gen(function*(){let n=yield*t;return yield*e.Metric.snapshot,n}),ce=t=>e.Effect.gen(function*(){yield*e.Metric.snapshot;let n=yield*t;return yield*e.Metric.snapshot,n}),E=(e=`test-storage`)=>({storageObservability:C(e),uploadObservability:w(),flowObservability:T()}),le=(t,n=`test-storage`)=>{let r=E(n);return t.pipe(e.Effect.provide(r.storageObservability),e.Effect.provide(r.uploadObservability),e.Effect.provide(r.flowObservability))},D=e.Context.GenericTag(`TracingService`),O=t=>{let n=t?.serviceName??`uploadista-storage`;return e.Layer.succeed(D,{serviceName:n})},k=e=>O({serviceName:`uploadista-${e}-store`}),A=(t,n,r)=>i=>i.pipe(e.Effect.withSpan(`${n}-${t}`,{attributes:{"storage.type":n,operation:t,...r}})),ue=t.WebSdk.layer(()=>({resource:{serviceName:`uploadista-storage`},spanProcessor:new n.BatchSpanProcessor(new n.ConsoleSpanExporter)})),de=t.NodeSdk.layer(()=>({resource:{serviceName:`uploadista-storage`},spanProcessor:new n.BatchSpanProcessor(new n.ConsoleSpanExporter)})),fe=t.WebSdk.layer(()=>({resource:{serviceName:`uploadista-storage-workers`},spanProcessor:new n.BatchSpanProcessor(new n.ConsoleSpanExporter)})),j=(t,n,r)=>r.pipe(e.Effect.tap(()=>t.uploadRequestsTotal.pipe(e.Metric.tagged(`upload_id`,n))(e.Effect.succeed(1))),e.Effect.tapError(()=>t.uploadErrorsTotal.pipe(e.Metric.tagged(`upload_id`,n))(e.Effect.succeed(1))),e.Effect.tap(()=>t.uploadSuccessTotal.pipe(e.Metric.tagged(`upload_id`,n))(e.Effect.succeed(1)))),M=(t,n,r)=>r.pipe(e.Effect.tap(()=>t.apiCallsTotal.pipe(e.Metric.tagged(`operation`,n))(e.Effect.succeed(1)))),N=(t,n)=>e.Effect.gen(function*(){let r=yield*e.Effect.sync(()=>Date.now()),i=yield*n,a=((yield*e.Effect.sync(()=>Date.now()))-r)/1e3;return yield*t(e.Effect.succeed(a)),i}),P=(t,n,r)=>r.pipe(e.Effect.tap(()=>t.fileSizeHistogram(e.Effect.succeed(n)))),pe=(t,n,r)=>r.pipe(e.Effect.tap(()=>t.partSizeHistogram(e.Effect.succeed(n)))),F=(t,n)=>n.pipe(e.Effect.tap(()=>t.activeUploadsGauge(e.Effect.succeed(1))),e.Effect.ensuring(t.activeUploadsGauge(e.Effect.succeed(-1)))),I=(t,n,r)=>e.Effect.gen(function*(){let i=yield*e.Effect.sync(()=>Date.now()),a=yield*r,o=((yield*e.Effect.sync(()=>Date.now()))-i)/1e3,s=o>0?n/o:0;return yield*t.uploadThroughputGauge(e.Effect.succeed(s)),a}),L=(e,t,n,r,i)=>{let a=r.pipe(n=>M(e,t,n),t=>j(e,n,t),t=>N(e.uploadDurationHistogram,t),t=>F(e,t));return i!==void 0&&(a=a.pipe(t=>P(e,i,t),t=>I(e,i,t))),a},R=()=>({flowStartedTotal:e.Metric.counter(`flow_started_total`,{description:`Total number of flows started`}),flowCompletedTotal:e.Metric.counter(`flow_completed_total`,{description:`Total number of flows completed successfully`}),flowFailedTotal:e.Metric.counter(`flow_failed_total`,{description:`Total number of flows that failed`}),flowPausedTotal:e.Metric.counter(`flow_paused_total`,{description:`Total number of flows that were paused`}),flowResumedTotal:e.Metric.counter(`flow_resumed_total`,{description:`Total number of flows that were resumed`}),nodeExecutedTotal:e.Metric.counter(`node_executed_total`,{description:`Total number of nodes executed`}),nodeSuccessTotal:e.Metric.counter(`node_success_total`,{description:`Total number of nodes executed successfully`}),nodeFailedTotal:e.Metric.counter(`node_failed_total`,{description:`Total number of nodes that failed`}),nodeSkippedTotal:e.Metric.counter(`node_skipped_total`,{description:`Total number of nodes skipped (conditional)`}),flowDurationHistogram:e.Metric.histogram(`flow_duration_seconds`,e.MetricBoundaries.exponential({start:.1,factor:2,count:20}),`Duration of complete flow execution in seconds`),nodeDurationHistogram:e.Metric.histogram(`node_duration_seconds`,e.MetricBoundaries.exponential({start:.01,factor:2,count:18}),`Duration of individual node execution in seconds`),flowNodeCountHistogram:e.Metric.histogram(`flow_node_count`,e.MetricBoundaries.linear({start:1,width:5,count:20}),`Number of nodes in a flow`),parallelNodesHistogram:e.Metric.histogram(`parallel_nodes_count`,e.MetricBoundaries.linear({start:1,width:2,count:15}),`Number of nodes executed in parallel`),activeFlowsGauge:e.Metric.gauge(`active_flows`,{description:`Number of currently active flows`}),activeNodesGauge:e.Metric.gauge(`active_nodes`,{description:`Number of currently executing nodes`}),pausedFlowsGauge:e.Metric.gauge(`paused_flows`,{description:`Number of currently paused flows`}),flowLatencySummary:e.Metric.summary({name:`flow_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Flow execution latency percentiles`}),nodeLatencySummary:e.Metric.summary({name:`node_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Node execution latency percentiles`})}),me=R(),he=(t,n)=>r=>r.pipe(e.Effect.withSpan(`flow-${t}`,{attributes:{"flow.operation":t,...n}})),ge=t=>e.Effect.annotateCurrentSpan({"flow.id":t.flowId??`unknown`,"flow.name":t.flowName??`unknown`,"flow.job_id":t.jobId??`unknown`,"flow.node_count":t.nodeCount?.toString()??`0`,"flow.storage_id":t.storageId??`unknown`}),_e=t=>e.Effect.annotateCurrentSpan({"node.id":t.nodeId,"node.type":t.nodeType,"node.name":t.nodeName??`unknown`,"node.flow_id":t.flowId??`unknown`,"node.job_id":t.jobId??`unknown`}),ve=t=>e.Effect.annotateCurrentSpan({"execution.order":t.executionOrder?.join(`,`)??``,"execution.current_index":t.currentIndex?.toString()??`0`,"execution.total_nodes":t.totalNodes?.toString()??`0`,"execution.parallel_count":t.parallelCount?.toString()??`0`}),z=(t=`uploadista-flow-engine`)=>{let n=R();return e.Layer.succeed(u,{serviceName:t,enabled:!0,metrics:{flowStarted:e.Metric.increment(n.flowStartedTotal),flowCompleted:e.Metric.increment(n.flowCompletedTotal),flowFailed:e.Metric.increment(n.flowFailedTotal),nodeExecuted:e.Metric.increment(n.nodeExecutedTotal)}})},ye=z(),be=p(!1),xe=e.Effect.gen(function*(){return(yield*u).metrics}),Se=t=>{let n=R();return e.Effect.gen(function*(){let r=Date.now(),i=yield*t,a=(Date.now()-r)/1e3;return yield*e.Metric.update(n.flowDurationHistogram,a),yield*e.Metric.update(n.flowLatencySummary,a),i}).pipe(e.Effect.withSpan(`flow-execution`))},Ce=(t,n,r)=>{let i=R();return e.Effect.gen(function*(){let t=Date.now(),n=yield*r,a=(Date.now()-t)/1e3;return yield*e.Metric.update(i.nodeDurationHistogram,a),yield*e.Metric.update(i.nodeLatencySummary,a),n}).pipe(e.Effect.withSpan(`node-${n}`,{attributes:{"node.id":t,"node.type":n}}))},we=t=>{let n=R();return e.Effect.gen(function*(){return yield*e.Metric.increment(n.activeFlowsGauge),yield*e.Effect.acquireUseRelease(e.Effect.void,()=>t,()=>e.Metric.set(n.activeFlowsGauge,-1))})},Te=t=>{let n=R();return e.Effect.gen(function*(){return yield*e.Metric.increment(n.activeNodesGauge),yield*e.Effect.acquireUseRelease(e.Effect.void,()=>t,()=>e.Metric.set(n.activeNodesGauge,-1))})},B=e=>{if(!e||typeof e!=`object`)return`unknown_flow_error`;let t=`code`in e?e.code:void 0;if(!t)return`unknown_flow_error`;switch(t){case`FLOW_VALIDATION_ERROR`:case`FLOW_INVALID_INPUT`:case`FLOW_INVALID_OUTPUT`:return`flow_validation_error`;case`FLOW_NODE_NOT_FOUND`:case`FLOW_EDGE_INVALID`:return`node_not_found_error`;case`FLOW_NODE_EXECUTION_FAILED`:case`FLOW_NODE_ERROR`:return`node_execution_error`;case`FLOW_TIMEOUT`:return`flow_timeout_error`;case`FLOW_CANCELLED`:case`ABORTED`:return`flow_cancelled_error`;default:return`unknown_flow_error`}},Ee=t=>{let n=R(),r=B(t);return e.Effect.gen(function*(){yield*e.Metric.increment(n.flowFailedTotal),yield*e.Effect.logError(`Flow execution failed`).pipe(e.Effect.annotateLogs({"error.category":r,"error.message":String(t)}))})},De=(t,n,r)=>{let i=R(),a=B(r);return e.Effect.gen(function*(){yield*e.Metric.increment(i.nodeFailedTotal),yield*e.Effect.logError(`Node execution failed`).pipe(e.Effect.annotateLogs({"node.id":t,"node.type":n,"error.category":a,"error.message":String(r)}))})},V=()=>{let t={serviceName:`test-flow-engine`,enabled:!0,metrics:{flowStarted:e.Effect.void,flowCompleted:e.Effect.void,flowFailed:e.Effect.void,nodeExecuted:e.Effect.void}};return e.Layer.succeed(u,t)},Oe=t=>t.pipe(e.Effect.provide(V()));var H=class extends e.Context.Tag(`MetricsService`)(){};const ke=e.Layer.succeed(H,{recordUpload:(t,n)=>e.Effect.void}),Ae=`s3`,U=S(`s3`),W=k(`s3`),je=e=>{if(!e||typeof e!=`object`)return null;let t=`code`in e?e.code:void 0;if(!t)return null;switch(t){case`NoSuchKey`:case`NoSuchBucket`:case`NoSuchUpload`:return`client_error`;case`BucketAlreadyExists`:case`BucketNotEmpty`:return`client_error`;case`InvalidBucketName`:case`InvalidPart`:case`InvalidPartOrder`:return`client_error`;case`EntityTooSmall`:case`EntityTooLarge`:return`client_error`;case`ExpiredToken`:case`TokenRefreshRequired`:return`authentication_error`;case`RequestTimeTooSkewed`:case`SlowDown`:return`throttling_error`;default:return null}},Me=o(`s3`,U,je),Ne=e.Layer.mergeAll(W),Pe=(e,t)=>j(U,e,t),Fe=(e,t)=>M(U,e,t),Ie=N,Le=(e,t,n,r)=>L(U,e,t,n,r),Re=(e,t)=>n=>A(e,`s3`,t)(n),ze=_.bind(null,`s3`),Be=g.bind(null,`s3`),Ve=v.bind(null,`s3`),He=h,{uploadRequestsTotal:Ue,uploadPartsTotal:We,uploadSuccessTotal:Ge,uploadErrorsTotal:Ke,apiCallsTotal:qe,uploadDurationHistogram:Je,partUploadDurationHistogram:Ye,fileSizeHistogram:Xe,partSizeHistogram:Ze,activeUploadsGauge:Qe,uploadThroughputGauge:$e,uploadLatencySummary:et}=U,G=`azure`,K=S(G),q=k(G),tt=e=>{if(!e||typeof e!=`object`)return null;let t=`code`in e?e.code:`statusCode`in e?e.statusCode:void 0;if(!t)return null;switch(t){case`BlobNotFound`:case`ContainerNotFound`:case`InvalidBlobOrBlock`:return`client_error`;case`ContainerAlreadyExists`:case`BlobAlreadyExists`:return`client_error`;case`InvalidBlockId`:case`InvalidBlockList`:case`InvalidBlobType`:return`client_error`;case`RequestBodyTooLarge`:case`InvalidHeaderValue`:return`client_error`;case`AuthenticationFailed`:case`InvalidAuthenticationInfo`:return`authentication_error`;case`AccountIsDisabled`:return`authorization_error`;case`InsufficientAccountPermissions`:return`authorization_error`;case`OperationTimedOut`:case`ServerBusy`:case`InternalError`:return`server_error`;default:if(typeof t==`number`){if(t>=500)return`server_error`;if(t===429)return`throttling_error`;if(t===403)return`authorization_error`;if(t===401)return`authentication_error`;if(t>=400)return`client_error`}return null}},nt=o(G,K,tt),rt=e.Layer.mergeAll(q),it=(e,t)=>j(K,e,t),at=(e,t)=>M(K,e,t),ot=N,st=(e,t,n,r)=>L(K,e,t,n,r),ct=(e,t)=>n=>A(e,G,t)(n),lt=_.bind(null,G),ut=g.bind(null,G),dt=v.bind(null,G),ft=h,{uploadRequestsTotal:pt,uploadPartsTotal:mt,uploadSuccessTotal:ht,uploadErrorsTotal:gt,apiCallsTotal:_t,uploadDurationHistogram:vt,partUploadDurationHistogram:yt,fileSizeHistogram:bt,partSizeHistogram:xt,activeUploadsGauge:St,uploadThroughputGauge:Ct,uploadLatencySummary:wt}=K,Tt=`gcs`,J=S(`gcs`),Y=k(`gcs`),Et=e=>{if(!e||typeof e!=`object`)return null;let t=`code`in e?e.code:`status`in e?e.status:void 0;if(!t)return null;switch(t){case`NoSuchBucket`:case`NoSuchKey`:case`NoSuchUpload`:return`client_error`;case`BucketAlreadyOwnedByYou`:case`BucketNotEmpty`:return`client_error`;case`InvalidBucketName`:case`InvalidArgument`:case`InvalidPart`:case`InvalidPartOrder`:return`client_error`;case`EntityTooSmall`:case`EntityTooLarge`:return`client_error`;case`MalformedPolicy`:return`client_error`;case`Unauthorized`:case`AuthenticationRequired`:return`authentication_error`;case`Forbidden`:case`AccessDenied`:return`authorization_error`;case`TooManyRequests`:case`RateLimitExceeded`:return`throttling_error`;case`InternalError`:case`ServiceUnavailable`:case`BackendError`:return`server_error`;default:if(typeof t==`number`){if(t>=500)return`server_error`;if(t===429)return`throttling_error`;if(t===403)return`authorization_error`;if(t===401)return`authentication_error`;if(t>=400)return`client_error`}return null}},Dt=o(`gcs`,J,Et),Ot=e.Layer.mergeAll(Y),kt=(e,t)=>j(J,e,t),At=(e,t)=>M(J,e,t),jt=N,Mt=(e,t,n,r)=>L(J,e,t,n,r),Nt=(e,t)=>n=>A(e,`gcs`,t)(n),Pt=_.bind(null,`gcs`),Ft=g.bind(null,`gcs`),It=v.bind(null,`gcs`),Lt=h,{uploadRequestsTotal:Rt,uploadPartsTotal:zt,uploadSuccessTotal:Bt,uploadErrorsTotal:Vt,apiCallsTotal:Ht,uploadDurationHistogram:Ut,partUploadDurationHistogram:Wt,fileSizeHistogram:Gt,partSizeHistogram:Kt,activeUploadsGauge:qt,uploadThroughputGauge:Jt,uploadLatencySummary:Yt}=J,X=`filesystem`,Z=S(X),Xt=k(X),Zt=e=>{if(!e||typeof e!=`object`)return null;let t=`code`in e?e.code:void 0;if(!t)return null;switch(t){case`ENOENT`:case`ENOTDIR`:return`client_error`;case`EEXIST`:return`client_error`;case`EISDIR`:return`client_error`;case`EINVAL`:case`ENAMETOOLONG`:return`client_error`;case`EACCES`:case`EPERM`:return`authorization_error`;case`ENOSPC`:case`EDQUOT`:return`server_error`;case`EIO`:case`EROFS`:case`EMFILE`:case`ENFILE`:return`server_error`;case`EBUSY`:return`throttling_error`;default:return null}},Qt=o(X,Z,Zt),$t=e.Layer.mergeAll(Xt),en=(e,t)=>j(Z,e,t),tn=(e,t)=>M(Z,e,t),nn=N,rn=(e,t,n,r)=>L(Z,e,t,n,r),an=(e,t)=>n=>A(e,X,t)(n),on=_.bind(null,X),sn=g.bind(null,X),cn=v.bind(null,X),ln=h,{uploadRequestsTotal:un,uploadPartsTotal:dn,uploadSuccessTotal:fn,uploadErrorsTotal:pn,apiCallsTotal:mn,uploadDurationHistogram:hn,partUploadDurationHistogram:gn,fileSizeHistogram:_n,partSizeHistogram:vn,activeUploadsGauge:yn,uploadThroughputGauge:bn,uploadLatencySummary:xn}=Z,Q=()=>({uploadCreatedTotal:e.Metric.counter(`upload_created_total`,{description:`Total number of uploads created`}),uploadCompletedTotal:e.Metric.counter(`upload_completed_total`,{description:`Total number of uploads completed successfully`}),uploadFailedTotal:e.Metric.counter(`upload_failed_total`,{description:`Total number of uploads that failed`}),chunkUploadedTotal:e.Metric.counter(`chunk_uploaded_total`,{description:`Total number of chunks uploaded`}),uploadFromUrlTotal:e.Metric.counter(`upload_from_url_total`,{description:`Total number of URL-based uploads`}),uploadFromUrlSuccessTotal:e.Metric.counter(`upload_from_url_success_total`,{description:`Total number of successful URL-based uploads`}),uploadFromUrlFailedTotal:e.Metric.counter(`upload_from_url_failed_total`,{description:`Total number of failed URL-based uploads`}),uploadDurationHistogram:e.Metric.histogram(`upload_duration_seconds`,e.MetricBoundaries.exponential({start:.01,factor:2,count:20}),`Duration of complete upload operations in seconds`),chunkUploadDurationHistogram:e.Metric.histogram(`chunk_upload_duration_seconds`,e.MetricBoundaries.exponential({start:.001,factor:2,count:15}),`Duration of individual chunk uploads in seconds`),uploadFileSizeHistogram:e.Metric.histogram(`upload_file_size_bytes`,e.MetricBoundaries.exponential({start:1024,factor:2,count:25}),`Size of uploaded files in bytes`),chunkSizeHistogram:e.Metric.histogram(`chunk_size_bytes`,e.MetricBoundaries.linear({start:262144,width:262144,count:20}),`Size of uploaded chunks in bytes`),activeUploadsGauge:e.Metric.gauge(`active_uploads`,{description:`Number of currently active uploads`}),uploadThroughputGauge:e.Metric.gauge(`upload_throughput_bytes_per_second`,{description:`Current upload throughput in bytes per second`}),uploadLatencySummary:e.Metric.summary({name:`upload_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Upload operation latency percentiles`}),chunkLatencySummary:e.Metric.summary({name:`chunk_latency_seconds`,maxAge:`10 minutes`,maxSize:1e3,error:.01,quantiles:[.5,.9,.95,.99],description:`Chunk upload latency percentiles`})}),Sn=Q(),Cn=(t,n)=>r=>r.pipe(e.Effect.withSpan(`upload-${t}`,{attributes:{"upload.operation":t,...n}})),wn=t=>e.Effect.annotateCurrentSpan({"upload.id":t.uploadId??`unknown`,"upload.file_name":t.fileName??`unknown`,"upload.file_size":t.fileSize?.toString()??`0`,"upload.storage_id":t.storageId??`unknown`,"upload.mime_type":t.mimeType??`unknown`}),Tn=t=>e.Effect.annotateCurrentSpan({"chunk.upload_id":t.uploadId,"chunk.size":t.chunkSize.toString(),"chunk.offset":t.offset.toString(),"chunk.total_size":t.totalSize?.toString()??`0`,"chunk.progress":t.totalSize&&t.totalSize>0?(t.offset/t.totalSize*100).toFixed(2):`0`}),En=(t=`uploadista-upload-server`)=>{let n=Q();return e.Layer.succeed(l,{serviceName:t,enabled:!0,metrics:{uploadCreated:e.Effect.succeed(n.uploadCreatedTotal).pipe(e.Effect.flatMap(t=>e.Metric.increment(t))),uploadCompleted:e.Effect.succeed(n.uploadCompletedTotal).pipe(e.Effect.flatMap(t=>e.Metric.increment(t))),uploadFailed:e.Effect.succeed(n.uploadFailedTotal).pipe(e.Effect.flatMap(t=>e.Metric.increment(t))),chunkUploaded:e.Effect.succeed(n.chunkUploadedTotal).pipe(e.Effect.flatMap(t=>e.Metric.increment(t)))}})},Dn=En(),On=f(!1),kn=e.Effect.gen(function*(){return(yield*l).metrics}),An=t=>{let n=Q();return e.Effect.gen(function*(){let r=Date.now(),i=yield*t,a=(Date.now()-r)/1e3;return yield*e.Metric.update(n.uploadDurationHistogram,a),i}).pipe(e.Effect.withSpan(`upload-operation`))},jn=t=>{let n=Q();return e.Effect.gen(function*(){let r=Date.now(),i=yield*t,a=(Date.now()-r)/1e3;return yield*e.Metric.update(n.chunkUploadDurationHistogram,a),i}).pipe(e.Effect.withSpan(`chunk-upload`))},$=e=>{if(!e||typeof e!=`object`)return`unknown_error`;let t=`code`in e?e.code:void 0,n=`name`in e?e.name:void 0,r=e instanceof Error?e.message.toLowerCase():``;return t===`ABORTED`||n===`AbortError`||r.includes(`abort`)?`abort_error`:t===`FILE_TOO_LARGE`||t===`LIMIT_FILE_SIZE`||t===`RequestEntityTooLarge`||r.includes(`too large`)||r.includes(`size limit`)||r.includes(`max size`)?`size_limit_error`:t===`INVALID_FILE`||t===`INVALID_METADATA`||t===`VALIDATION_ERROR`||r.includes(`validation`)||r.includes(`invalid`)?`validation_error`:t===`NetworkError`||t===`ECONNRESET`||t===`ENOTFOUND`||t===`ETIMEDOUT`||r.includes(`network`)||r.includes(`timeout`)?`network_error`:t===`UNAUTHORIZED`||t===`AuthenticationFailed`||n===`AuthenticationError`||r.includes(`authentication`)||r.includes(`unauthorized`)?`authentication_error`:t===`FORBIDDEN`||t===`AccessDenied`||n===`AuthorizationError`||r.includes(`forbidden`)||r.includes(`permission`)?`authorization_error`:t===`FILE_WRITE_ERROR`||t===`STORAGE_ERROR`||r.includes(`storage`)||r.includes(`write error`)?`storage_error`:`unknown_error`},Mn=(t,n,r,i={})=>e.Effect.gen(function*(){let a=$(r);yield*t.uploadFailedTotal.pipe(e.Metric.tagged(`operation`,n),e.Metric.tagged(`error_category`,a))(e.Effect.succeed(1));let o={operation:n,error_category:a,error_type:typeof r,error_message:r instanceof Error?r.message:String(r),error_code:r&&typeof r==`object`&&`code`in r?String(r.code):void 0,error_name:r&&typeof r==`object`&&`name`in r?String(r.name):void 0,...i};yield*e.Effect.logError(`Upload ${n} failed`).pipe(e.Effect.annotateLogs(o))}),Nn=e=>t=>{if(e){let n=e(t);if(n!==null)return n}return $(t)},Pn=e.Layer.succeed(l,{serviceName:`uploadista-upload-server-test`,enabled:!0,metrics:{uploadCreated:()=>Promise.resolve(),uploadCompleted:()=>Promise.resolve(),uploadFailed:()=>Promise.resolve(),chunkUploaded:()=>Promise.resolve()}}),Fn=()=>Q(),In=()=>{let e=Fn(),t=[`uploadCreatedTotal`,`uploadCompletedTotal`,`uploadFailedTotal`,`chunkUploadedTotal`,`uploadFromUrlTotal`,`uploadFromUrlSuccessTotal`,`uploadFromUrlFailedTotal`,`uploadDurationHistogram`,`chunkUploadDurationHistogram`,`uploadFileSizeHistogram`,`chunkSizeHistogram`,`activeUploadsGauge`,`uploadThroughputGauge`,`uploadLatencySummary`,`chunkLatencySummary`].filter(t=>!(t in e));if(t.length>0)throw Error(`Missing required metrics: ${t.join(`, `)}`);return!0};exports.AzureObservabilityLayer=rt,exports.AzureTracingLayer=q,exports.FilesystemObservabilityLayer=$t,exports.FilesystemTracingLayer=Xt,exports.FlowObservability=u,exports.FlowObservabilityDisabled=ie,exports.FlowObservabilityLive=ye,exports.GCSObservabilityLayer=Ot,exports.GCSTracingLayer=Y,exports.MetricsService=H,exports.NoOpMetricsServiceLive=ke,exports.NodeSdkLive=de,exports.Observability=s,exports.ObservabilityDisabled=te,exports.S3ObservabilityLayer=Ne,exports.S3TracingLayer=W,exports.StorageObservability=c,exports.StorageObservabilityDisabled=ne,exports.TracingService=D,exports.UploadObservability=l,exports.UploadObservabilityDisabled=re,exports.UploadObservabilityLive=Dn,exports.UploadObservabilityTest=Pn,exports.WebSdkLive=ue,exports.WorkersSdkLive=fe,exports.azureActiveUploadsGauge=St,exports.azureApiCallsTotal=_t,exports.azureFileSizeHistogram=bt,exports.azureMetrics=K,exports.azurePartSizeHistogram=xt,exports.azurePartUploadDurationHistogram=yt,exports.azureUploadDurationHistogram=vt,exports.azureUploadErrorsTotal=gt,exports.azureUploadLatencySummary=wt,exports.azureUploadPartsTotal=mt,exports.azureUploadRequestsTotal=pt,exports.azureUploadSuccessTotal=ht,exports.azureUploadThroughputGauge=Ct,exports.captureMetrics=se,exports.classifyFlowError=B,exports.classifyStorageError=r,exports.classifyUploadError=$,exports.createFlowMetrics=R,exports.createStorageErrorClassifier=i,exports.createStorageErrorTracker=o,exports.createStorageMetrics=S,exports.createStorageTracingLayer=k,exports.createTestFixture=E,exports.createTracingLayer=O,exports.createUploadErrorClassifier=Nn,exports.createUploadGauges=x,exports.createUploadHistograms=b,exports.createUploadMetrics=y,exports.createUploadServerMetrics=Q,exports.createUploadSummaries=oe,exports.filesystemActiveUploadsGauge=yn,exports.filesystemApiCallsTotal=mn,exports.filesystemFileSizeHistogram=_n,exports.filesystemMetrics=Z,exports.filesystemPartSizeHistogram=vn,exports.filesystemPartUploadDurationHistogram=gn,exports.filesystemUploadDurationHistogram=hn,exports.filesystemUploadErrorsTotal=pn,exports.filesystemUploadLatencySummary=xn,exports.filesystemUploadPartsTotal=dn,exports.filesystemUploadRequestsTotal=un,exports.filesystemUploadSuccessTotal=fn,exports.filesystemUploadThroughputGauge=bn,exports.flowMetrics=me,exports.gcsActiveUploadsGauge=qt,exports.gcsApiCallsTotal=Ht,exports.gcsFileSizeHistogram=Gt,exports.gcsMetrics=J,exports.gcsPartSizeHistogram=Kt,exports.gcsPartUploadDurationHistogram=Wt,exports.gcsUploadDurationHistogram=Ut,exports.gcsUploadErrorsTotal=Vt,exports.gcsUploadLatencySummary=Yt,exports.gcsUploadPartsTotal=zt,exports.gcsUploadRequestsTotal=Rt,exports.gcsUploadSuccessTotal=Bt,exports.gcsUploadThroughputGauge=Jt,exports.getFlowMetrics=xe,exports.getTestMetrics=Fn,exports.getUploadMetrics=kn,exports.isObservabilityEnabled=m,exports.logAzureContext=ft,exports.logAzureOperation=lt,exports.logAzureUploadCompletion=dt,exports.logAzureUploadProgress=ut,exports.logFilesystemContext=ln,exports.logFilesystemOperation=on,exports.logFilesystemUploadCompletion=cn,exports.logFilesystemUploadProgress=sn,exports.logGCSContext=Lt,exports.logGCSOperation=Pt,exports.logGCSUploadCompletion=It,exports.logGCSUploadProgress=Ft,exports.logS3Context=He,exports.logS3Operation=ze,exports.logS3UploadCompletion=Ve,exports.logS3UploadProgress=Be,exports.logStorageOperation=_,exports.logUploadCompletion=v,exports.logUploadProgress=g,exports.logWithContext=h,exports.makeFlowObservabilityLayer=p,exports.makeFlowObservabilityLive=z,exports.makeObservabilityLayer=d,exports.makeStorageObservabilityLayer=ee,exports.makeTestFlowObservability=T,exports.makeTestFlowObservabilityUtil=V,exports.makeTestStorageObservability=C,exports.makeTestUploadObservability=w,exports.makeUploadObservabilityLayer=f,exports.makeUploadObservabilityLive=En,exports.runWithTestFlowObservability=Oe,exports.runWithTestObservability=le,exports.s3ActiveUploadsGauge=Qe,exports.s3ApiCallsTotal=qe,exports.s3FileSizeHistogram=Xe,exports.s3Metrics=U,exports.s3PartSizeHistogram=Ze,exports.s3PartUploadDurationHistogram=Ye,exports.s3UploadDurationHistogram=Je,exports.s3UploadErrorsTotal=Ke,exports.s3UploadLatencySummary=et,exports.s3UploadPartsTotal=We,exports.s3UploadRequestsTotal=Ue,exports.s3UploadSuccessTotal=Ge,exports.s3UploadThroughputGauge=$e,exports.trackActiveFlow=we,exports.trackActiveNode=Te,exports.trackAzureError=nt,exports.trackFileSize=P,exports.trackFilesystemError=Qt,exports.trackFlowError=Ee,exports.trackGCSError=Dt,exports.trackNodeError=De,exports.trackPartSize=pe,exports.trackS3Error=Me,exports.trackStorageError=a,exports.trackUploadError=Mn,exports.uploadServerMetrics=Sn,exports.validateMetricsExist=In,exports.whenObservabilityEnabled=ae,exports.withActiveUploadTracking=F,exports.withApiMetrics=M,exports.withAzureApiMetrics=at,exports.withAzureOperationMetrics=st,exports.withAzureSpan=ct,exports.withAzureTimingMetrics=ot,exports.withAzureUploadMetrics=it,exports.withChunkContext=Tn,exports.withChunkDuration=jn,exports.withExecutionContext=ve,exports.withFilesystemApiMetrics=tn,exports.withFilesystemOperationMetrics=rn,exports.withFilesystemSpan=an,exports.withFilesystemTimingMetrics=nn,exports.withFilesystemUploadMetrics=en,exports.withFlowContext=ge,exports.withFlowDuration=Se,exports.withFlowSpan=he,exports.withGCSApiMetrics=At,exports.withGCSOperationMetrics=Mt,exports.withGCSSpan=Nt,exports.withGCSTimingMetrics=jt,exports.withGCSUploadMetrics=kt,exports.withMetricTracking=ce,exports.withNodeContext=_e,exports.withNodeDuration=Ce,exports.withS3ApiMetrics=Fe,exports.withS3OperationMetrics=Le,exports.withS3Span=Re,exports.withS3TimingMetrics=Ie,exports.withS3UploadMetrics=Pe,exports.withStorageOperationMetrics=L,exports.withStorageSpan=A,exports.withThroughputTracking=I,exports.withTimingMetrics=N,exports.withUploadContext=wn,exports.withUploadDuration=An,exports.withUploadMetrics=j,exports.withUploadSpan=Cn;
|
package/dist/index.d.cts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Context, Effect, Layer, Metric, Option } from "effect";
|
|
2
|
-
import * as
|
|
3
|
-
import * as
|
|
2
|
+
import * as effect_MetricKeyType7 from "effect/MetricKeyType";
|
|
3
|
+
import * as effect_MetricState7 from "effect/MetricState";
|
|
4
4
|
import * as effect_Tracer0 from "effect/Tracer";
|
|
5
5
|
import * as _effect_opentelemetry_Resource0 from "@effect/opentelemetry/Resource";
|
|
6
6
|
import * as effect_Metric0 from "effect/Metric";
|
|
@@ -14,10 +14,10 @@ declare const createUploadMetrics: (storageType: string) => {
|
|
|
14
14
|
apiCallsTotal: Metric.Metric.Counter<number>;
|
|
15
15
|
};
|
|
16
16
|
declare const createUploadHistograms: (storageType: string) => {
|
|
17
|
-
uploadDurationHistogram: Metric.Metric<
|
|
18
|
-
partUploadDurationHistogram: Metric.Metric<
|
|
19
|
-
fileSizeHistogram: Metric.Metric<
|
|
20
|
-
partSizeHistogram: Metric.Metric<
|
|
17
|
+
uploadDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
18
|
+
partUploadDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
19
|
+
fileSizeHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
20
|
+
partSizeHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
21
21
|
};
|
|
22
22
|
declare const createUploadGauges: (storageType: string) => {
|
|
23
23
|
activeUploadsGauge: Metric.Metric.Gauge<number>;
|
|
@@ -30,10 +30,10 @@ declare const createStorageMetrics: (storageType: string) => {
|
|
|
30
30
|
uploadLatencySummary: Metric.Metric.Summary<number>;
|
|
31
31
|
activeUploadsGauge: Metric.Metric.Gauge<number>;
|
|
32
32
|
uploadThroughputGauge: Metric.Metric.Gauge<number>;
|
|
33
|
-
uploadDurationHistogram: Metric.Metric<
|
|
34
|
-
partUploadDurationHistogram: Metric.Metric<
|
|
35
|
-
fileSizeHistogram: Metric.Metric<
|
|
36
|
-
partSizeHistogram: Metric.Metric<
|
|
33
|
+
uploadDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
34
|
+
partUploadDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
35
|
+
fileSizeHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
36
|
+
partSizeHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
37
37
|
uploadRequestsTotal: Metric.Metric.Counter<number>;
|
|
38
38
|
uploadPartsTotal: Metric.Metric.Counter<number>;
|
|
39
39
|
uploadSuccessTotal: Metric.Metric.Counter<number>;
|
|
@@ -250,10 +250,10 @@ declare const createFlowMetrics: () => {
|
|
|
250
250
|
nodeSuccessTotal: Metric.Metric.Counter<number>;
|
|
251
251
|
nodeFailedTotal: Metric.Metric.Counter<number>;
|
|
252
252
|
nodeSkippedTotal: Metric.Metric.Counter<number>;
|
|
253
|
-
flowDurationHistogram: Metric.Metric<
|
|
254
|
-
nodeDurationHistogram: Metric.Metric<
|
|
255
|
-
flowNodeCountHistogram: Metric.Metric<
|
|
256
|
-
parallelNodesHistogram: Metric.Metric<
|
|
253
|
+
flowDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
254
|
+
nodeDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
255
|
+
flowNodeCountHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
256
|
+
parallelNodesHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
257
257
|
activeFlowsGauge: Metric.Metric.Gauge<number>;
|
|
258
258
|
activeNodesGauge: Metric.Metric.Gauge<number>;
|
|
259
259
|
pausedFlowsGauge: Metric.Metric.Gauge<number>;
|
|
@@ -277,10 +277,10 @@ declare const flowMetrics: {
|
|
|
277
277
|
nodeSuccessTotal: Metric.Metric.Counter<number>;
|
|
278
278
|
nodeFailedTotal: Metric.Metric.Counter<number>;
|
|
279
279
|
nodeSkippedTotal: Metric.Metric.Counter<number>;
|
|
280
|
-
flowDurationHistogram: Metric.Metric<
|
|
281
|
-
nodeDurationHistogram: Metric.Metric<
|
|
282
|
-
flowNodeCountHistogram: Metric.Metric<
|
|
283
|
-
parallelNodesHistogram: Metric.Metric<
|
|
280
|
+
flowDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
281
|
+
nodeDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
282
|
+
flowNodeCountHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
283
|
+
parallelNodesHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
284
284
|
activeFlowsGauge: Metric.Metric.Gauge<number>;
|
|
285
285
|
activeNodesGauge: Metric.Metric.Gauge<number>;
|
|
286
286
|
pausedFlowsGauge: Metric.Metric.Gauge<number>;
|
|
@@ -409,10 +409,10 @@ declare const s3Metrics: {
|
|
|
409
409
|
uploadLatencySummary: effect_Metric0.Metric.Summary<number>;
|
|
410
410
|
activeUploadsGauge: effect_Metric0.Metric.Gauge<number>;
|
|
411
411
|
uploadThroughputGauge: effect_Metric0.Metric.Gauge<number>;
|
|
412
|
-
uploadDurationHistogram: effect_Metric0.Metric<
|
|
413
|
-
partUploadDurationHistogram: effect_Metric0.Metric<
|
|
414
|
-
fileSizeHistogram: effect_Metric0.Metric<
|
|
415
|
-
partSizeHistogram: effect_Metric0.Metric<
|
|
412
|
+
uploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
413
|
+
partUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
414
|
+
fileSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
415
|
+
partSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
416
416
|
uploadRequestsTotal: effect_Metric0.Metric.Counter<number>;
|
|
417
417
|
uploadPartsTotal: effect_Metric0.Metric.Counter<number>;
|
|
418
418
|
uploadSuccessTotal: effect_Metric0.Metric.Counter<number>;
|
|
@@ -447,7 +447,7 @@ declare const logS3UploadCompletion: (uploadId: string, metrics: {
|
|
|
447
447
|
retryCount?: number;
|
|
448
448
|
}) => Effect.Effect<void, never, never>;
|
|
449
449
|
declare const logS3Context: (message: string, context: Record<string, unknown>) => Effect.Effect<void, never, never>;
|
|
450
|
-
declare const s3UploadRequestsTotal: effect_Metric0.Metric.Counter<number>, s3UploadPartsTotal: effect_Metric0.Metric.Counter<number>, s3UploadSuccessTotal: effect_Metric0.Metric.Counter<number>, s3UploadErrorsTotal: effect_Metric0.Metric.Counter<number>, s3ApiCallsTotal: effect_Metric0.Metric.Counter<number>, s3UploadDurationHistogram: effect_Metric0.Metric<
|
|
450
|
+
declare const s3UploadRequestsTotal: effect_Metric0.Metric.Counter<number>, s3UploadPartsTotal: effect_Metric0.Metric.Counter<number>, s3UploadSuccessTotal: effect_Metric0.Metric.Counter<number>, s3UploadErrorsTotal: effect_Metric0.Metric.Counter<number>, s3ApiCallsTotal: effect_Metric0.Metric.Counter<number>, s3UploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, s3PartUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, s3FileSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, s3PartSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, s3ActiveUploadsGauge: effect_Metric0.Metric.Gauge<number>, s3UploadThroughputGauge: effect_Metric0.Metric.Gauge<number>, s3UploadLatencySummary: effect_Metric0.Metric.Summary<number>;
|
|
451
451
|
type S3Metrics = StorageMetrics;
|
|
452
452
|
//#endregion
|
|
453
453
|
//#region src/storage/azure.d.ts
|
|
@@ -455,10 +455,10 @@ declare const azureMetrics: {
|
|
|
455
455
|
uploadLatencySummary: effect_Metric0.Metric.Summary<number>;
|
|
456
456
|
activeUploadsGauge: effect_Metric0.Metric.Gauge<number>;
|
|
457
457
|
uploadThroughputGauge: effect_Metric0.Metric.Gauge<number>;
|
|
458
|
-
uploadDurationHistogram: effect_Metric0.Metric<
|
|
459
|
-
partUploadDurationHistogram: effect_Metric0.Metric<
|
|
460
|
-
fileSizeHistogram: effect_Metric0.Metric<
|
|
461
|
-
partSizeHistogram: effect_Metric0.Metric<
|
|
458
|
+
uploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
459
|
+
partUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
460
|
+
fileSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
461
|
+
partSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
462
462
|
uploadRequestsTotal: effect_Metric0.Metric.Counter<number>;
|
|
463
463
|
uploadPartsTotal: effect_Metric0.Metric.Counter<number>;
|
|
464
464
|
uploadSuccessTotal: effect_Metric0.Metric.Counter<number>;
|
|
@@ -493,7 +493,7 @@ declare const logAzureUploadCompletion: (uploadId: string, metrics: {
|
|
|
493
493
|
retryCount?: number;
|
|
494
494
|
}) => Effect.Effect<void, never, never>;
|
|
495
495
|
declare const logAzureContext: (message: string, context: Record<string, unknown>) => Effect.Effect<void, never, never>;
|
|
496
|
-
declare const azureUploadRequestsTotal: effect_Metric0.Metric.Counter<number>, azureUploadPartsTotal: effect_Metric0.Metric.Counter<number>, azureUploadSuccessTotal: effect_Metric0.Metric.Counter<number>, azureUploadErrorsTotal: effect_Metric0.Metric.Counter<number>, azureApiCallsTotal: effect_Metric0.Metric.Counter<number>, azureUploadDurationHistogram: effect_Metric0.Metric<
|
|
496
|
+
declare const azureUploadRequestsTotal: effect_Metric0.Metric.Counter<number>, azureUploadPartsTotal: effect_Metric0.Metric.Counter<number>, azureUploadSuccessTotal: effect_Metric0.Metric.Counter<number>, azureUploadErrorsTotal: effect_Metric0.Metric.Counter<number>, azureApiCallsTotal: effect_Metric0.Metric.Counter<number>, azureUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, azurePartUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, azureFileSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, azurePartSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, azureActiveUploadsGauge: effect_Metric0.Metric.Gauge<number>, azureUploadThroughputGauge: effect_Metric0.Metric.Gauge<number>, azureUploadLatencySummary: effect_Metric0.Metric.Summary<number>;
|
|
497
497
|
type AzureMetrics = StorageMetrics;
|
|
498
498
|
//#endregion
|
|
499
499
|
//#region src/storage/gcs.d.ts
|
|
@@ -501,10 +501,10 @@ declare const gcsMetrics: {
|
|
|
501
501
|
uploadLatencySummary: effect_Metric0.Metric.Summary<number>;
|
|
502
502
|
activeUploadsGauge: effect_Metric0.Metric.Gauge<number>;
|
|
503
503
|
uploadThroughputGauge: effect_Metric0.Metric.Gauge<number>;
|
|
504
|
-
uploadDurationHistogram: effect_Metric0.Metric<
|
|
505
|
-
partUploadDurationHistogram: effect_Metric0.Metric<
|
|
506
|
-
fileSizeHistogram: effect_Metric0.Metric<
|
|
507
|
-
partSizeHistogram: effect_Metric0.Metric<
|
|
504
|
+
uploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
505
|
+
partUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
506
|
+
fileSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
507
|
+
partSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
508
508
|
uploadRequestsTotal: effect_Metric0.Metric.Counter<number>;
|
|
509
509
|
uploadPartsTotal: effect_Metric0.Metric.Counter<number>;
|
|
510
510
|
uploadSuccessTotal: effect_Metric0.Metric.Counter<number>;
|
|
@@ -539,7 +539,7 @@ declare const logGCSUploadCompletion: (uploadId: string, metrics: {
|
|
|
539
539
|
retryCount?: number;
|
|
540
540
|
}) => Effect.Effect<void, never, never>;
|
|
541
541
|
declare const logGCSContext: (message: string, context: Record<string, unknown>) => Effect.Effect<void, never, never>;
|
|
542
|
-
declare const gcsUploadRequestsTotal: effect_Metric0.Metric.Counter<number>, gcsUploadPartsTotal: effect_Metric0.Metric.Counter<number>, gcsUploadSuccessTotal: effect_Metric0.Metric.Counter<number>, gcsUploadErrorsTotal: effect_Metric0.Metric.Counter<number>, gcsApiCallsTotal: effect_Metric0.Metric.Counter<number>, gcsUploadDurationHistogram: effect_Metric0.Metric<
|
|
542
|
+
declare const gcsUploadRequestsTotal: effect_Metric0.Metric.Counter<number>, gcsUploadPartsTotal: effect_Metric0.Metric.Counter<number>, gcsUploadSuccessTotal: effect_Metric0.Metric.Counter<number>, gcsUploadErrorsTotal: effect_Metric0.Metric.Counter<number>, gcsApiCallsTotal: effect_Metric0.Metric.Counter<number>, gcsUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, gcsPartUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, gcsFileSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, gcsPartSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, gcsActiveUploadsGauge: effect_Metric0.Metric.Gauge<number>, gcsUploadThroughputGauge: effect_Metric0.Metric.Gauge<number>, gcsUploadLatencySummary: effect_Metric0.Metric.Summary<number>;
|
|
543
543
|
type GCSMetrics = StorageMetrics;
|
|
544
544
|
//#endregion
|
|
545
545
|
//#region src/storage/filesystem.d.ts
|
|
@@ -547,10 +547,10 @@ declare const filesystemMetrics: {
|
|
|
547
547
|
uploadLatencySummary: effect_Metric0.Metric.Summary<number>;
|
|
548
548
|
activeUploadsGauge: effect_Metric0.Metric.Gauge<number>;
|
|
549
549
|
uploadThroughputGauge: effect_Metric0.Metric.Gauge<number>;
|
|
550
|
-
uploadDurationHistogram: effect_Metric0.Metric<
|
|
551
|
-
partUploadDurationHistogram: effect_Metric0.Metric<
|
|
552
|
-
fileSizeHistogram: effect_Metric0.Metric<
|
|
553
|
-
partSizeHistogram: effect_Metric0.Metric<
|
|
550
|
+
uploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
551
|
+
partUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
552
|
+
fileSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
553
|
+
partSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
554
554
|
uploadRequestsTotal: effect_Metric0.Metric.Counter<number>;
|
|
555
555
|
uploadPartsTotal: effect_Metric0.Metric.Counter<number>;
|
|
556
556
|
uploadSuccessTotal: effect_Metric0.Metric.Counter<number>;
|
|
@@ -585,7 +585,7 @@ declare const logFilesystemUploadCompletion: (uploadId: string, metrics: {
|
|
|
585
585
|
retryCount?: number;
|
|
586
586
|
}) => Effect.Effect<void, never, never>;
|
|
587
587
|
declare const logFilesystemContext: (message: string, context: Record<string, unknown>) => Effect.Effect<void, never, never>;
|
|
588
|
-
declare const filesystemUploadRequestsTotal: effect_Metric0.Metric.Counter<number>, filesystemUploadPartsTotal: effect_Metric0.Metric.Counter<number>, filesystemUploadSuccessTotal: effect_Metric0.Metric.Counter<number>, filesystemUploadErrorsTotal: effect_Metric0.Metric.Counter<number>, filesystemApiCallsTotal: effect_Metric0.Metric.Counter<number>, filesystemUploadDurationHistogram: effect_Metric0.Metric<
|
|
588
|
+
declare const filesystemUploadRequestsTotal: effect_Metric0.Metric.Counter<number>, filesystemUploadPartsTotal: effect_Metric0.Metric.Counter<number>, filesystemUploadSuccessTotal: effect_Metric0.Metric.Counter<number>, filesystemUploadErrorsTotal: effect_Metric0.Metric.Counter<number>, filesystemApiCallsTotal: effect_Metric0.Metric.Counter<number>, filesystemUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, filesystemPartUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, filesystemFileSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, filesystemPartSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>, filesystemActiveUploadsGauge: effect_Metric0.Metric.Gauge<number>, filesystemUploadThroughputGauge: effect_Metric0.Metric.Gauge<number>, filesystemUploadLatencySummary: effect_Metric0.Metric.Summary<number>;
|
|
589
589
|
type FilesystemMetrics = StorageMetrics;
|
|
590
590
|
//#endregion
|
|
591
591
|
//#region src/upload/metrics.d.ts
|
|
@@ -600,10 +600,10 @@ declare const createUploadServerMetrics: () => {
|
|
|
600
600
|
uploadFromUrlTotal: Metric.Metric.Counter<number>;
|
|
601
601
|
uploadFromUrlSuccessTotal: Metric.Metric.Counter<number>;
|
|
602
602
|
uploadFromUrlFailedTotal: Metric.Metric.Counter<number>;
|
|
603
|
-
uploadDurationHistogram: Metric.Metric<
|
|
604
|
-
chunkUploadDurationHistogram: Metric.Metric<
|
|
605
|
-
uploadFileSizeHistogram: Metric.Metric<
|
|
606
|
-
chunkSizeHistogram: Metric.Metric<
|
|
603
|
+
uploadDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
604
|
+
chunkUploadDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
605
|
+
uploadFileSizeHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
606
|
+
chunkSizeHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
607
607
|
activeUploadsGauge: Metric.Metric.Gauge<number>;
|
|
608
608
|
uploadThroughputGauge: Metric.Metric.Gauge<number>;
|
|
609
609
|
uploadLatencySummary: Metric.Metric.Summary<number>;
|
|
@@ -624,10 +624,10 @@ declare const uploadServerMetrics: {
|
|
|
624
624
|
uploadFromUrlTotal: Metric.Metric.Counter<number>;
|
|
625
625
|
uploadFromUrlSuccessTotal: Metric.Metric.Counter<number>;
|
|
626
626
|
uploadFromUrlFailedTotal: Metric.Metric.Counter<number>;
|
|
627
|
-
uploadDurationHistogram: Metric.Metric<
|
|
628
|
-
chunkUploadDurationHistogram: Metric.Metric<
|
|
629
|
-
uploadFileSizeHistogram: Metric.Metric<
|
|
630
|
-
chunkSizeHistogram: Metric.Metric<
|
|
627
|
+
uploadDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
628
|
+
chunkUploadDurationHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
629
|
+
uploadFileSizeHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
630
|
+
chunkSizeHistogram: Metric.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
631
631
|
activeUploadsGauge: Metric.Metric.Gauge<number>;
|
|
632
632
|
uploadThroughputGauge: Metric.Metric.Gauge<number>;
|
|
633
633
|
uploadLatencySummary: Metric.Metric.Summary<number>;
|
|
@@ -718,10 +718,10 @@ declare const getTestMetrics: () => {
|
|
|
718
718
|
uploadFromUrlTotal: effect_Metric0.Metric.Counter<number>;
|
|
719
719
|
uploadFromUrlSuccessTotal: effect_Metric0.Metric.Counter<number>;
|
|
720
720
|
uploadFromUrlFailedTotal: effect_Metric0.Metric.Counter<number>;
|
|
721
|
-
uploadDurationHistogram: effect_Metric0.Metric<
|
|
722
|
-
chunkUploadDurationHistogram: effect_Metric0.Metric<
|
|
723
|
-
uploadFileSizeHistogram: effect_Metric0.Metric<
|
|
724
|
-
chunkSizeHistogram: effect_Metric0.Metric<
|
|
721
|
+
uploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
722
|
+
chunkUploadDurationHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
723
|
+
uploadFileSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
724
|
+
chunkSizeHistogram: effect_Metric0.Metric<effect_MetricKeyType7.MetricKeyType.Histogram, number, effect_MetricState7.MetricState.Histogram>;
|
|
725
725
|
activeUploadsGauge: effect_Metric0.Metric.Gauge<number>;
|
|
726
726
|
uploadThroughputGauge: effect_Metric0.Metric.Gauge<number>;
|
|
727
727
|
uploadLatencySummary: effect_Metric0.Metric.Summary<number>;
|
package/dist/index.d.cts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.cts","names":[],"sources":["../src/core/metrics.ts","../src/core/errors.ts","../src/core/layers.ts","../src/core/logging.ts","../src/core/testing.ts","../src/core/tracing.ts","../src/core/utilities.ts","../src/flow/metrics.ts","../src/flow/tracing.ts","../src/flow/layers.ts","../src/flow/errors.ts","../src/flow/testing.ts","../src/service/metrics.ts","../src/storage/s3.ts","../src/storage/azure.ts","../src/storage/gcs.ts","../src/storage/filesystem.ts","../src/upload/metrics.ts","../src/upload/tracing.ts","../src/upload/layers.ts","../src/upload/errors.ts","../src/upload/testing.ts"],"sourcesContent":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.d.cts","names":[],"sources":["../src/core/metrics.ts","../src/core/errors.ts","../src/core/layers.ts","../src/core/logging.ts","../src/core/testing.ts","../src/core/tracing.ts","../src/core/utilities.ts","../src/flow/metrics.ts","../src/flow/tracing.ts","../src/flow/layers.ts","../src/flow/errors.ts","../src/flow/testing.ts","../src/service/metrics.ts","../src/storage/s3.ts","../src/storage/azure.ts","../src/storage/gcs.ts","../src/storage/filesystem.ts","../src/upload/metrics.ts","../src/upload/tracing.ts","../src/upload/layers.ts","../src/upload/errors.ts","../src/upload/testing.ts"],"sourcesContent":[],"mappings":"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"}
|