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:
commit
eba37e773d
@ -2,6 +2,8 @@
|
||||
|
||||
## Current Master
|
||||
|
||||
- Add a check for improper Transaction data.
|
||||
|
||||
## 2.13.5 2016-10-18
|
||||
|
||||
- Increase default max gas to `100000` over the RPC's `estimateGas` response.
|
||||
|
@ -227,5 +227,27 @@ describe('util', function() {
|
||||
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)
|
||||
})
|
||||
|
||||
})
|
||||
})
|
||||
})
|
||||
|
@ -7,6 +7,7 @@ const actions = require('./actions')
|
||||
const util = require('./util')
|
||||
const numericBalance = require('./util').numericBalance
|
||||
const addressSummary = require('./util').addressSummary
|
||||
const isHex = require('./util').isHex
|
||||
const EthBalance = require('./components/eth-balance')
|
||||
const ethUtil = require('ethereumjs-util')
|
||||
const RangeSlider = require('./components/range-slider')
|
||||
@ -190,7 +191,7 @@ SendTransactionScreen.prototype.render = function () {
|
||||
marginBottom: '16px',
|
||||
},
|
||||
}, [
|
||||
'Transactional Data (optional)',
|
||||
'Transaction Data (optional)',
|
||||
]),
|
||||
|
||||
// 'data' field
|
||||
@ -312,6 +313,11 @@ SendTransactionScreen.prototype.onSubmit = function (gasPrice) {
|
||||
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())
|
||||
|
||||
var txParams = {
|
||||
|
@ -35,6 +35,7 @@ module.exports = {
|
||||
normalizeNumberToWei: normalizeNumberToWei,
|
||||
valueTable: valueTable,
|
||||
bnTable: bnTable,
|
||||
isHex: isHex,
|
||||
}
|
||||
|
||||
function valuesFor (obj) {
|
||||
@ -209,3 +210,7 @@ function readableDate (ms) {
|
||||
var time = `${hours}:${minutes.substr(-2)}:${seconds.substr(-2)}`
|
||||
return `${dateStr} ${time}`
|
||||
}
|
||||
|
||||
function isHex (str) {
|
||||
return Boolean(str.match(/^(0x)?[0-9a-fA-F]+$/))
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user