mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-11 19:44:21 +00:00
985ea0fb89
* [FEATURE] Initial EAC integration. * Title and explanation * [FEATURE] Move the Schedule Payment to the main tab. * [FEATURE] TimeBounty slider. * [FEATURE] Move to main menu. * [FEATURE] Redirection to the DApp for details. * [FEATURE] Timestamp scheduling * Scheduling: Basic date and time widget * Linting fixes * Moved the datetime field to new tab * Fixed push errors * Added missing specs * Undid unintentional UI change * Fixed some failing tests * Ignore datetime parameter when checking if a transaction is full * Added a date selector widget and renamed ScheduleTimestamp to ScheduleDate * Marked componentDidMount * Initialized Pikaday * Revert "Initialized Pikaday" This reverts commit 4e5bf5b2b882f236f5977400abf9b7092cbd1592. * Revert "Marked componentDidMount" This reverts commit 85d52192ac58f4b6ca9219e702f7390cd27e582f. * Revert "Added a date selector widget and renamed ScheduleTimestamp to ScheduleDate" This reverts commit aaad0ac9b565a78d1bfc631754160919fd38a59b. * Converted the date picker into a datetime picker * Added decent styling to the datetimepicker * Added validation to the datetime picker * Fixed prepush errors for scheduling timestamp * Adjusted validation logic scheduling timestamp * [FEATURE] Move scheduling to main tab. * [FEATURE] Timezone selector * [FEATURE] Scheduling: Timezone selector * Removed zombie files * [FEATURE] Reimplement Time Bounty. * [FEATURE] Time/block selector * [FEATURE] Add Window Size field. * [FEATURE] Time/block switch functionality * Implemented time/block switcher fuctionality * [FEATURE] Add Schedule Gas Price field. * [FEATURE] Scheduling toggle * [FEATURE] Add basic styling and network check. * [FEATURE] Add Schedule Gas Limit field * [FEATURE] "Scheduled" button styling * Reordered, renamed and centered scheduling elements * Added the toggle button styling * Class -> ClassName * [FEATURE] Add Deposit field * [FEATURE] Move scheduling code into one directory * [FIX] Scheduling responsiveness * [FIX] Datetime picker not working on md screens * [FEATURE] Timestamp Scheduling basic functionality * [FIX] Fix data serialization. * [FEATURE] Timezone inclusion * [FEATURE] Add ChronoLogic logo. * [FEATURE] Add link to image. * [FIX] Update CSS of logo. * [FEATURE] Default Window Size * [FEATURE] Modified Help component to enable acting as a tooltip * [FEATURE] Call contract to validate scheduling params * [FIX] Change moment import to fix tests * [FEATURE] Gas estimation for scheduling * [FEATURE] Additional validation * [FEATURE] UI changes and descriptions * [FEATURE] Add tooltip to window and fix fee display. * [FIX] Fix ethereumjs-abi dependency. * [FEATURE] Hide scheduling when sending tokens. * [FIX] Improved styling datetime picker * [FEATURE] Add Redux state for scheduling * [FEATURE] Create Toggle component, Share code between components * [FEATURE] Use Tooltip component for help. * [FEATURE] Better datetime picker * [FEATURE] Remove fee * Trigger mycryptobuild * [FIX] Timestamp scheduling - Validation match * [FIX] EAC integration touchups * [FIX] Code review fixes * [FIX] Window Size type * [FIX] Type fixes. * [FIX] Make tooltips only show on icons + resposiveness fixes * [FIX] Break tooltips into more lines * [FIX] Remove unnecessary code. * [FIX] Remove unnecessary code. * [FIX] Remove unnecessary types declaration. * [FIX] Fee class names
139 lines
4.4 KiB
TypeScript
139 lines
4.4 KiB
TypeScript
import abi from 'ethereumjs-abi';
|
|
import { toChecksumAddress, addHexPrefix } from 'ethereumjs-util';
|
|
import BN from 'bn.js';
|
|
import {
|
|
FuncParams,
|
|
FunctionOutputMappings,
|
|
Output,
|
|
Input,
|
|
ITypeMapping,
|
|
ISuppliedArgs
|
|
} from './types';
|
|
|
|
export default class AbiFunction {
|
|
public constant: boolean;
|
|
public outputs: Output[];
|
|
public inputs: Input[];
|
|
private funcParams: FuncParams;
|
|
private inputNames: string[];
|
|
private inputTypes: string[];
|
|
private outputNames: string[];
|
|
private outputTypes: string[];
|
|
private methodSelector: string;
|
|
private name: string;
|
|
|
|
constructor(abiFunc: any, outputMappings: FunctionOutputMappings) {
|
|
Object.assign(this, abiFunc);
|
|
this.init(outputMappings);
|
|
}
|
|
|
|
public encodeInput = (suppliedInputs: object = {}) => {
|
|
const args = this.processSuppliedArgs(suppliedInputs);
|
|
const encodedCall = this.makeEncodedFuncCall(args);
|
|
return encodedCall;
|
|
};
|
|
|
|
public decodeInput = (argString: string) => {
|
|
// Remove method selector from data, if present
|
|
argString = argString.replace(addHexPrefix(this.methodSelector), '');
|
|
// Convert argdata to a hex buffer for ethereumjs-abi
|
|
const argBuffer = new Buffer(argString, 'hex');
|
|
// Decode!
|
|
const argArr = abi.rawDecode(this.inputTypes, argBuffer);
|
|
//TODO: parse checksummed addresses
|
|
return argArr.reduce((argObj, currArg, index) => {
|
|
const currName = this.inputNames[index];
|
|
const currType = this.inputTypes[index];
|
|
return {
|
|
...argObj,
|
|
[currName]: this.parsePostDecodedValue(currType, currArg)
|
|
};
|
|
}, {});
|
|
};
|
|
|
|
public decodeOutput = (argString: string) => {
|
|
// Remove method selector from data, if present
|
|
argString = argString.replace(addHexPrefix(this.methodSelector), '');
|
|
|
|
// Remove 0x prefix
|
|
argString = argString.replace('0x', '');
|
|
|
|
// Convert argdata to a hex buffer for ethereumjs-abi
|
|
const argBuffer = new Buffer(argString, 'hex');
|
|
// Decode!
|
|
const argArr = abi.rawDecode(this.outputTypes, argBuffer);
|
|
|
|
//TODO: parse checksummed addresses
|
|
return argArr.reduce((argObj, currArg, index) => {
|
|
const currName = this.outputNames[index];
|
|
const currType = this.outputTypes[index];
|
|
return {
|
|
...argObj,
|
|
[currName]: this.parsePostDecodedValue(currType, currArg)
|
|
};
|
|
}, {});
|
|
};
|
|
|
|
private init(outputMappings: FunctionOutputMappings = []) {
|
|
this.funcParams = this.makeFuncParams();
|
|
//TODO: do this in O(n)
|
|
this.inputTypes = this.inputs.map(({ type }) => type);
|
|
this.outputTypes = this.outputs.map(({ type }) => type);
|
|
this.inputNames = this.inputs.map(({ name }) => name);
|
|
this.outputNames = this.outputs.map(({ name }, i) => outputMappings[i] || name || `${i}`);
|
|
|
|
this.methodSelector = abi.methodID(this.name, this.inputTypes).toString('hex');
|
|
}
|
|
|
|
private parsePostDecodedValue = (type: string, value: any) => {
|
|
const valueMapping: ITypeMapping = {
|
|
address: (val: any) => toChecksumAddress(val.toString(16))
|
|
};
|
|
|
|
const mapppedType = valueMapping[type];
|
|
|
|
return mapppedType ? mapppedType(value) : BN.isBN(value) ? value.toString() : value;
|
|
};
|
|
|
|
private parsePreEncodedValue = (_: string, value: any) =>
|
|
BN.isBN(value) ? value.toString() : value;
|
|
|
|
private makeFuncParams = () =>
|
|
this.inputs.reduce((accumulator, currInput) => {
|
|
const { name, type } = currInput;
|
|
const inputHandler = (inputToParse: any) =>
|
|
//TODO: introduce typechecking and typecasting mapping for inputs
|
|
({ name, type, value: this.parsePreEncodedValue(type, inputToParse) });
|
|
|
|
return {
|
|
...accumulator,
|
|
[name]: { processInput: inputHandler, type, name }
|
|
};
|
|
}, {});
|
|
|
|
private makeEncodedFuncCall = (args: string[]) => {
|
|
const encodedArgs = abi.rawEncode(this.inputTypes, args).toString('hex');
|
|
return addHexPrefix(`${this.methodSelector}${encodedArgs}`);
|
|
};
|
|
|
|
private processSuppliedArgs = (suppliedArgs: ISuppliedArgs) =>
|
|
this.inputNames.map(name => {
|
|
const type = this.funcParams[name].type;
|
|
//TODO: parse args based on type
|
|
if (typeof suppliedArgs[name] === 'undefined') {
|
|
throw Error(
|
|
`Expected argument "${name}" of type "${type}" missing, suppliedArgs: ${JSON.stringify(
|
|
suppliedArgs,
|
|
null,
|
|
2
|
|
)}`
|
|
);
|
|
}
|
|
const value = suppliedArgs[name];
|
|
|
|
const processedArg = this.funcParams[name].processInput(value);
|
|
|
|
return processedArg.value;
|
|
});
|
|
}
|