Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
P
plugin
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
JIRA
JIRA
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
link33
plugin
Commits
9771febb
Commit
9771febb
authored
Aug 23, 2019
by
liuyuhang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add change test
parent
05b8ae47
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
18 changed files
with
123 additions
and
106 deletions
+123
-106
round_state.go
plugin/consensus/tendermint/types/round_state.go
+3
-3
proposal_change.go
plugin/dapp/autonomy/commands/proposal_change.go
+5
-5
proposal_project.go
plugin/dapp/autonomy/commands/proposal_project.go
+2
-1
proposal_rule.go
plugin/dapp/autonomy/commands/proposal_rule.go
+2
-1
boardaction.go
plugin/dapp/autonomy/executor/boardaction.go
+4
-4
boardaction_test.go
plugin/dapp/autonomy/executor/boardaction_test.go
+60
-33
change_test.go
plugin/dapp/autonomy/executor/change_test.go
+0
-0
changeaction.go
plugin/dapp/autonomy/executor/changeaction.go
+14
-16
changeaction_test.go
plugin/dapp/autonomy/executor/changeaction_test.go
+0
-0
exec.go
plugin/dapp/autonomy/executor/exec.go
+1
-3
exec_local.go
plugin/dapp/autonomy/executor/exec_local.go
+1
-3
kv.go
plugin/dapp/autonomy/executor/kv.go
+1
-2
projectaction.go
plugin/dapp/autonomy/executor/projectaction.go
+8
-9
query.go
plugin/dapp/autonomy/executor/query.go
+1
-2
ruleaction.go
plugin/dapp/autonomy/executor/ruleaction.go
+11
-12
ruleaction_test.go
plugin/dapp/autonomy/executor/ruleaction_test.go
+3
-3
const.go
plugin/dapp/autonomy/types/const.go
+1
-3
certutils.go
...rt/authority/tools/cryptogen/generator/utils/certutils.go
+6
-6
No files found.
plugin/consensus/tendermint/types/round_state.go
View file @
9771febb
...
...
@@ -117,9 +117,9 @@ type RoundState struct {
// RoundStateMessage ...
func
(
rs
*
RoundState
)
RoundStateMessage
()
*
tmtypes
.
NewRoundStepMsg
{
return
&
tmtypes
.
NewRoundStepMsg
{
Height
:
rs
.
Height
,
Round
:
int32
(
rs
.
Round
),
Step
:
int32
(
rs
.
Step
),
Height
:
rs
.
Height
,
Round
:
int32
(
rs
.
Round
),
Step
:
int32
(
rs
.
Step
),
SecondsSinceStartTime
:
int32
(
time
.
Since
(
rs
.
StartTime
)
.
Seconds
()),
LastCommitRound
:
int32
(
rs
.
LastCommit
.
Round
()),
}
...
...
plugin/dapp/autonomy/commands/proposal_change.go
View file @
9771febb
...
...
@@ -58,14 +58,14 @@ func proposalChange(cmd *cobra.Command, args []string) {
if
len
(
per
)
==
2
{
if
per
[
1
]
==
"true"
{
change
:=
&
auty
.
Change
{
Cancel
:
true
,
Addr
:
per
[
0
],
Cancel
:
true
,
Addr
:
per
[
0
],
}
changes
=
append
(
changes
,
change
)
}
else
if
per
[
1
]
==
"false"
{
change
:=
&
auty
.
Change
{
Cancel
:
false
,
Addr
:
per
[
0
],
Cancel
:
false
,
Addr
:
per
[
0
],
}
changes
=
append
(
changes
,
change
)
}
...
...
@@ -75,7 +75,7 @@ func proposalChange(cmd *cobra.Command, args []string) {
Year
:
year
,
Month
:
month
,
Day
:
day
,
Changes
:
changes
,
Changes
:
changes
,
StartBlockHeight
:
startBlock
,
EndBlockHeight
:
endBlock
,
}
...
...
plugin/dapp/autonomy/commands/proposal_project.go
View file @
9771febb
...
...
@@ -7,12 +7,13 @@ package commands
import
(
"encoding/json"
"strings"
jsonrpc
"github.com/33cn/chain33/rpc/jsonclient"
rpctypes
"github.com/33cn/chain33/rpc/types"
"github.com/33cn/chain33/types"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
"github.com/spf13/cobra"
"strings"
)
// ProposalProjectCmd 创建提案命令
...
...
plugin/dapp/autonomy/commands/proposal_rule.go
View file @
9771febb
...
...
@@ -7,12 +7,13 @@ package commands
import
(
"encoding/json"
"strings"
jsonrpc
"github.com/33cn/chain33/rpc/jsonclient"
rpctypes
"github.com/33cn/chain33/rpc/types"
"github.com/33cn/chain33/types"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
"github.com/spf13/cobra"
"strings"
)
// ProposalRuleCmd 创建提案命令
...
...
plugin/dapp/autonomy/executor/boardaction.go
View file @
9771febb
...
...
@@ -285,7 +285,7 @@ func (a *action) votePropBoard(voteProb *auty.VoteProposalBoard) (*types.Receipt
// 更新当前具有权利的董事会成员
if
cur
.
VoteResult
.
Pass
{
act
:=
&
auty
.
ActiveBoard
{
Boards
:
cur
.
PropBoard
.
Boards
,
Boards
:
cur
.
PropBoard
.
Boards
,
StartHeight
:
a
.
height
,
}
kv
=
append
(
kv
,
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
act
)})
...
...
@@ -365,7 +365,7 @@ func (a *action) tmintPropBoard(tmintProb *auty.TerminateProposalBoard) (*types.
// 更新当前具有权利的董事会成员
if
cur
.
VoteResult
.
Pass
{
act
:=
&
auty
.
ActiveBoard
{
Boards
:
cur
.
PropBoard
.
Boards
,
Boards
:
cur
.
PropBoard
.
Boards
,
StartHeight
:
a
.
height
,
}
kv
=
append
(
kv
,
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
act
)})
...
...
@@ -398,7 +398,7 @@ func (a *action) verifyMinerAddr(addrs []string, bindAddr string) (string, error
}
tkBind
:=
&
ticketTy
.
TicketBind
{}
err
=
types
.
Decode
(
value
,
tkBind
)
if
err
!=
nil
||
tkBind
.
MinerAddress
!=
bindAddr
{
if
err
!=
nil
||
tkBind
.
MinerAddress
!=
bindAddr
{
return
addr
,
auty
.
ErrBindAddr
}
}
...
...
@@ -503,7 +503,7 @@ func (a *action) checkVotesRecord(addrs []string, key []byte) (*auty.VotesRecord
for
_
,
addr
:=
range
votes
.
Address
{
if
_
,
ok
:=
mp
[
addr
];
ok
{
err
:=
auty
.
ErrRepeatVoteAddr
alog
.
Error
(
"autonomy "
,
"addr"
,
addr
,
"err"
,
err
)
alog
.
Error
(
"autonomy "
,
"addr"
,
addr
,
"err"
,
err
)
return
nil
,
err
}
}
...
...
plugin/dapp/autonomy/executor/boardaction_test.go
View file @
9771febb
...
...
@@ -20,10 +20,10 @@ import (
"github.com/33cn/chain33/types"
"github.com/33cn/chain33/util"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
ticket
"github.com/33cn/plugin/plugin/dapp/ticket/executor"
ticketTy
"github.com/33cn/plugin/plugin/dapp/ticket/types"
"github.com/stretchr/testify/mock"
"github.com/stretchr/testify/require"
ticketTy
"github.com/33cn/plugin/plugin/dapp/ticket/types"
ticket
"github.com/33cn/plugin/plugin/dapp/ticket/executor"
)
// ExecEnv exec environment
...
...
@@ -47,43 +47,70 @@ var (
AddrC
=
"1NLHPEcbTWWxxU3dGUZBhayjrCHD3psX7k"
AddrD
=
"1MCftFynyvG2F4ED5mdHYgziDxx6vDrScs"
PrivKey1
=
"0x9d4f8ab11361be596468b265cb66946c87873d4a119713fd0c3d8302eae0a8e4"
PrivKey2
=
"0xd165c84ed37c2a427fea487470ee671b7a0495d68d82607cafbc6348bf23bec5"
PrivKey3
=
"0xc21d38be90493512a5c2417d565269a8b23ce8152010e404ff4f75efead8183a"
PrivKey4
=
"0xfdf2bbff853ecff2e7b86b2a8b45726c6538ca7d1403dc94e50131ef379bdca0"
PrivKey5
=
"0x794443611e7369a57b078881445b93b754cbc9b9b8f526535ab9c6d21d29203d"
PrivKey6
=
"0xf2cc48d30560e4c92e84821df68cf1086de82ee6a5725fc2a590a58d6ffe4fc5"
PrivKey7
=
"0xeb4738a7c685a7ccf5471c3335a2d7ebe284b11d8a1717d814904b8d1ba936d9"
PrivKey8
=
"0x9d315182e56fde7fadb94408d360203894e5134216944e858f9b31f70e9ecf40"
PrivKey9
=
"0x128de4afa7c061c00d854a1bca51b58e80a2c292583739e5aebf4c0f778959e1"
PrivKey1
=
"0x9d4f8ab11361be596468b265cb66946c87873d4a119713fd0c3d8302eae0a8e4"
PrivKey2
=
"0xd165c84ed37c2a427fea487470ee671b7a0495d68d82607cafbc6348bf23bec5"
PrivKey3
=
"0xc21d38be90493512a5c2417d565269a8b23ce8152010e404ff4f75efead8183a"
PrivKey4
=
"0xfdf2bbff853ecff2e7b86b2a8b45726c6538ca7d1403dc94e50131ef379bdca0"
PrivKey5
=
"0x794443611e7369a57b078881445b93b754cbc9b9b8f526535ab9c6d21d29203d"
PrivKey6
=
"0xf2cc48d30560e4c92e84821df68cf1086de82ee6a5725fc2a590a58d6ffe4fc5"
PrivKey7
=
"0xeb4738a7c685a7ccf5471c3335a2d7ebe284b11d8a1717d814904b8d1ba936d9"
PrivKey8
=
"0x9d315182e56fde7fadb94408d360203894e5134216944e858f9b31f70e9ecf40"
PrivKey9
=
"0x128de4afa7c061c00d854a1bca51b58e80a2c292583739e5aebf4c0f778959e1"
PrivKey10
=
"0x1c3e6cac2f887e1ab9180e2d5772dc4ba01accb8d4df434faba097003eb35482"
Addr1
=
"12HKLEn6g4FH39yUbHh4EVJWcFo5CXg22d"
Addr2
=
"1Ka7EPFRqs3v9yreXG6qA4RQbNmbPJCZPj"
Addr3
=
"12cjnN5D4DPdBQSwh6vjwJbtsW4EJALTMv"
Addr4
=
"1Luh4AziYyaC5zP3hUXtXFZS873xAxm6rH"
Addr5
=
"1NNaYHkscJaLJ2wUrFNeh6cQXBS4TrFYeB"
Addr6
=
"1L1puAUjfmtDECKo2C1qLWsAMZtDGTBWf6"
Addr7
=
"1LNf9AVXzUMQkQM5hgGLhkdrVtD8UMBSUm"
Addr8
=
"1PcGKYYoLn1PLLJJodc1UpgWGeFAQasAkx"
Addr9
=
"1BM2xhBk95qoae8zKNDWwAVGgBERhb7DQu"
Addr10
=
"1Q9sQwothzM1gKSzkVZ8Dt1tqKX1uzSagx"
PrivKey11
=
"0xfd0c4a8a1efcd221ee0f36b7d4f57d8ff843cb8bc193b39c7863332d355acafa"
PrivKey12
=
"0x4c9691bf6acc908ef5c07abcad23cf7f98e46e84101aa5059322aa53eb4dc471"
PrivKey13
=
"0x50b9c6a4358ef8ffc96d5831a8dfd5e0fae504d49e20c5eafd12b6015423de33"
PrivKey14
=
"0x96e3c766850a915fe4718b890d96208d5d1a3694b2597e08165480b5b48b84cb"
PrivKey15
=
"0xeac5e45243c3920cf8a98f3d3a2e3a9b43f30a21769b57f734213913511e7575"
PrivKey16
=
"0xd2aaa6f050a4db13fbd2c8bf87cbb96e217289172baca6c12e8a8b0680b9aa1a"
PrivKey17
=
"0x33b3b977c657435a49773b5605a704ad5fdca0fa34fe36a02ea0f13a49099832"
Addr11
=
"15VUiygdxMSZ3rykwe742yomp2cPJ9Tfve"
Addr12
=
"1DyR84CU5AHbGXLEnhHMwMvWNMeunLZsuJ"
Addr13
=
"132pBvrgSYgHASxzoeL3bqnsqUpaBbUktm"
Addr14
=
"1DEV4XwdBUWRkMuy4ARRiEAoxQ2LoDByNG"
Addr15
=
"18Y87cw2hiYC71bvpD872oYMYXtw66Qp6o"
Addr16
=
"1Fghq6cgdJEDr6gQBmvba3t6aXAkyZyjr2"
Addr17
=
"142KsfJLvEA5FJxAgKm9ZDtFVjkRaPdu82"
boards
=
[]
string
{
AddrA
,
AddrB
,
AddrC
,
AddrD
,
"12HKLEn6g4FH39yUbHh4EVJWcFo5CXg22d"
,
"1Ka7EPFRqs3v9yreXG6qA4RQbNmbPJCZPj"
,
"12cjnN5D4DPdBQSwh6vjwJbtsW4EJALTMv"
,
"1Luh4AziYyaC5zP3hUXtXFZS873xAxm6rH"
,
"1NNaYHkscJaLJ2wUrFNeh6cQXBS4TrFYeB"
,
"1L1puAUjfmtDECKo2C1qLWsAMZtDGTBWf6"
,
"1LNf9AVXzUMQkQM5hgGLhkdrVtD8UMBSUm"
,
"1PcGKYYoLn1PLLJJodc1UpgWGeFAQasAkx"
,
"1BM2xhBk95qoae8zKNDWwAVGgBERhb7DQu"
,
"1Q9sQwothzM1gKSzkVZ8Dt1tqKX1uzSagx"
,
"15VUiygdxMSZ3rykwe742yomp2cPJ9Tfve"
,
"1DyR84CU5AHbGXLEnhHMwMvWNMeunLZsuJ"
,
"132pBvrgSYgHASxzoeL3bqnsqUpaBbUktm"
,
"1DEV4XwdBUWRkMuy4ARRiEAoxQ2LoDByNG"
,
"18Y87cw2hiYC71bvpD872oYMYXtw66Qp6o"
,
"1Fghq6cgdJEDr6gQBmvba3t6aXAkyZyjr2"
,
"142KsfJLvEA5FJxAgKm9ZDtFVjkRaPdu82"
,
}
total
=
types
.
Coin
*
30000
Addr1
,
Addr2
,
Addr3
,
Addr4
,
Addr5
,
Addr6
,
Addr7
,
Addr8
,
Addr9
,
Addr10
,
Addr11
,
Addr12
,
Addr13
,
Addr14
,
Addr15
,
Addr16
,
Addr17
,
}
total
=
types
.
Coin
*
30000
)
func
init
()
{
...
...
@@ -547,7 +574,7 @@ func TestVerifyMinerAddr(t *testing.T) {
// 授权地址AddrD
for
_
,
addr
:=
range
addrs
{
tkBind
:=
&
ticketTy
.
TicketBind
{
MinerAddress
:
AddrD
,
MinerAddress
:
AddrD
,
ReturnAddress
:
addr
,
}
stateDB
.
Set
(
ticket
.
BindKey
(
addr
),
types
.
Encode
(
tkBind
))
...
...
@@ -565,7 +592,7 @@ func TestVerifyMinerAddr(t *testing.T) {
// ErrBindAddr
testf
=
"1Ka7EPFRqs3v9yreXG6qA4RQbNmbPJCZPj"
tkBind
:=
&
ticketTy
.
TicketBind
{
MinerAddress
:
AddrA
,
MinerAddress
:
AddrA
,
ReturnAddress
:
testf
,
}
stateDB
.
Set
(
ticket
.
BindKey
(
testf
),
types
.
Encode
(
tkBind
))
...
...
plugin/dapp/autonomy/executor/change_test.go
0 → 100644
View file @
9771febb
This diff is collapsed.
Click to expand it.
plugin/dapp/autonomy/executor/changeaction.go
View file @
9771febb
...
...
@@ -8,10 +8,8 @@ import (
"github.com/33cn/chain33/common"
"github.com/33cn/chain33/types"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
)
func
(
a
*
action
)
propChange
(
prob
*
auty
.
ProposalChange
)
(
*
types
.
Receipt
,
error
)
{
//如果全小于等于0,则说明该提案规则参数不正确
if
prob
==
nil
||
len
(
prob
.
Changes
)
==
0
{
...
...
@@ -56,10 +54,10 @@ func (a *action) propChange(prob *auty.ProposalChange) (*types.Receipt, error) {
kv
=
append
(
kv
,
receipt
.
KV
...
)
cur
:=
&
auty
.
AutonomyProposalChange
{
PropChange
:
prob
,
PropChange
:
prob
,
CurRule
:
rule
,
Board
:
new
,
VoteResult
:
&
auty
.
VoteResult
{
TotalVotes
:
int32
(
len
(
act
.
Boards
))},
VoteResult
:
&
auty
.
VoteResult
{
TotalVotes
:
int32
(
len
(
act
.
Boards
))},
Status
:
auty
.
AutonomyStatusProposalChange
,
Address
:
a
.
fromaddr
,
Height
:
a
.
height
,
...
...
@@ -168,15 +166,10 @@ func (a *action) votePropChange(voteProb *auty.VoteProposalChange) (*types.Recei
// 更新投票记录
votes
.
Address
=
append
(
votes
.
Address
,
a
.
fromaddr
)
// 获取可投票数
vtCouts
,
err
:=
a
.
getAddressVotes
(
a
.
fromaddr
,
start
)
if
err
!=
nil
{
return
nil
,
err
}
if
voteProb
.
Approve
{
cur
.
VoteResult
.
ApproveVotes
+=
vtCouts
cur
.
VoteResult
.
ApproveVotes
++
}
else
{
cur
.
VoteResult
.
OpposeVotes
+=
vtCouts
cur
.
VoteResult
.
OpposeVotes
++
}
var
logs
[]
*
types
.
ReceiptLog
...
...
@@ -331,7 +324,7 @@ func (a *action) checkChangeable(act *auty.ActiveBoard, change []*auty.Change) (
return
nil
,
auty
.
ErrBoardNumber
}
new
:=
&
auty
.
ActiveBoard
{
Amount
:
act
.
Amount
,
Amount
:
act
.
Amount
,
StartHeight
:
act
.
StartHeight
,
}
for
k
:=
range
mpBd
{
...
...
@@ -359,13 +352,14 @@ func copyAutonomyProposalChange(cur *auty.AutonomyProposalChange) *auty.Autonomy
}
newAut
:=
*
cur
if
cur
.
PropChange
!=
nil
{
newPropChange
:=
*
cur
.
GetPropChange
()
newPropChange
:=
*
cur
.
PropChange
newAut
.
PropChange
=
&
newPropChange
if
cur
.
PropChange
.
Changes
!=
nil
{
chs
:=
cur
.
GetPropChange
()
.
GetChanges
()
for
_
,
ch
:=
range
chs
{
newAut
.
PropChange
.
Changes
=
make
([]
*
auty
.
Change
,
len
(
cur
.
PropChange
.
Changes
))
chs
:=
cur
.
PropChange
.
Changes
for
i
,
ch
:=
range
chs
{
newch
:=
*
ch
newAut
.
PropChange
.
Changes
=
append
(
newAut
.
PropChange
.
Changes
,
&
newch
)
newAut
.
PropChange
.
Changes
[
i
]
=
&
newch
}
}
}
...
...
@@ -375,6 +369,10 @@ func copyAutonomyProposalChange(cur *auty.AutonomyProposalChange) *auty.Autonomy
}
if
cur
.
Board
!=
nil
{
newBoard
:=
*
cur
.
GetBoard
()
newBoard
.
Boards
=
make
([]
string
,
len
(
cur
.
Board
.
Boards
))
copy
(
newBoard
.
Boards
,
cur
.
Board
.
Boards
)
newBoard
.
Revboards
=
make
([]
string
,
len
(
cur
.
Board
.
Revboards
))
copy
(
newBoard
.
Revboards
,
cur
.
Board
.
Revboards
)
newAut
.
Board
=
&
newBoard
}
if
cur
.
VoteResult
!=
nil
{
...
...
plugin/dapp/autonomy/executor/changeaction_test.go
0 → 100644
View file @
9771febb
This diff is collapsed.
Click to expand it.
plugin/dapp/autonomy/executor/exec.go
View file @
9771febb
...
...
@@ -105,7 +105,6 @@ func (a *Autonomy) Exec_CommentProp(payload *auty.Comment, tx *types.Transaction
return
action
.
commentProp
(
payload
)
}
// 提案修改董事会成员相关
// Exec_PropChange 创建提案规则
...
...
@@ -130,4 +129,4 @@ func (a *Autonomy) Exec_VotePropChange(payload *auty.VoteProposalChange, tx *typ
func
(
a
*
Autonomy
)
Exec_TmintPropChange
(
payload
*
auty
.
TerminateProposalChange
,
tx
*
types
.
Transaction
,
index
int
)
(
*
types
.
Receipt
,
error
)
{
action
:=
newAction
(
a
,
tx
,
int32
(
index
))
return
action
.
tmintPropChange
(
payload
)
}
\ No newline at end of file
}
plugin/dapp/autonomy/executor/exec_local.go
View file @
9771febb
...
...
@@ -85,7 +85,6 @@ func (a *Autonomy) ExecLocal_CommentProp(payload *auty.Comment, tx *types.Transa
return
a
.
execAutoLocalCommentProp
(
tx
,
receiptData
)
}
// 提案修改董事会成员相关
// ExecLocal_PropChange 创建提案规则
...
...
@@ -106,4 +105,4 @@ func (a *Autonomy) ExecLocal_VotePropChange(payload *auty.VoteProposalChange, tx
// ExecLocal_TmintPropChange 终止提案规则
func
(
a
*
Autonomy
)
ExecLocal_TmintPropChange
(
payload
*
auty
.
TerminateProposalChange
,
tx
*
types
.
Transaction
,
receiptData
*
types
.
ReceiptData
,
index
int
)
(
*
types
.
LocalDBSet
,
error
)
{
return
a
.
execAutoLocalChange
(
tx
,
receiptData
)
}
\ No newline at end of file
}
plugin/dapp/autonomy/executor/kv.go
View file @
9771febb
...
...
@@ -78,4 +78,4 @@ var (
func
propChangeID
(
txHash
string
)
[]
byte
{
return
[]
byte
(
fmt
.
Sprintf
(
"%s%s"
,
changePrefix
,
txHash
))
}
\ No newline at end of file
}
plugin/dapp/autonomy/executor/projectaction.go
View file @
9771febb
...
...
@@ -13,8 +13,8 @@ import (
)
const
(
maxBoardPeriodAmount
=
types
.
Coin
*
10000
*
300
// 每个时期董事会审批最大额度300万
boardPeriod
=
17280
*
30
*
1
// 时期为一个月
maxBoardPeriodAmount
=
types
.
Coin
*
10000
*
300
// 每个时期董事会审批最大额度300万
boardPeriod
=
17280
*
30
*
1
// 时期为一个月
)
func
(
a
*
action
)
propProject
(
prob
*
auty
.
ProposalProject
)
(
*
types
.
Receipt
,
error
)
{
...
...
@@ -37,10 +37,10 @@ func (a *action) propProject(prob *auty.ProposalProject) (*types.Receipt, error)
}
// 检查是否可以对已审批额度归0,如果可以则设置kv
var
kva
*
types
.
KeyValue
if
a
.
height
>
pboard
.
StartHeight
+
boardPeriod
{
if
a
.
height
>
pboard
.
StartHeight
+
boardPeriod
{
pboard
.
StartHeight
=
a
.
height
pboard
.
Amount
=
0
kva
=
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
pboard
)}
kva
=
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
pboard
)}
}
// 检查额度
pass
:=
a
.
checkPeriodAmount
(
pboard
,
prob
.
Amount
)
...
...
@@ -593,7 +593,7 @@ func (a *action) checkPeriodAmount(act *auty.ActiveBoard, amount int64) bool {
if
act
==
nil
{
return
false
}
if
act
.
Amount
+
amount
>=
maxBoardPeriodAmount
{
if
act
.
Amount
+
amount
>=
maxBoardPeriodAmount
{
return
false
}
return
true
...
...
@@ -604,10 +604,10 @@ func (a *action) updatePeriodAmount(amount int64) (*types.KeyValue, error) {
if
err
!=
nil
{
return
nil
,
err
}
if
a
.
height
>
act
.
StartHeight
+
boardPeriod
{
if
a
.
height
>
act
.
StartHeight
+
boardPeriod
{
act
.
StartHeight
=
a
.
height
act
.
Amount
=
0
}
act
.
Amount
+=
amount
return
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
act
)},
nil
}
\ No newline at end of file
return
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
act
)},
nil
}
plugin/dapp/autonomy/executor/query.go
View file @
9771febb
...
...
@@ -52,4 +52,4 @@ func (a *Autonomy) Query_GetProposalChange(in *types.ReqString) (types.Message,
// Query_ListProposalChange 批量查询
func
(
a
*
Autonomy
)
Query_ListProposalChange
(
in
*
auty
.
ReqQueryProposalChange
)
(
types
.
Message
,
error
)
{
return
a
.
listProposalChange
(
in
)
}
\ No newline at end of file
}
plugin/dapp/autonomy/executor/ruleaction.go
View file @
9771febb
...
...
@@ -9,8 +9,8 @@ import (
"github.com/33cn/chain33/types"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
"github.com/33cn/chain33/system/dapp"
"github.com/33cn/chain33/common/address"
"github.com/33cn/chain33/system/dapp"
)
const
(
...
...
@@ -19,37 +19,36 @@ const (
// 最大董事会赞成率
maxBoardApproveRatio
=
66
// 最小全体持票人否决率
minPubOpposeRatio
=
33
minPubOpposeRatio
=
33
// 最大全体持票人否决率
maxPubOpposeRatio
=
50
maxPubOpposeRatio
=
50
// 最小公示周期
minPublicPeriod
int32
=
17280
*
7
minPublicPeriod
int32
=
17280
*
7
// 最大公示周期
maxPublicPeriod
int32
=
17280
*
14
maxPublicPeriod
int32
=
17280
*
14
// 最小重大项目阈值
minLargeProjectAmount
=
types
.
Coin
*
100
*
10000
// 最大重大项目阈值
maxLargeProjectAmount
=
types
.
Coin
*
300
*
10000
// 最小提案金
minProposalAmount
=
types
.
Coin
*
20
minProposalAmount
=
types
.
Coin
*
20
// 最大提案金
maxProposalAmount
=
types
.
Coin
*
2000
maxProposalAmount
=
types
.
Coin
*
2000
)
func
(
a
*
action
)
propRule
(
prob
*
auty
.
ProposalRule
)
(
*
types
.
Receipt
,
error
)
{
//如果全小于等于0,则说明该提案规则参数不正确
if
prob
.
RuleCfg
==
nil
||
prob
.
RuleCfg
.
BoardApproveRatio
<=
0
&&
prob
.
RuleCfg
.
PubOpposeRatio
<=
0
&&
prob
.
RuleCfg
.
ProposalAmount
<=
0
&&
prob
.
RuleCfg
.
LargeProjectAmount
<=
0
&&
prob
.
RuleCfg
.
PublicPeriod
<=
0
{
prob
.
RuleCfg
.
ProposalAmount
<=
0
&&
prob
.
RuleCfg
.
LargeProjectAmount
<=
0
&&
prob
.
RuleCfg
.
PublicPeriod
<=
0
{
alog
.
Error
(
"propRule "
,
"ProposalRule RuleCfg invaild or have no modify param"
,
prob
.
RuleCfg
)
return
nil
,
types
.
ErrInvalidParam
}
if
prob
.
RuleCfg
.
BoardApproveRatio
>
maxBoardApproveRatio
||
prob
.
RuleCfg
.
BoardApproveRatio
<
minBoardApproveRatio
||
prob
.
RuleCfg
.
PubOpposeRatio
>
maxPubOpposeRatio
||
prob
.
RuleCfg
.
PubOpposeRatio
<
minPubOpposeRatio
||
prob
.
RuleCfg
.
PublicPeriod
>
maxPublicPeriod
||
prob
.
RuleCfg
.
PublicPeriod
<
minPublicPeriod
||
prob
.
RuleCfg
.
PublicPeriod
>
maxPublicPeriod
||
prob
.
RuleCfg
.
PublicPeriod
<
minPublicPeriod
||
prob
.
RuleCfg
.
LargeProjectAmount
>
maxLargeProjectAmount
||
prob
.
RuleCfg
.
LargeProjectAmount
<
minLargeProjectAmount
||
prob
.
RuleCfg
.
ProposalAmount
>
maxProposalAmount
||
prob
.
RuleCfg
.
ProposalAmount
<
minProposalAmount
{
alog
.
Error
(
"propRule RuleCfg invaild"
,
"ruleCfg"
,
prob
.
RuleCfg
)
prob
.
RuleCfg
.
ProposalAmount
>
maxProposalAmount
||
prob
.
RuleCfg
.
ProposalAmount
<
minProposalAmount
{
alog
.
Error
(
"propRule RuleCfg invaild"
,
"ruleCfg"
,
prob
.
RuleCfg
)
return
nil
,
types
.
ErrInvalidParam
}
if
prob
.
StartBlockHeight
<
a
.
height
||
prob
.
EndBlockHeight
<
a
.
height
{
...
...
plugin/dapp/autonomy/executor/ruleaction_test.go
View file @
9771febb
...
...
@@ -23,9 +23,9 @@ import (
const
(
testBoardApproveRatio
int32
=
60
testPubOpposeRatio
int32
=
35
testProposalAmount
=
minProposalAmount
*
2
testLargeProjectAmount
=
minLargeProjectAmount
*
2
testPublicPeriod
=
minPublicPeriod
testProposalAmount
=
minProposalAmount
*
2
testLargeProjectAmount
=
minLargeProjectAmount
*
2
testPublicPeriod
=
minPublicPeriod
)
func
TestRevokeProposalRule
(
t
*
testing
.
T
)
{
...
...
plugin/dapp/autonomy/types/const.go
View file @
9771febb
...
...
@@ -47,7 +47,7 @@ const (
TyLogVotePropRule
=
2123
TyLogTmintPropRule
=
2124
TyLogCommentProp
=
2131
TyLogCommentProp
=
2131
TyLogPropChange
=
2141
TyLogRvkPropChange
=
2142
...
...
@@ -88,8 +88,6 @@ const (
AutonomyStatusTmintPropChange
)
const
(
// GetProposalBoard 用于在cmd里面的区分不同的查询
GetProposalBoard
=
"GetProposalBoard"
...
...
plugin/dapp/cert/authority/tools/cryptogen/generator/utils/certutils.go
View file @
9771febb
...
...
@@ -73,9 +73,9 @@ func ParseX509CertificateToSm2(x509Cert *x509.Certificate) *sm2.Certificate {
UnknownExtKeyUsage
:
x509Cert
.
UnknownExtKeyUsage
,
BasicConstraintsValid
:
x509Cert
.
BasicConstraintsValid
,
IsCA
:
x509Cert
.
IsCA
,
MaxPathLen
:
x509Cert
.
MaxPathLen
,
MaxPathLenZero
:
x509Cert
.
MaxPathLenZero
,
IsCA
:
x509Cert
.
IsCA
,
MaxPathLen
:
x509Cert
.
MaxPathLen
,
MaxPathLenZero
:
x509Cert
.
MaxPathLenZero
,
SubjectKeyId
:
x509Cert
.
SubjectKeyId
,
AuthorityKeyId
:
x509Cert
.
AuthorityKeyId
,
...
...
@@ -136,9 +136,9 @@ func ParseSm2CertificateToX509(sm2Cert *sm2.Certificate) *x509.Certificate {
UnknownExtKeyUsage
:
sm2Cert
.
UnknownExtKeyUsage
,
BasicConstraintsValid
:
sm2Cert
.
BasicConstraintsValid
,
IsCA
:
sm2Cert
.
IsCA
,
MaxPathLen
:
sm2Cert
.
MaxPathLen
,
MaxPathLenZero
:
sm2Cert
.
MaxPathLenZero
,
IsCA
:
sm2Cert
.
IsCA
,
MaxPathLen
:
sm2Cert
.
MaxPathLen
,
MaxPathLenZero
:
sm2Cert
.
MaxPathLenZero
,
SubjectKeyId
:
sm2Cert
.
SubjectKeyId
,
AuthorityKeyId
:
sm2Cert
.
AuthorityKeyId
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment