@easbot/plugin 0.1.11
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/LICENSE +21 -0
- package/README.md +0 -0
- package/dist/index.cjs +1 -0
- package/dist/index.d.cts +1863 -0
- package/dist/index.d.ts +1863 -0
- package/dist/index.mjs +1 -0
- package/package.json +80 -0
package/dist/index.mjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import k,{z as z$1}from'zod';export{buildToolArgs,createTool,toolSchema as schema}from'@easbot/types';import'@easbot/sdk';function C(r){return {description:r.description,args:r.args,execute:r.execute}}C.schema=k;var p={Command:"command",Prompt:"prompt",Http:"http",Agent:"agent",Function:"function"},o={SessionStart:"session.start",SessionEnd:"session.end",SessionCompacting:"session.compacting",SessionCompact:"session.compact",StepStart:"step.start",StepFinish:"step.finish",StepStop:"step.stop",StepStopFailure:"step.stop.failure",MessageReceive:"message.receive",MessageTransform:"message.transform",SystemTransform:"system.transform",ToolBefore:"tool.before",ToolAfter:"tool.after",ToolFailure:"tool.failure",ToolDefinition:"tool.definition",CommandBefore:"command.before",CommandAfter:"command.after",PermissionAsk:"permission.ask",PermissionDenied:"permission.denied",LlmParams:"llm.params",LlmHeaders:"llm.headers",ShellEnv:"shell.env",TextComplete:"text.complete",GatewayMessageReceive:"gateway.message.receive",GatewayMessageProcess:"gateway.message.process",GatewayMessageComplete:"gateway.message.complete",GatewayMessageSend:"gateway.message.send",HeartbeatTrigger:"scheduler.heartbeat.trigger",HeartbeatComplete:"scheduler.heartbeat.complete",ScheduledTaskTrigger:"scheduler.task.trigger",ScheduledTaskComplete:"scheduler.task.complete",ContextBuildBefore:"context.build.before",ContextBuildAfter:"context.build.after"},He=Object.values(o);var d=z$1.string().optional(),T=z$1.object({type:z$1.literal(p.Command),command:z$1.string(),if:d,shell:z$1.enum(["bash","powershell"]).optional(),timeout:z$1.number().positive().optional(),statusMessage:z$1.string().optional(),once:z$1.boolean().optional(),async:z$1.boolean().optional()}),v=z$1.object({type:z$1.literal(p.Prompt),if:d,timeout:z$1.number().positive().optional(),model:z$1.string().optional(),statusMessage:z$1.string().optional(),once:z$1.boolean().optional(),runMode:z$1.enum(["session","fork"]).optional(),system:z$1.string().optional(),parts:z$1.array(z$1.unknown())}),P=z$1.object({type:z$1.literal(p.Http),url:z$1.string(),if:d,timeout:z$1.number().positive().optional(),method:z$1.enum(["GET","POST","PUT","DELETE"]).optional(),headers:z$1.record(z$1.string(),z$1.string()).optional(),allowedEnvVars:z$1.array(z$1.string()).optional(),statusMessage:z$1.string().optional(),once:z$1.boolean().optional()}),H=z$1.object({type:z$1.literal(p.Agent),if:d,timeout:z$1.number().positive().optional(),model:z$1.string().optional(),statusMessage:z$1.string().optional(),once:z$1.boolean().optional(),system:z$1.string().optional(),parts:z$1.array(z$1.unknown())}),D=z$1.object({type:z$1.literal(p.Function),handler:z$1.function()}),E=z$1.discriminatedUnion("type",[T,v,P,H,D]),w=z$1.object({event:z$1.string(),matcher:z$1.string().optional(),hooks:z$1.array(E)}),je=z$1.record(z$1.string(),z$1.array(w)),n=z$1.string().min(1).describe("Session unique identifier"),s=z$1.string().min(1).describe("Message unique identifier"),c=z$1.string().min(1).describe("Tool call unique identifier"),u=z$1.string().optional().describe("Agent name"),l=z$1.string().optional().describe("Model identifier"),b=z$1.object({providerID:z$1.string().describe("Provider ID"),modelID:z$1.string().describe("Model ID"),api:z$1.object({id:z$1.string().describe("API ID"),npm:z$1.string().optional().describe("NPM package name")}).optional().describe("API information")}).optional().describe("Model object"),S=z$1.string().optional().describe("Working directory path"),M=z$1.enum(["user_request","max_tokens","stop","error","timeout","cancelled"]).describe("Session end reason"),j=z$1.enum(["stop","max_tokens","end_turn","stop_sequence"]).describe("Step finish reason"),A=z$1.object({sessionID:n,source:z$1.enum(["user","agent","system","scheduled"]).optional().describe("Session source"),model:l,agent:u,cwd:S}),z=z$1.object({sessionID:n,reason:M,duration:z$1.number().positive().optional().describe("Session duration in milliseconds")}),R=z$1.object({sessionID:n,trigger:z$1.enum(["manual","auto","threshold"]).describe("Compaction trigger"),contextLength:z$1.number().positive().describe("Current context length"),threshold:z$1.number().positive().describe("Trigger threshold")}),F=z$1.object({sessionID:n,summary:z$1.string().describe("Compaction summary"),previousLength:z$1.number().positive().describe("Previous context length"),newLength:z$1.number().positive().describe("New context length")}),O=z$1.object({sessionID:n,messageID:s,model:l,agent:u}),W=z$1.object({sessionID:n,messageID:s,model:l,agent:u,finishReason:j,tokens:z$1.object({input:z$1.number().int().nonnegative().optional(),output:z$1.number().int().nonnegative().optional(),total:z$1.number().int().nonnegative().optional()}).optional().describe("Token usage statistics")}),B=z$1.object({sessionID:n,reason:z$1.string().describe("Stop reason")}),G=z$1.object({sessionID:n,error:z$1.string().describe("Error message"),errorType:z$1.enum(["rate_limit","auth_error","network_error","timeout","invalid_request","server_error"]).describe("Error type")}),L=z$1.enum(["user","assistant","system","tool"]),I=z$1.discriminatedUnion("type",[z$1.object({type:z$1.literal("text"),text:z$1.string().describe("Text content")}),z$1.object({type:z$1.literal("image"),source:z$1.object({type:z$1.enum(["base64","url"]),mime:z$1.string().optional().describe("File mime type"),data:z$1.string().describe("File base64 encoding data or url")})}),z$1.object({type:z$1.literal("file"),url:z$1.string().describe("File path"),filename:z$1.string().describe("File name"),mime:z$1.string().optional().describe("File mime type")})]),h=z$1.object({id:s,role:L,content:z$1.union([z$1.string(),z$1.array(I)]),name:z$1.string().optional().describe("Message sender name"),tool_call_id:c.optional().describe("Related tool call ID")}),_=z$1.object({sessionID:n,agent:u,model:l,messageID:s,message:z$1.object({id:s,role:z$1.literal("user"),content:z$1.union([z$1.string(),z$1.array(I)])}).describe("User message")}),q=z$1.object({sessionID:n,messages:z$1.array(h).describe("Messages to transform")}),N=z$1.object({sessionID:n,model:l,system:z$1.array(z$1.string()).describe("Current system prompt")}),g=z$1.record(z$1.string(),z$1.unknown()).describe("Tool call arguments"),U=z$1.object({title:z$1.string().optional().describe("Result title"),content:z$1.string().describe("Result content"),is_error:z$1.boolean().optional().describe("Is error result"),metadata:z$1.record(z$1.string(),z$1.unknown()).optional().describe("Extra metadata")}),Z=z$1.object({sessionID:n,tool:z$1.string().describe("Tool name"),callID:c,args:g}),V=z$1.object({sessionID:n,tool:z$1.string(),callID:c,args:g,result:U,duration:z$1.number().nonnegative().optional().describe("Execution duration in milliseconds")}),$=z$1.object({sessionID:n,tool:z$1.string(),callID:c,args:g,error:z$1.string().describe("Error message"),errorType:z$1.enum(["timeout","invalid_args","execution_error","permission_denied"])}),K=z$1.object({sessionID:n,toolID:z$1.string().describe("Tool ID"),definition:z$1.object({name:z$1.string(),description:z$1.string().optional(),parameters:z$1.record(z$1.string(),z$1.unknown()).optional()}).describe("Tool definition")}),J=z$1.object({sessionID:n,command:z$1.string().describe("Command name"),arguments:z$1.union([z$1.string(),z$1.record(z$1.string(),z$1.unknown())]).describe("Command arguments")}),Q=z$1.object({sessionID:n,command:z$1.string().describe("Command name"),arguments:z$1.union([z$1.string(),z$1.record(z$1.string(),z$1.unknown())]).optional(),result:z$1.object({info:z$1.unknown().optional().describe("Message info"),parts:z$1.array(z$1.unknown()).optional().describe("Message parts"),title:z$1.string().optional().describe("Result title"),metadata:z$1.record(z$1.string(),z$1.unknown()).optional().describe("Result metadata"),output:z$1.string().optional().describe("Result output"),success:z$1.boolean().optional().describe("Whether execution succeeded"),error:z$1.string().optional().describe("Error message if failed")}).describe("Command execution result")}),X=z$1.enum(["read","write","exec","admin"]),Y=z$1.object({tool:z$1.string().describe("Tool name requesting permission"),args:g.optional(),level:X.optional(),reason:z$1.string().optional().describe("Reason for permission request")}),ee=z$1.object({sessionID:n,request:Y}),te=z$1.object({sessionID:n,tool:z$1.string(),reason:z$1.string().optional()}),x=z$1.enum(["openai","anthropic","google","azure","custom"]),oe=z$1.object({temperature:z$1.number().min(0).max(2).optional(),topP:z$1.number().min(0).max(1).optional(),topK:z$1.number().int().positive().optional(),maxTokens:z$1.number().int().positive().optional(),stopSequences:z$1.array(z$1.string()).optional(),responseFormat:z$1.enum(["text","json_object"]).optional()}),ne=z$1.object({sessionID:n,agent:u,model:b,provider:x,params:oe.partial().optional()}),re=z$1.object({sessionID:n,agent:u,model:b,provider:x,headers:z$1.record(z$1.string(),z$1.string()).optional()}),se=z$1.object({cwd:S.describe("Working directory"),sessionID:n.optional(),callID:c.optional()}),ie=z$1.object({sessionID:n,messageID:s,partID:z$1.string().describe("Text part ID"),text:z$1.string().describe("Completed text")}),ae=z$1.object({sessionID:n,mode:z$1.enum(["agent","chat","query"]).describe("Build mode"),projectID:z$1.string().optional()}),pe=z$1.object({sessionID:n,context:z$1.object({messages:z$1.array(h),system:z$1.array(z$1.string()),metadata:z$1.record(z$1.string(),z$1.unknown())}).describe("Built context")}),ue=z$1.object({gatewayID:z$1.string().describe("Gateway ID"),messageID:s,message:z$1.unknown().describe("Received message")}),me=z$1.object({gatewayID:z$1.string(),messageID:s,message:z$1.unknown(),sessionID:n.optional()}),ce=z$1.object({gatewayID:z$1.string(),messageID:s,result:z$1.unknown().optional()}),le=z$1.object({gatewayID:z$1.string(),messageID:s,message:z$1.unknown(),target:z$1.string().optional().describe("Send target")}),de=z$1.object({sessionID:n.optional(),timestamp:z$1.number().describe("Heartbeat timestamp"),name:z$1.string().optional().describe("Heartbeat name")}),ge=z$1.object({sessionID:n.optional(),timestamp:z$1.number(),duration:z$1.number().nonnegative().optional()}),fe=z$1.object({taskID:z$1.string().describe("Task ID"),taskName:z$1.string().optional(),timestamp:z$1.number(),payload:z$1.record(z$1.string(),z$1.unknown()).optional()}),ye=z$1.object({taskID:z$1.string(),timestamp:z$1.number(),success:z$1.boolean(),result:z$1.record(z$1.string(),z$1.unknown()).optional(),error:z$1.string().optional()}),y={[o.SessionStart]:A,[o.SessionEnd]:z,[o.SessionCompacting]:R,[o.SessionCompact]:F,[o.StepStart]:O,[o.StepFinish]:W,[o.StepStop]:B,[o.StepStopFailure]:G,[o.MessageReceive]:_,[o.MessageTransform]:q,[o.SystemTransform]:N,[o.ToolBefore]:Z,[o.ToolAfter]:V,[o.ToolFailure]:$,[o.ToolDefinition]:K,[o.CommandBefore]:J,[o.CommandAfter]:Q,[o.PermissionAsk]:ee,[o.PermissionDenied]:te,[o.LlmParams]:ne,[o.LlmHeaders]:re,[o.ShellEnv]:se,[o.TextComplete]:ie,[o.ContextBuildBefore]:ae,[o.ContextBuildAfter]:pe,[o.GatewayMessageReceive]:ue,[o.GatewayMessageProcess]:me,[o.GatewayMessageComplete]:ce,[o.GatewayMessageSend]:le,[o.HeartbeatTrigger]:de,[o.HeartbeatComplete]:ge,[o.ScheduledTaskTrigger]:fe,[o.ScheduledTaskComplete]:ye};function Ae(r){return y[r]}function ze(r,f){let m=y[r];if(!m)throw new Error(`No schema found for event: ${r}`);return m.parse(f)}function Re(r,f){let m=y[r];return m?m.safeParse(f):{success:false,error:new z$1.ZodError([{code:"custom",path:[],message:`No schema found for event: ${r}`}])}}var Ne=z$1.enum(["command","mcp","skill"]).describe("Command source"),be=z$1.union([z$1.string(),z$1.record(z$1.string(),z$1.unknown())]).describe("Command arguments"),Se=z$1.discriminatedUnion("type",[z$1.object({type:z$1.literal("text"),text:z$1.string().describe("Text content")}),z$1.object({type:z$1.literal("image"),source:z$1.object({type:z$1.enum(["base64","url"]),mime:z$1.string().describe("File mime type"),data:z$1.string().describe("File base64 encoding data or url")})}),z$1.object({type:z$1.literal("file"),url:z$1.string().describe("File path"),filename:z$1.string().describe("File name"),mime:z$1.string().optional().describe("File mime type")})]),Ue=z$1.object({name:z$1.string().describe("Command name"),description:z$1.string().describe("Command description"),agent:z$1.string().optional().describe("Specified agent name"),model:z$1.string().optional().describe("Specified model"),hints:z$1.array(z$1.string()).optional().describe("Argument hints"),commandType:z$1.enum(["prompt","local"]).optional().describe("Command type"),hidden:z$1.boolean().optional().describe("Whether hidden")}),Ze=z$1.object({sessionID:z$1.string().describe("Session ID"),directory:z$1.string().describe("Working directory"),model:z$1.string().optional().describe("Model identifier"),agent:z$1.string().optional().describe("Agent name"),arguments:be.describe("Command arguments")}),Ie=z$1.record(z$1.string(),z$1.unknown()).describe("Result metadata"),Ve=z$1.object({title:z$1.string().describe("Result title"),metadata:Ie.describe("Result metadata"),output:z$1.string().describe("Result output"),parts:z$1.array(Se).optional().describe("Result parts"),success:z$1.boolean().describe("Whether execution succeeded"),error:z$1.string().optional().describe("Error message if failed")}),$e=z$1.object({agent:z$1.object({name:z$1.string().describe("Agent name"),model:z$1.string().optional().describe("Agent model")}).optional().describe("Agent context")}),Ke=z$1.object({isEnabled:z$1.boolean().optional().describe("Is enabled check result")});export{H as AgentExecutorSchema,u as AgentSchema,c as CallIDSchema,Q as CommandAfterInputSchema,be as CommandArgumentsSchema,J as CommandBeforeInputSchema,Ie as CommandExecuteResultMetadataSchema,Ve as CommandExecuteResultSchema,Ze as CommandExecutionContextSchema,T as CommandExecutorSchema,$e as CommandInitContextSchema,Ke as CommandInitResultSchema,Ue as CommandMetadataSchema,Se as CommandPromptPartSchema,Ne as CommandSourceSchema,I as ContentPartSchema,pe as ContextBuildAfterInputSchema,ae as ContextBuildBeforeInputSchema,S as CwdSchema,M as EndReasonSchema,y as EventInputSchemas,j as FinishReasonSchema,D as FunctionExecutorSchema,ce as GatewayMessageCompleteInputSchema,me as GatewayMessageProcessInputSchema,ue as GatewayMessageReceiveInputSchema,le as GatewayMessageSendInputSchema,He as HOOK_EVENTS,ge as HeartbeatCompleteInputSchema,de as HeartbeatTriggerInputSchema,o as HookEvent,E as HookExecutorSchema,w as HookMatcherSchema,p as HookType,je as HooksConfigSchema,P as HttpExecutorSchema,re as LlmHeadersInputSchema,ne as LlmParamsInputSchema,oe as LlmParamsSchema,x as LlmProviderSchema,s as MessageIDSchema,_ as MessageReceiveInputSchema,L as MessageRoleSchema,h as MessageSchema,q as MessageTransformInputSchema,b as ModelObjectSchema,l as ModelSchema,ee as PermissionAskInputSchema,te as PermissionDeniedInputSchema,X as PermissionLevelSchema,Y as PermissionRequestSchema,v as PromptExecutorSchema,ye as ScheduledTaskCompleteInputSchema,fe as ScheduledTaskTriggerInputSchema,F as SessionCompactInputSchema,R as SessionCompactingInputSchema,z as SessionEndInputSchema,n as SessionIDSchema,A as SessionStartInputSchema,se as ShellEnvInputSchema,W as StepFinishInputSchema,O as StepStartInputSchema,G as StepStopFailureInputSchema,B as StepStopInputSchema,N as SystemTransformInputSchema,ie as TextCompleteInputSchema,V as ToolAfterInputSchema,g as ToolArgsSchema,Z as ToolBeforeInputSchema,K as ToolDefinitionInputSchema,$ as ToolFailureInputSchema,U as ToolResultSchema,Ae as getEventInputSchema,Re as safeValidateHookInput,C as tool,ze as validateHookInput};
|
package/package.json
ADDED
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@easbot/plugin",
|
|
3
|
+
"version": "0.1.11",
|
|
4
|
+
"description": "EASBot Plugin for client applications",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "dist/index.cjs",
|
|
7
|
+
"module": "dist/index.mjs",
|
|
8
|
+
"types": "dist/index.d.ts",
|
|
9
|
+
"exports": {
|
|
10
|
+
".": {
|
|
11
|
+
"types": "./dist/index.d.ts",
|
|
12
|
+
"import": "./dist/index.mjs",
|
|
13
|
+
"require": "./dist/index.cjs"
|
|
14
|
+
},
|
|
15
|
+
"./hook": {
|
|
16
|
+
"types": "./dist/hook/index.d.ts",
|
|
17
|
+
"import": "./dist/hook/index.mjs",
|
|
18
|
+
"require": "./dist/hook/index.cjs"
|
|
19
|
+
},
|
|
20
|
+
"./package.json": "./package.json"
|
|
21
|
+
},
|
|
22
|
+
"scripts": {
|
|
23
|
+
"dev": "tsup --watch --env.NODE_ENV development",
|
|
24
|
+
"build": "tsup --env.NODE_ENV production",
|
|
25
|
+
"test": "vitest",
|
|
26
|
+
"test:run": "vitest run",
|
|
27
|
+
"lint": "biome check .",
|
|
28
|
+
"lint:fix": "biome check --write .",
|
|
29
|
+
"lint:report": "biome check --reporter=summary .",
|
|
30
|
+
"format": "biome format .",
|
|
31
|
+
"format:fix": "biome format --write .",
|
|
32
|
+
"type-check": "tsc --noEmit",
|
|
33
|
+
"clean": "npx rimraf dist node_modules",
|
|
34
|
+
"prepare": "echo norun",
|
|
35
|
+
"prepublishOnly": "pnpm build",
|
|
36
|
+
"publish:npm": "bash script/publish.sh",
|
|
37
|
+
"publish:npm:win": "powershell -ExecutionPolicy Bypass -File script/publish.ps1"
|
|
38
|
+
},
|
|
39
|
+
"keywords": [
|
|
40
|
+
"easbot",
|
|
41
|
+
"plugin",
|
|
42
|
+
"bot",
|
|
43
|
+
"client"
|
|
44
|
+
],
|
|
45
|
+
"author": "houjallen",
|
|
46
|
+
"license": "MIT",
|
|
47
|
+
"repository": {
|
|
48
|
+
"type": "git",
|
|
49
|
+
"url": "https://github.com/houjallen/easbot.git",
|
|
50
|
+
"directory": "packages/plugin"
|
|
51
|
+
},
|
|
52
|
+
"homepage": "https://github.com/houjallen/easbot/tree/main/packages/plugin#readme",
|
|
53
|
+
"bugs": {
|
|
54
|
+
"url": "https://github.com/houjallen/easbot/issues"
|
|
55
|
+
},
|
|
56
|
+
"files": [
|
|
57
|
+
"dist",
|
|
58
|
+
"README.md",
|
|
59
|
+
"README.en.md",
|
|
60
|
+
"LICENSE"
|
|
61
|
+
],
|
|
62
|
+
"dependencies": {
|
|
63
|
+
"zod": "^4.3.6",
|
|
64
|
+
"@easbot/sdk": "workspace:*",
|
|
65
|
+
"@easbot/types": "workspace:*"
|
|
66
|
+
},
|
|
67
|
+
"devDependencies": {
|
|
68
|
+
"@types/node": "^22.17.0",
|
|
69
|
+
"tsup": "^8.5.1",
|
|
70
|
+
"@biomejs/biome": "^2.4.8",
|
|
71
|
+
"typescript": "^6.0.2",
|
|
72
|
+
"vitest": "^4.1.1"
|
|
73
|
+
},
|
|
74
|
+
"engines": {
|
|
75
|
+
"node": ">=22.17.0"
|
|
76
|
+
},
|
|
77
|
+
"publishConfig": {
|
|
78
|
+
"access": "public"
|
|
79
|
+
}
|
|
80
|
+
}
|