aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/controllers/currency.js
diff options
context:
space:
mode:
authorkumavis <aaron@kumavis.me>2018-10-30 08:25:05 +0800
committerkumavis <aaron@kumavis.me>2018-10-30 08:25:05 +0800
commitccbc2332829569b6bb416ced624ee3123c54b939 (patch)
treeb865d8b499a00921b4b38f2839dfc6c631aa4666 /app/scripts/controllers/currency.js
parentf0602ca354a6d352c13a79a1cba884f54e5b9a83 (diff)
parent1bb4a8428c73c1f1137793b25900db159eec3fa8 (diff)
downloadtangerine-wallet-browser-ccbc2332829569b6bb416ced624ee3123c54b939.tar
tangerine-wallet-browser-ccbc2332829569b6bb416ced624ee3123c54b939.tar.gz
tangerine-wallet-browser-ccbc2332829569b6bb416ced624ee3123c54b939.tar.bz2
tangerine-wallet-browser-ccbc2332829569b6bb416ced624ee3123c54b939.tar.lz
tangerine-wallet-browser-ccbc2332829569b6bb416ced624ee3123c54b939.tar.xz
tangerine-wallet-browser-ccbc2332829569b6bb416ced624ee3123c54b939.tar.zst
tangerine-wallet-browser-ccbc2332829569b6bb416ced624ee3123c54b939.zip
Merge branch 'develop' of github.com:MetaMask/metamask-extension into sentry-enhancements2
Diffstat (limited to 'app/scripts/controllers/currency.js')
-rw-r--r--app/scripts/controllers/currency.js58
1 files changed, 54 insertions, 4 deletions
diff --git a/app/scripts/controllers/currency.js b/app/scripts/controllers/currency.js
index 6b82265f6..cc78ef8a6 100644
--- a/app/scripts/controllers/currency.js
+++ b/app/scripts/controllers/currency.js
@@ -21,6 +21,7 @@ class CurrencyController {
* since midnight of January 1, 1970
* @property {number} conversionInterval The id of the interval created by the scheduleConversionInterval method.
* Used to clear an existing interval on subsequent calls of that method.
+ * @property {string} nativeCurrency The ticker/symbol of the native chain currency
*
*/
constructor (opts = {}) {
@@ -28,6 +29,7 @@ class CurrencyController {
currentCurrency: 'usd',
conversionRate: 0,
conversionDate: 'N/A',
+ nativeCurrency: 'ETH',
}, opts.initState)
this.store = new ObservableStore(initState)
}
@@ -37,6 +39,29 @@ class CurrencyController {
//
/**
+ * A getter for the nativeCurrency property
+ *
+ * @returns {string} A 2-4 character shorthand that describes the specific currency
+ *
+ */
+ getNativeCurrency () {
+ return this.store.getState().nativeCurrency
+ }
+
+ /**
+ * A setter for the nativeCurrency property
+ *
+ * @param {string} nativeCurrency The new currency to set as the nativeCurrency in the store
+ *
+ */
+ setNativeCurrency (nativeCurrency) {
+ this.store.updateState({
+ nativeCurrency,
+ ticker: nativeCurrency,
+ })
+ }
+
+ /**
* A getter for the currentCurrency property
*
* @returns {string} A 2-4 character shorthand that describes a specific currency, currently selected by the user
@@ -104,16 +129,28 @@ class CurrencyController {
*
*/
async updateConversionRate () {
- let currentCurrency
+ let currentCurrency, nativeCurrency
try {
currentCurrency = this.getCurrentCurrency()
+ nativeCurrency = this.getNativeCurrency()
+ // select api
+ let apiUrl
+ if (nativeCurrency === 'ETH') {
+ // ETH
+ apiUrl = `https://api.infura.io/v1/ticker/eth${currentCurrency.toLowerCase()}`
+ } else {
+ // ETC
+ apiUrl = `https://min-api.cryptocompare.com/data/price?fsym=${nativeCurrency.toUpperCase()}&tsyms=${currentCurrency.toUpperCase()}`
+ }
+ // attempt request
let response
try {
- response = await fetch(`https://api.infura.io/v1/ticker/eth${currentCurrency.toLowerCase()}`)
+ response = await fetch(apiUrl)
} catch (err) {
log.error(new Error(`CurrencyController - Failed to request currency from Infura:\n${err.stack}`))
return
}
+ // parse response
let rawResponse
let parsedResponse
try {
@@ -123,8 +160,21 @@ class CurrencyController {
log.error(new Error(`CurrencyController - Failed to parse response "${rawResponse}"`))
return
}
- this.setConversionRate(Number(parsedResponse.bid))
- this.setConversionDate(Number(parsedResponse.timestamp))
+ // set exhcange rate
+ if (nativeCurrency === 'ETH') {
+ // ETH
+ this.setConversionRate(Number(parsedResponse.bid))
+ this.setConversionDate(Number(parsedResponse.timestamp))
+ } else {
+ // ETC
+ if (parsedResponse[currentCurrency.toUpperCase()]) {
+ this.setConversionRate(Number(parsedResponse[currentCurrency.toUpperCase()]))
+ this.setConversionDate(parseInt((new Date()).getTime() / 1000))
+ } else {
+ this.setConversionRate(0)
+ this.setConversionDate('N/A')
+ }
+ }
} catch (err) {
// reset current conversion rate
this.setConversionRate(0)