2017-01-25 18:51:41 +01:00
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
2016-12-15 10:05:52 +01:00
// 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/>.
2017-07-28 10:25:34 +02:00
import Api from '@parity/api' ;
2017-11-21 12:31:34 +01:00
import qs from 'query-string' ;
2017-07-28 10:25:34 +02:00
import Web3 from 'web3' ;
function initProvider ( ) {
2017-11-20 13:37:52 +01:00
const path = window . location . pathname . split ( '/' ) ;
2017-11-21 12:31:34 +01:00
const query = qs . parse ( window . location . search ) ;
2017-11-20 13:37:52 +01:00
2017-11-21 12:31:34 +01:00
let appId = path [ 1 ] || query . appId ;
2017-11-20 13:37:52 +01:00
2017-08-01 15:04:07 +02:00
if ( appId === 'dapps' ) {
2017-11-20 13:37:52 +01:00
appId = path [ 2 ] ;
2017-07-28 10:25:34 +02:00
}
const ethereum = new Api . Provider . PostMessage ( appId ) ;
2017-07-28 15:37:58 +02:00
console . log ( ` Requesting API communications token for ${ appId } ` ) ;
2017-07-28 10:25:34 +02:00
ethereum
. requestNewToken ( )
. then ( ( tokenId ) => {
2017-07-28 15:37:58 +02:00
console . log ( ` Received API communications token ${ tokenId } ` ) ;
2017-07-28 10:25:34 +02:00
} )
. catch ( ( error ) => {
console . error ( 'Unable to retrieve communications token' , error ) ;
} ) ;
window . ethereum = ethereum ;
2017-10-25 16:54:41 +02:00
window . isParity = true ;
2017-07-28 10:25:34 +02:00
return ethereum ;
}
function initWeb3 ( ethereum ) {
// FIXME: Use standard provider for web3
2017-11-13 09:31:08 +01:00
const provider = new Api . Provider . SendAsync ( ethereum ) ;
const web3 = new Web3 ( provider ) ;
if ( ! web3 . currentProvider ) {
web3 . currentProvider = provider ;
}
2017-07-28 10:25:34 +02:00
// set default account
web3 . eth . getAccounts ( ( error , accounts ) => {
if ( error || ! accounts || ! accounts [ 0 ] ) {
return ;
}
web3 . eth . defaultAccount = accounts [ 0 ] ;
} ) ;
window . web3 = web3 ;
}
function initParity ( ethereum ) {
const api = new Api ( ethereum ) ;
2017-09-01 13:03:00 +02:00
window . parity = Object . assign ( { } , window . parity || { } , {
2017-07-28 10:25:34 +02:00
Api ,
api
2017-09-01 13:03:00 +02:00
} ) ;
2017-07-28 10:25:34 +02:00
}
2017-11-13 09:31:08 +01:00
if ( typeof window !== 'undefined' && ! window . isParity ) {
const ethereum = initProvider ( ) ;
2017-07-28 10:25:34 +02:00
2017-11-13 09:31:08 +01:00
initWeb3 ( ethereum ) ;
initParity ( ethereum ) ;
2017-07-28 15:37:58 +02:00
2017-11-13 09:31:08 +01:00
console . warn ( 'Deprecation: Dapps should only used the exposed EthereumProvider on `window.ethereum`, the use of `window.parity` and `window.web3` will be removed in future versions of this injector' ) ;
}