Skip to content

Commit

Permalink
All peg-out related detection pushes should be <= OP_PUSHDATA4
Browse files Browse the repository at this point in the history
  • Loading branch information
instagibbs committed May 8, 2019
1 parent bb80fd1 commit cff50f5
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 3 deletions.
2 changes: 1 addition & 1 deletion src/primitives/pak.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -185,7 +185,7 @@ bool ScriptHasValidPAKProof(const CScript& script, const uint256& genesis_hash)
std::vector<unsigned char> extracted_pubkey_hash;

// Get full pubkey
if (!script.GetOp(pc, opcode, data) || opcode != 33 || data.size() != 33) {
if (!script.GetOp(pc, opcode, data) || data.size() != 33 || opcode > OP_PUSHDATA4) {
return false;
}
CPubKey full_pubkey(data.begin(), data.end());
Expand Down
11 changes: 9 additions & 2 deletions src/script/script.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -213,17 +213,24 @@ bool CScript::IsPegoutScript(uint256& genesis_hash, CScript& pegout_scriptpubkey
return false;
}

if (!GetOp(pc, opcode, data) || data.size() != 32 ) {
if (!GetOp(pc, opcode, data) || data.size() != 32 || opcode > OP_PUSHDATA4) {
return false;
}
genesis_hash = uint256(data);

// Read in parent chain destination scriptpubkey
if (!GetOp(pc, opcode, data) || data.size() == 0 ) {
if (!GetOp(pc, opcode, data) || opcode > OP_PUSHDATA4 ) {
return false;
}
pegout_scriptpubkey = CScript(data.begin(), data.end());

// All extra opcodes must be pushes
while(GetOp(pc, opcode, data)) {
if (opcode > OP_PUSHDATA4) {
return false;
}
}

return true;
}

Expand Down

0 comments on commit cff50f5

Please sign in to comment.