From 693333ba68309baa0fa56bfbadd3bd1ded8b1e79 Mon Sep 17 00:00:00 2001 From: Luk Lu Date: Sun, 15 Mar 2020 21:19:38 +0800 Subject: [PATCH] =?UTF-8?q?=E5=9C=A8=20Action.js=20=E9=87=8C=EF=BC=9A?= =?UTF-8?q?=E6=8A=8A=20wo=20=E6=94=B9=E5=90=8D=E4=B8=BA=20TypedActionDict;?= =?UTF-8?q?=20=E5=8E=BB=E6=8E=89=20=5FinitTypeDict=EF=BC=8Crequire('...')?= =?UTF-8?q?=20=E5=8D=B3=E5=8F=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Action.js | 38 +++++++++++++++++++------------------- TypedActionDict.js | 15 +++++++++++++++ index.js | 16 +--------------- 3 files changed, 35 insertions(+), 34 deletions(-) create mode 100644 TypedActionDict.js diff --git a/Action.js b/Action.js index 375a8d3..9128285 100644 --- a/Action.js +++ b/Action.js @@ -1,6 +1,6 @@ const Ling = require('so.ling') const ticCrypto = require('tic.crypto') -const wo = {} +const TypedActionDict = require('./TypedActionDict.js') // 或者直接加载到 Action 类上? /** ****************** Public of instance ********************/ @@ -62,7 +62,7 @@ MOM.verifySig = async function() { return result } DAD.verifySig = async function (actionData) { - let typedAction = new wo[actionData.type](actionData) + let typedAction = new TypedActionDict[actionData.type](actionData) return await typedAction.verifySig() } @@ -70,7 +70,7 @@ MOM.verifyAddress = function () { return this.actorAddress === ticCrypto.pubkey2address(this.actorPubkey) } DAD.verifyAddress = function (actionData) { - let typedAction = new wo[actionData.type](actionData) + let typedAction = new TypedActionDict[actionData.type](actionData) return typedAction.verifyAddress() } @@ -78,27 +78,27 @@ MOM.verifyHash = function () { return this.hash === ticCrypto.hash(this.getJson({ exclude: ['hash', 'blockHash'] })) } DAD.verifyHash = function (actionData) { - let typedAction = new wo[actionData.type](actionData) + let typedAction = new TypedActionDict[actionData.type](actionData) return typedAction.verifyHash() } MOM.validateMe = function() { // Applicable on both client and chain server. 子类应当覆盖本方法,静态的检查事务内容的格式。不能检查 balance 等需要全链数据库的东西,因为本方法也要用在前端检查。 // to implement in subclasses: 检查子类事务内容的格式 - let typedAction = new wo[this.type](this) + let typedAction = new TypedActionDict[this.type](this) return typedAction.validateMe() } DAD.validate = function (action) { // Allicable on both client and chain server. mylog.info(`Validating action type=${action.type} of hash=${action.hash}`) - let typedAction = new wo[action.type](action) + let typedAction = new TypedActionDict[action.type](action) return typedAction.validateMe() } MOM.executableMe = async function() { // Applicable on chain server. 子类应当覆盖本方法,动态的检查事务内容,在当前链状态下,是否能执行。To check if an action is executableMe given the current chain status. - let typedAction = new wo[this.type](this) + let typedAction = new TypedActionDict[this.type](this) return await typedAction.executableMe() } DAD.executable = async function(action) { // For chain server. - let typedAction = new wo[action.type](action) + let typedAction = new TypedActionDict[action.type](action) if (typedAction.hasOwnProperty('executableMe')) { // 防止子类忘了定义自己的 executableMe return await typedAction.executableMe() }else { @@ -107,31 +107,31 @@ DAD.executable = async function(action) { // For chain server. } MOM.executeMe = async function() { // For chain server. 子类应当覆盖本方法,执行事务,记录其(除了存入 Action 数据表之外的)副作用到内存数据库或其他地方。 // to implement in subclasses: 把action的影响,汇总登记到其他表格(用于辅助的、索引的表格),方便快速索引、处理。每种事务类型都要重定义这个方法。 - let typedAction = new wo[this.type](this) + let typedAction = new TypedActionDict[this.type](this) return await typedAction.executeMe() } DAD.execute = async function (action) { // For chain server. mylog.info(`Excecuting action type=${action.type} of hash=${action.hash}`) - let typedAction = new wo[action.type](action) + let typedAction = new TypedActionDict[action.type](action) return await typedAction.executeMe() } // [todo 20190411] 执行事务池中的所有事务 // DAD.executePool = async function() { // } -DAD._initTypeDict = function(typedActionDict) { - Object.assign(wo, typedActionDict) -} DAD.getTypedAction = function(type){ - return wo[type] + return TypedActionDict[type] +} +DAD.addTypedAction = function(TypedAction){ + TypedActionDict[TypedAction.name] = TypedAction } DAD.createTypedAction = function(action){ - return new wo[action.type](action) + return new TypedActionDict[action.type](action) } DAD.buildUserAction = async function (action, keypair) { // Applicable on client. 客户端调用 Action.build,即可新建、并打包成一个完整的子事务,不需要亲自调用 constructor, packMe 等方法。 if (action && action.type && keypair && keypair.seckey && keypair.pubkey && ticCrypto.seckey2pubkey(keypair.seckey)===keypair.pubkey) { - let typedAction = new wo[action.type](action) + let typedAction = new TypedActionDict[action.type](action) typedAction.actorPubkey = keypair.pubkey if (typedAction.validateMe()) { await typedAction.packMe(keypair) // 在 packMe 里,会把 actorPubkey 转存为 actorAddress。 @@ -184,8 +184,8 @@ DAD.api.prepare = async function (option) { } catch (error) {} } // 前端发来action数据,进行格式检查(不检查是否可执行--这和事务类型、执行顺序有关)后放入缓冲池。 - if (option && option.Action && option.Action.type && wo[option.Action.type] && option.Action.hash && !DAD.actionPool[option.Action.hash]) { - let typedAction = new wo[option.Action.type](option.Action) + if (option && option.Action && option.Action.type && TypedActionDict[option.Action.type] && option.Action.hash && !DAD.actionPool[option.Action.hash]) { + let typedAction = new TypedActionDict[option.Action.type](option.Action) if (typedAction.verifyAddress() && // 只检查所有事务通用的格式 await typedAction.verifySig() && typedAction.verifyHash() && @@ -195,7 +195,7 @@ DAD.api.prepare = async function (option) { DAD.actionPool[option.Action.hash] = typedAction DAD.actionPoolInfo.totalAmount += option.Action.amount || 0 DAD.actionPoolInfo.totalFee += option.Action.fee || 0 -// wo.Netnode.broadcast({ Action: option.Action }) // 即使对 master 分支的node.server 也报错:Cannot read property 'broadcast' of undefined +// TypedActionDict.Netnode.broadcast({ Action: option.Action }) // 即使对 master 分支的node.server 也报错:Cannot read property 'broadcast' of undefined return option.Action } } diff --git a/TypedActionDict.js b/TypedActionDict.js new file mode 100644 index 0000000..8484037 --- /dev/null +++ b/TypedActionDict.js @@ -0,0 +1,15 @@ +// const Action = require('./Action.js') // 不要在 index 里引入 Action,避免循环无限引入。 +const ActionTransfer = require('./ActionTransfer.js') +const ActionStore = require('./ActionStore.js') +const ActionMultisig = require('./ActionMultisig.js') +const ActionLockProof = require('./ActionLockProof.js') +// const ActionTac = require('./ActionTac.js') + +module.exports = { +// Action, + ActionTransfer, + ActionStore, + ActionMultisig, + ActionLockProof, +// ActionTac +} \ No newline at end of file diff --git a/index.js b/index.js index 8484037..57322e5 100644 --- a/index.js +++ b/index.js @@ -1,15 +1 @@ -// const Action = require('./Action.js') // 不要在 index 里引入 Action,避免循环无限引入。 -const ActionTransfer = require('./ActionTransfer.js') -const ActionStore = require('./ActionStore.js') -const ActionMultisig = require('./ActionMultisig.js') -const ActionLockProof = require('./ActionLockProof.js') -// const ActionTac = require('./ActionTac.js') - -module.exports = { -// Action, - ActionTransfer, - ActionStore, - ActionMultisig, - ActionLockProof, -// ActionTac -} \ No newline at end of file +module.exports = require('./Action.js') \ No newline at end of file