1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

Merge pull request #752 from MetaMask/i#741

Add validations to txData param in send form
This commit is contained in:
Dan Finlay 2016-10-21 17:24:04 -07:00 committed by GitHub
commit eba37e773d
4 changed files with 36 additions and 1 deletions

View File

@ -2,6 +2,8 @@
## Current Master ## Current Master
- Add a check for improper Transaction data.
## 2.13.5 2016-10-18 ## 2.13.5 2016-10-18
- Increase default max gas to `100000` over the RPC's `estimateGas` response. - Increase default max gas to `100000` over the RPC's `estimateGas` response.

View File

@ -227,5 +227,27 @@ describe('util', function() {
assert.equal(result.toString(10), '1111000000000000000', 'accepts decimals') assert.equal(result.toString(10), '1111000000000000000', 'accepts decimals')
}) })
}) })
describe('#isHex', function(){
it('should return true when given a hex string', function() {
var result = util.isHex('c3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714caef0c4f2')
assert(result)
})
it('should return false when given a non-hex string', function() {
var result = util.isHex('c3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714imnotreal')
assert(!result)
})
it('should return false when given a string containing a non letter/number character', function() {
var result = util.isHex('c3ab8ff13720!8ad9047dd39466b3c%8974e592c2fa383d4a396071imnotreal')
assert(!result)
})
it('should return true when given a hex string with hex-prefix', function() {
var result = util.isHex('0xc3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714caef0c4f2')
assert(result)
})
})
}) })
}) })

View File

@ -7,6 +7,7 @@ const actions = require('./actions')
const util = require('./util') const util = require('./util')
const numericBalance = require('./util').numericBalance const numericBalance = require('./util').numericBalance
const addressSummary = require('./util').addressSummary const addressSummary = require('./util').addressSummary
const isHex = require('./util').isHex
const EthBalance = require('./components/eth-balance') const EthBalance = require('./components/eth-balance')
const ethUtil = require('ethereumjs-util') const ethUtil = require('ethereumjs-util')
const RangeSlider = require('./components/range-slider') const RangeSlider = require('./components/range-slider')
@ -190,7 +191,7 @@ SendTransactionScreen.prototype.render = function () {
marginBottom: '16px', marginBottom: '16px',
}, },
}, [ }, [
'Transactional Data (optional)', 'Transaction Data (optional)',
]), ]),
// 'data' field // 'data' field
@ -312,6 +313,11 @@ SendTransactionScreen.prototype.onSubmit = function (gasPrice) {
return this.props.dispatch(actions.displayWarning(message)) return this.props.dispatch(actions.displayWarning(message))
} }
if (!isHex(ethUtil.stripHexPrefix(txData)) && txData) {
message = 'Transaction data must be hex string.'
return this.props.dispatch(actions.displayWarning(message))
}
this.props.dispatch(actions.hideWarning()) this.props.dispatch(actions.hideWarning())
var txParams = { var txParams = {

View File

@ -35,6 +35,7 @@ module.exports = {
normalizeNumberToWei: normalizeNumberToWei, normalizeNumberToWei: normalizeNumberToWei,
valueTable: valueTable, valueTable: valueTable,
bnTable: bnTable, bnTable: bnTable,
isHex: isHex,
} }
function valuesFor (obj) { function valuesFor (obj) {
@ -209,3 +210,7 @@ function readableDate (ms) {
var time = `${hours}:${minutes.substr(-2)}:${seconds.substr(-2)}` var time = `${hours}:${minutes.substr(-2)}:${seconds.substr(-2)}`
return `${dateStr} ${time}` return `${dateStr} ${time}`
} }
function isHex (str) {
return Boolean(str.match(/^(0x)?[0-9a-fA-F]+$/))
}