* Start removing duplicated functionality (v1 inside v2) * Update compilation targets * Update locks * Fix js-old build * Update with removed extra references * Adapt dev.{parity,web3}.html for extra debug info * Update dependencies * Remove Tooltips * Update dependencies * Only inject window.ethereum once * Fix versions to 2.0.x for @parity libraries * Update to @parity/api 2.1.x * Update for @parity/api 2.1.x * Freeze signer plugin dependency hashes * Fix lint * Move local account handling from API * Update for 2.2.x @parity/{shared,ui} * Update API references for middleware * Install updated dependencies * Update for build * Always do local builds for development * Remove unused hasAccounts property * Fix Windows build for js-old * Adjust inclusing rules to be Windows friendly * Explicitly add --config option to webpack * Add process.env.EMBED flag for Windows compatability * Revert embed flag * Fix build * Merge changes from beta * Update packages after merge * Update Accounts from beta * Update with beta * Remove upgrade check * Fix CI build script execution * Make rm -rf commands cross-platform * Remove ability to deploy wallets (only watch) * Update path references for js-old (Windows) * Render local dapps first * Cleanup dependencies
153 lines
3.8 KiB
JavaScript
153 lines
3.8 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 { personalAccountsInfo } from './personalActions';
|
|
|
|
let instance;
|
|
|
|
export default class Personal {
|
|
constructor (store, api) {
|
|
this._api = api;
|
|
this._store = store;
|
|
}
|
|
|
|
static get (store) {
|
|
if (!instance && store) {
|
|
return Personal.init(store);
|
|
}
|
|
|
|
return instance;
|
|
}
|
|
|
|
static init (store) {
|
|
const { api } = store.getState();
|
|
|
|
if (!instance) {
|
|
instance = new Personal(store, api);
|
|
} else if (!instance) {
|
|
throw new Error('The Personal Provider has not been initialized yet');
|
|
}
|
|
|
|
return instance;
|
|
}
|
|
|
|
static start () {
|
|
const self = instance;
|
|
|
|
return Personal.stop()
|
|
.then(() => Promise.all([
|
|
self._removeDeleted(),
|
|
self._subscribeAccountsInfo()
|
|
]));
|
|
}
|
|
|
|
static stop () {
|
|
if (!instance) {
|
|
return Promise.resolve();
|
|
}
|
|
|
|
const self = instance;
|
|
|
|
return self._unsubscribeAccountsInfo();
|
|
}
|
|
|
|
_subscribeAccountsInfo () {
|
|
let resolved = false;
|
|
|
|
// The Promise will be resolved when the first
|
|
// accounts are loaded
|
|
return new Promise((resolve, reject) => {
|
|
this._api
|
|
.subscribe('parity_allAccountsInfo', (error, accountsInfo) => {
|
|
if (error) {
|
|
console.error('parity_allAccountsInfo', error);
|
|
|
|
if (!resolved) {
|
|
resolved = true;
|
|
return reject(error);
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
// Add the address to each accounts
|
|
Object.keys(accountsInfo)
|
|
.forEach((address) => {
|
|
accountsInfo[address].address = address;
|
|
});
|
|
|
|
const { dispatch, getState } = this._store;
|
|
|
|
personalAccountsInfo(accountsInfo)(dispatch, getState)
|
|
.then(() => {
|
|
if (!resolved) {
|
|
resolved = true;
|
|
return resolve();
|
|
}
|
|
})
|
|
.catch((error) => {
|
|
if (!resolved) {
|
|
resolved = true;
|
|
return reject(error);
|
|
}
|
|
});
|
|
})
|
|
.then((subId) => {
|
|
this.subscriptionId = subId;
|
|
});
|
|
});
|
|
}
|
|
|
|
_unsubscribeAccountsInfo () {
|
|
// Unsubscribe to any previous
|
|
// subscriptions
|
|
if (this.subscriptionId) {
|
|
return this._api
|
|
.unsubscribe(this.subscriptionId)
|
|
.then(() => {
|
|
this.subscriptionId = null;
|
|
});
|
|
}
|
|
|
|
return Promise.resolve();
|
|
}
|
|
|
|
_removeDeleted () {
|
|
return this._api.parity
|
|
.allAccountsInfo()
|
|
.then((accountsInfo) => {
|
|
return Promise.all(
|
|
Object
|
|
.keys(accountsInfo)
|
|
.filter((address) => {
|
|
const account = accountsInfo[address];
|
|
|
|
return !account.uuid && account.meta && account.meta.deleted;
|
|
})
|
|
.map((address) => this._api.parity.removeAddress(address))
|
|
);
|
|
})
|
|
.then((results) => {
|
|
if (results.length) {
|
|
console.log(`Removed ${results.length} previously marked addresses`);
|
|
}
|
|
})
|
|
.catch((error) => {
|
|
console.warn('removeDeleted', error);
|
|
});
|
|
}
|
|
}
|