Packhouse
Search…
⌃K

Event

Packhouse Event
Packhouse提供了簡單的事件系統,主要提供於追蹤呼叫行為。
除非特殊情況,你不需要自己處理事件追蹤,使用Step,可以輕鬆追蹤整個運行過程。

Add Listener

Use

第一次使用Tool時觸發:
嚴格來說Line是一連串的Tool執行,在呼叫Line的事件中你會發現Name會以Namespace的模式顯示。
packhouse.on('use', (event, { type, name, group }) => {
console.log(type) // tool
console.log(name) // sum
console.log(group.sign) // null *this is merger sign
console.log(group.name) // math
})
packhouse.tool('math/sum').action(...)

Run

每次執行Tool時會被觸發:
packhouse.on('run', (event, { id, caller, detail }) => {
let { name, args, mode, request, response, group } = detail
console.log(id) // uuid, 每次執行都會配發一個新的id
console.log(caller) // 如果該次呼叫是由另一個tool調用,可以得知是哪個id呼叫
console.log(name) // sum
console.log(args) // [10, 20]
console.log(mode) // action
console.log(request) // "[\"number\", \"number\"]"
console.log(response) // number
console.log(group.sign) // null *this is merger sign
console.log(group.name) // math
})
packhouse.tool('math/sum').action(10, 20, () => {})

Done

運行結束時觸發:
packhouse.on('done', (event, { id, caller, detail }) => {
let { result, success } = detail
console.log(id) // 與執行的id相同
console.log(caller) // 如果該次呼叫是由另一個tool調用,可以得知是哪個id呼叫
console.log(success) // true
console.log(result) // 30
})
packhouse.tool('math/sum').action(10, 20, () => {})

Remove Listener

每次監聽事件都會回傳一個監聽Id,因此可以藉由該Id指定移除事件:
let id = packhouse.on('run', () => {})
packhouse.off('run', id)
也可以利用第一個event參數來關閉事件:
packhouse.on('run', event => event.off())