49fdd23d58
* Move secureApi to shell * Extract isTestnet test * Use mobx + subscriptions for status * Re-add status indicator * Add lerna * Move intial packages to js/packages * Move 3rdparty/{email,sms}-verification to correct location * Move package.json & README to library src * Move tests for library packages * Move views & dapps to packages * Move i18n to root * Move shell to actual src (main app) * Remove ~ references * Change ~ to root (explicit imports) * Finalise convert of ~ * Move views into dapps as well * Move dapps to packages/ * Fix references * Update css * Update test spec locations * Update tests * Case fix * Skip flakey tests * Update enzyme * Skip previously ignored tests * Allow empty api for hw * Re-add theme for embed
136 lines
3.6 KiB
JavaScript
136 lines
3.6 KiB
JavaScript
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
|
// This file is part of Parity.
|
|
|
|
// Parity is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Parity is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
import { sha3, api } from '../parity.js';
|
|
import { getOwner, isOwned } from '../util/registry';
|
|
import postTx from '../util/post-tx';
|
|
|
|
export const clearError = () => ({
|
|
type: 'clearError'
|
|
});
|
|
|
|
const alreadyQueued = (queue, action, name) =>
|
|
!!queue.find((entry) => entry.action === action && entry.name === name);
|
|
|
|
export const reserveStart = (name) => ({ type: 'names reserve start', name });
|
|
|
|
export const reserveSuccess = (name) => ({ type: 'names reserve success', name });
|
|
|
|
export const reserveFail = (name, error) => ({ type: 'names reserve fail', name, error });
|
|
|
|
export const reserve = (name) => (dispatch, getState) => {
|
|
const state = getState();
|
|
const accountAddress = state.accounts.selected;
|
|
const contract = state.contract;
|
|
const fee = state.fee;
|
|
|
|
if (!contract || !accountAddress) {
|
|
return;
|
|
}
|
|
|
|
name = name.toLowerCase();
|
|
|
|
if (alreadyQueued(state.names.queue, 'reserve', name)) {
|
|
return;
|
|
}
|
|
|
|
dispatch(reserveStart(name));
|
|
|
|
return isOwned(contract, name)
|
|
.then((owned) => {
|
|
if (owned) {
|
|
throw new Error(`"${name}" has already been reserved`);
|
|
}
|
|
|
|
const { reserve } = contract.instance;
|
|
|
|
const options = {
|
|
from: accountAddress,
|
|
value: fee
|
|
};
|
|
const values = [
|
|
sha3.text(name)
|
|
];
|
|
|
|
return postTx(api, reserve, options, values);
|
|
})
|
|
.then((txHash) => {
|
|
dispatch(reserveSuccess(name));
|
|
})
|
|
.catch((err) => {
|
|
if (err.type !== 'REQUEST_REJECTED') {
|
|
console.error(`error rerserving ${name}`, err);
|
|
return dispatch(reserveFail(name, err));
|
|
}
|
|
|
|
dispatch(reserveFail(name));
|
|
});
|
|
};
|
|
|
|
export const dropStart = (name) => ({ type: 'names drop start', name });
|
|
|
|
export const dropSuccess = (name) => ({ type: 'names drop success', name });
|
|
|
|
export const dropFail = (name, error) => ({ type: 'names drop fail', name, error });
|
|
|
|
export const drop = (name) => (dispatch, getState) => {
|
|
const state = getState();
|
|
const accountAddress = state.accounts.selected;
|
|
const contract = state.contract;
|
|
|
|
if (!contract || !accountAddress) {
|
|
return;
|
|
}
|
|
|
|
name = name.toLowerCase();
|
|
|
|
if (alreadyQueued(state.names.queue, 'drop', name)) {
|
|
return;
|
|
}
|
|
|
|
dispatch(dropStart(name));
|
|
|
|
return getOwner(contract, name)
|
|
.then((owner) => {
|
|
if (owner.toLowerCase() !== accountAddress.toLowerCase()) {
|
|
throw new Error(`you are not the owner of "${name}"`);
|
|
}
|
|
|
|
const { drop } = contract.instance;
|
|
|
|
const options = {
|
|
from: accountAddress
|
|
};
|
|
|
|
const values = [
|
|
sha3.text(name)
|
|
];
|
|
|
|
return postTx(api, drop, options, values);
|
|
})
|
|
.then((txhash) => {
|
|
dispatch(dropSuccess(name));
|
|
})
|
|
.catch((err) => {
|
|
if (err.type !== 'REQUEST_REJECTED') {
|
|
console.error(`error dropping ${name}`, err);
|
|
return dispatch(dropFail(name, err));
|
|
}
|
|
|
|
dispatch(dropFail(name));
|
|
});
|
|
};
|