Skip to content

Commit

Permalink
Adds BAT support
Browse files Browse the repository at this point in the history
Resolves brave#10945
  • Loading branch information
NejcZdovc committed Oct 3, 2017
1 parent de5f381 commit 9038bf2
Show file tree
Hide file tree
Showing 22 changed files with 731 additions and 1,454 deletions.
54 changes: 16 additions & 38 deletions app/browser/api/ledger.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ const qr = require('qr-image')
const underscore = require('underscore')
const tldjs = require('tldjs')
const urlFormat = require('url').format
const queryString = require('querystring')
const levelUp = require('level')
const random = require('random-lib')
const uuid = require('uuid')
Expand Down Expand Up @@ -93,7 +92,8 @@ const clientOptions = {
rulesTestP: process.env.LEDGER_RULES_TESTING,
verboseP: process.env.LEDGER_VERBOSE,
server: process.env.LEDGER_SERVER_URL,
createWorker: electron.app.createWorker
createWorker: electron.app.createWorker,
version: 'v2'
}
const fileTypes = {
bmp: new Buffer([0x42, 0x4d]),
Expand Down Expand Up @@ -1107,7 +1107,7 @@ const enable = (state, paymentsEnabled) => {
}

if (!ledgerPublisher) {
ledgerPublisher = require('ledger-publisher')
ledgerPublisher = require('bat-publisher')
}
synopsis = new (ledgerPublisher.Synopsis)()
const stateSynopsis = ledgerState.getSynopsis(state)
Expand Down Expand Up @@ -1146,8 +1146,8 @@ const pathName = (name) => {
const sufficientBalanceToReconcile = (state) => {
const balance = Number(ledgerState.getInfoProp(state, 'balance') || 0)
const unconfirmed = Number(ledgerState.getInfoProp(state, 'unconfirmed') || 0)
const btc = ledgerState.getInfoProp(state, 'btc')
return btc && (balance + unconfirmed > 0.9 * Number(btc))
const bat = ledgerState.getInfoProp(state, 'bat')
return bat && (balance + unconfirmed > 0.9 * Number(bat))
}

const shouldShowNotificationReviewPublishers = () => {
Expand Down Expand Up @@ -1337,7 +1337,7 @@ const cacheRuleSet = (state, ruleset) => {
}

const clientprep = () => {
if (!ledgerClient) ledgerClient = require('ledger-client')
if (!ledgerClient) ledgerClient = require('bat-client')
_internal.debugP = ledgerClient.prototype.boolion(process.env.LEDGER_PUBLISHER_DEBUG)
_internal.verboseP = ledgerClient.prototype.boolion(process.env.LEDGER_PUBLISHER_VERBOSE)
}
Expand Down Expand Up @@ -1416,28 +1416,6 @@ const roundtrip = (params, options, callback) => {
if (options.payload) console.log('<<< ' + JSON.stringify(params.payload, null, 2).split('\n').join('\n<<< '))
}

const updateLedgerInfo = (state) => {
const ledgerInfo = ledgerState.getInfoProps(state)
const now = new Date().getTime()

if (ledgerInfo.get('buyURLExpires') > now) {
state = ledgerState.setInfoProp(state, 'buyMaximumUSD', 6)
}
if (typeof process.env.ADDFUNDS_URL !== 'undefined') {
state = ledgerState.setInfoProp(state, 'buyURLFrame', true)
const buyURL = process.env.ADDFUNDS_URL + '?' +
queryString.stringify({
currency: ledgerInfo.get('currency'),
amount: getSetting(settings.PAYMENTS_CONTRIBUTION_AMOUNT),
address: ledgerInfo.get('address')
})
state = ledgerState.setInfoProp(state, 'buyURL', buyURL)
state = ledgerState.setInfoProp(state, 'buyMaximumUSD', false)
}

return state
}

// Called from observeTransactions() when we see a new payment (transaction).
const showNotificationPaymentDone = (transactionContributionFiat) => {
notificationPaymentDoneMessage = locale.translation('notificationPaymentDone')
Expand Down Expand Up @@ -1482,9 +1460,10 @@ const getStateInfo = (state, parsedData) => {
return state
}

if (!ledgerClient) ledgerClient = require('bat-client')
const newInfo = {
paymentId: parsedData.properties.wallet.paymentId,
passphrase: parsedData.properties.wallet.keychains.passphrase,
passphrase: ledgerClient.prototype.getWalletPassphrase(parsedData),
created: !!parsedData.properties.wallet,
creating: !parsedData.properties.wallet,
reconcileFrequency: parsedData.properties.days,
Expand All @@ -1500,7 +1479,7 @@ const getStateInfo = (state, parsedData) => {

let transactions = []
if (!parsedData.transactions) {
return updateLedgerInfo(state)
return state
}

for (let i = parsedData.transactions.length - 1; i >= 0; i--) {
Expand All @@ -1523,13 +1502,12 @@ const getStateInfo = (state, parsedData) => {
}

observeTransactions(state, transactions)
state = ledgerState.setInfoProp(state, 'transactions', Immutable.fromJS(transactions))
return updateLedgerInfo(state)
return ledgerState.setInfoProp(state, 'transactions', Immutable.fromJS(transactions))
}

const generatePaymentData = (state) => {
const ledgerInfo = ledgerState.getInfoProps(state)
const paymentURL = `bitcoin:${ledgerInfo.get('address')}?amount=${ledgerInfo.get('btc')}&label=${encodeURI('Brave Software')}`
const paymentURL = `bitcoin:${ledgerInfo.get('address')}?amount=${ledgerInfo.get('bat')}&label=${encodeURI('Brave Software')}`
if (ledgerInfo.get('paymentURL') !== paymentURL) {
state = ledgerState.setInfoProp(state, 'paymentURL', paymentURL)
try {
Expand Down Expand Up @@ -1603,8 +1581,8 @@ const onWalletProperties = (state, body) => {
if (amount && currency) {
const bodyCurrency = body.getIn(['rates', 'currency'])
if (bodyCurrency) {
const btc = (amount / bodyCurrency).toFixed(8)
state = ledgerState.setInfoProp(state, 'btc', btc)
const bat = (amount / bodyCurrency).toFixed(8)
state = ledgerState.setInfoProp(state, 'bat', bat)
}
}

Expand Down Expand Up @@ -1668,7 +1646,7 @@ const getBalance = (state) => {
return
}

if (!ledgerBalance) ledgerBalance = require('ledger-balance')
if (!ledgerBalance) ledgerBalance = require('bat-balance')
ledgerBalance.getBalance(address, underscore.extend({balancesP: true}, client.options),
(err, provider, result) => {
if (err) {
Expand All @@ -1693,7 +1671,7 @@ const balanceReceived = (state, unconfirmed) => {
if (clientOptions.verboseP) {
console.log('\ngetBalance refreshes ledger info: ' + ledgerState.getInfoProp(state, 'unconfirmed'))
}
return updateLedgerInfo(state)
return state
}

if (ledgerState.getInfoProp(state, 'unconfirmed') === '0.0000') {
Expand Down Expand Up @@ -1826,7 +1804,7 @@ const initialize = (state, paymentsEnabled) => {
return state
}

if (!ledgerPublisher) ledgerPublisher = require('ledger-publisher')
if (!ledgerPublisher) ledgerPublisher = require('bat-publisher')
let ruleset = []
ledgerPublisher.ruleset.forEach(rule => {
if (rule.consequent) ruleset.push(rule)
Expand Down
1 change: 1 addition & 0 deletions app/browser/reducers/ledgerReducer.js
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,7 @@ const ledgerReducer = (state, action, immutableAction) => {
}
case appConstants.APP_NAVIGATOR_HANDLER_REGISTERED:
{
// TODO will this be changed when switching to BAT
const hasBitcoinHandler = (action.get('protocol') === 'bitcoin')
state = ledgerState.setInfoProp(state, 'hasBitcoinHandler', hasBitcoinHandler)
break
Expand Down
16 changes: 8 additions & 8 deletions app/common/lib/ledgerExportUtil.js
Original file line number Diff line number Diff line change
Expand Up @@ -197,7 +197,7 @@ module.exports.getPublisherVoteData = (transactions, viewingIds) => {
* Generates a contribution breakdown by publisher in an array of CSV rows from an array of transactions
* @example
* txUtil.getTransactionCSVRows(client.state.transactions)
* // [ ['Publisher,Votes,Fraction,BTC,USD'],
* // [ ['Publisher,Votes,Fraction,BAT,USD'],
* // ['chronicle.com,2,0.04081632653061224,0.0000033221,0.20 USD'],
* // ['waitbutwhy.com,3,0.061224489795918366,0.0000049832,0.31 USD'],
* // ['archlinux.org,1,0.02040816326530612,0.0000016611,0.10 USD'],
Expand Down Expand Up @@ -234,13 +234,13 @@ module.exports.getTransactionCSVRows = (transactions, viewingIds, addTotalRow, s

const currency = (publishers.length ? txContribData[publishers[0]].contribution.currency : 'USD')

const headerRow = ['Publisher', 'Votes', 'Fraction', 'BTC', currency].join(',')
const headerRow = ['Publisher', 'Votes', 'Fraction', 'BAT', currency].join(',')

var totalsRow = {
label: 'TOTAL',
votes: 0,
fraction: 0,
btc: 0,
bat: 0,
fiat: 0
}

Expand All @@ -249,10 +249,10 @@ module.exports.getTransactionCSVRows = (transactions, viewingIds, addTotalRow, s
rows = rows.concat(publishers.map(function (pub) {
var pubRow = txContribData[pub]

let rowBTC = pubRow.contribution.satoshis / Math.pow(10, 10)
let rowBAT = pubRow.contribution.satoshis / Math.pow(10, 10)
totalsRow.votes += pubRow.votes
totalsRow.fraction += pubRow.fraction
totalsRow.btc += rowBTC
totalsRow.bat += rowBAT

if (pubRow.contribution.currency === currency) {
totalsRow.fiat += parseFloat(pubRow.contribution.fiat || '0')
Expand All @@ -264,7 +264,7 @@ module.exports.getTransactionCSVRows = (transactions, viewingIds, addTotalRow, s
pub,
pubRow.votes,
pubRow.fraction,
rowBTC,
rowBAT,
pubRow.contribution.fiat.toFixed(2) + ' ' + pubRow.contribution.currency
].join(',')
}))
Expand All @@ -275,7 +275,7 @@ module.exports.getTransactionCSVRows = (transactions, viewingIds, addTotalRow, s
totalsRow.label,
totalsRow.votes,
totalsRow.fraction,
totalsRow.btc,
totalsRow.bat,
totalsRow.fiat.toFixed(2) + ' ' + currency
].join(','))
}
Expand All @@ -287,7 +287,7 @@ module.exports.getTransactionCSVRows = (transactions, viewingIds, addTotalRow, s
* Generates a contribution breakdown by publisher in an array of CSV rows from an array of transactions
* @example
* txUtil.getTransactionCSVText(state.transactions)
* // 'Publisher,Votes,Fraction,BTC,USD\nchronicle.com,2,0.04081632653061224,0.0000033221,0.20 USD\nwaitbutwhy.com,3,0.061224489795918366,0.0000049832,0.31 USD\narchlinux.org,1,0.02040816326530612,0.0000016611,0.10 USD /.../'
* // 'Publisher,Votes,Fraction,BAT,USD\nchronicle.com,2,0.04081632653061224,0.0000033221,0.20 USD\nwaitbutwhy.com,3,0.061224489795918366,0.0000049832,0.31 USD\narchlinux.org,1,0.02040816326530612,0.0000016611,0.10 USD /.../'
*
* @param {Object[]} transactions - array of transactions
* @param {string[]=} viewingIds - OPTIONAL array/string with one or more viewingIds to filter transactions by (if empty, uses all tx)
Expand Down
25 changes: 16 additions & 9 deletions app/common/lib/ledgerUtil.js
Original file line number Diff line number Diff line change
Expand Up @@ -62,17 +62,24 @@ const shouldTrackView = (view, responseList) => {
return false
}

const btcToCurrencyString = (btc, ledgerData) => {
const balance = Number(btc || 0)
const batToCurrencyString = (bat, ledgerData) => {
const balance = Number(bat || 0)
const currency = (ledgerData && ledgerData.get('currency')) || 'USD'

if (balance === 0) {
return `0 ${currency}`
}

if (ledgerData && ledgerData.get('btc') && typeof ledgerData.get('amount') === 'number') {
const btcValue = ledgerData.get('btc') / ledgerData.get('amount')
const fiatValue = (balance / btcValue).toFixed(2)
if (ledgerData == null) {
return `${balance} BAT`
}

const ledgerBat = ledgerData.get('bat')
const amount = ledgerData.get('amount')

if (ledgerBat && typeof amount === 'number') {
const batValue = ledgerBat / amount
const fiatValue = (balance / batValue).toFixed(2)
let roundedValue = Math.floor(fiatValue)
const diff = fiatValue - roundedValue

Expand All @@ -87,7 +94,7 @@ const btcToCurrencyString = (btc, ledgerData) => {
return `${roundedValue.toFixed(2)} ${currency}`
}

return `${balance} BTC`
return `${balance} BAT`
}

const formattedTimeFromNow = (timestamp) => {
Expand All @@ -110,11 +117,11 @@ const walletStatus = (ledgerData) => {
const pendingFunds = Number(ledgerData.get('unconfirmed') || 0)

if (pendingFunds + Number(ledgerData.get('balance') || 0) <
0.9 * Number(ledgerData.get('btc') || 0)) {
0.9 * Number(ledgerData.get('bat') || 0)) {
status.id = 'insufficientFundsStatus'
} else if (pendingFunds > 0) {
status.id = 'pendingFundsStatus'
status.args = {funds: btcToCurrencyString(pendingFunds, ledgerData)}
status.args = {funds: batToCurrencyString(pendingFunds, ledgerData)}
} else if (transactions && transactions.size > 0) {
status.id = 'defaultWalletStatus'
} else {
Expand Down Expand Up @@ -206,7 +213,7 @@ const stickyP = (state, publisherKey) => {

module.exports = {
shouldTrackView,
btcToCurrencyString,
batToCurrencyString,
formattedTimeFromNow,
formattedDateFromTimestamp,
walletStatus,
Expand Down
22 changes: 1 addition & 21 deletions app/extensions/brave/locales/en-US/preferences.properties
Original file line number Diff line number Diff line change
Expand Up @@ -26,16 +26,7 @@ backupLedger=Backup your wallet
balanceRecovered={{balance}} was recovered and transferred to your Brave wallet.
beta=beta
bitcoin=Bitcoin
bitcoinAdd=Use your existing Bitcoin wallet/account
bitcoinAddDescription=Use any BTC wallet that can transfer Bitcoin to your Brave wallet.
bitcoinBalance=Please transfer:&nbsp;
bitcoinBuy=Buy Bitcoin
bitcoinCopyAddress=Copy Bitcoin address to clipboard
bitcoinPaymentURL=Your Brave wallet address
bitcoinQR=Your Brave wallet QR code
bitcoinQRImg.title=Brave wallet QR code
bitcoinVisitAccount=Transfer BTC
bitcoinWalletNotAvailable=Wallet information not available. :(
bitwarden=bitwarden&reg;
blockAttackSites=Block reported attack sites (not available yet)
blockedCountBadge=Display block count badge on shields button
Expand All @@ -60,8 +51,6 @@ cancel=Cancel
checkDefaultOnStartup=Always check on startup
clearAll=Clear all
clearBrowsingDataNow=Clear Browsing Data Now…
coinbaseMessage=debit/credit funding powered by coinbase
coinbaseNotAvailable=Sorry! Adding funds with a credit/debit card is available only for contributions of $5/month at the moment.
comingSoon=Coming soon!
compactBraveryPanel=Use compact panel
contentSettings=Content Settings
Expand Down Expand Up @@ -95,7 +84,6 @@ defaultWalletStatus=Thanks for helping support your favorite websites!
defaultZoomLevel=Default zoom level
disableTitleMode=Always show the URL bar
disconnect=Disconnect
displayQRCode=Display QR code
dollarsPaid=$ Paid
done=Done
doNotManageMyPasswords=Don't manage my passwords
Expand Down Expand Up @@ -132,9 +120,6 @@ flashTroubleshooting=Flash not working? Try the troubleshooting tips on our
fr-FR=French (France)
fullscreenContent=Full Screen Content
fullscreenPermission=Fullscreen access
fundingDisabled1=Card funding is temporarily unavailable.
fundingDisabled2=We apologize for the inconvenience.
fundingDisabled3=Learn more...
general=General
generalSettings=General Settings
geolocationPermission=Location access
Expand Down Expand Up @@ -185,8 +170,6 @@ minimumVisitsHigh=10 visits
minimumVisitsLow=1 visit
minimumVisitsMedium=5 visits
minimumVisitsSetting=Minimum visits for publisher relevancy
moneyAdd=Use your debit/credit card
moneyAddSubTitle=No Bitcoin needed!
monthlyBudget=monthly budget
ms-MY=Malay (Malaysia)
multipleHomePages.title=Multiple home pages
Expand All @@ -213,7 +196,6 @@ ok=Ok
on=on
onePassword=1Password&reg; (requires application)
openExternalPermission=Open external applications
outsideUSAPayment=Buy Bitcoin at our recommended source
pageNofMText=Page {{n}} of {{m}}
paintTabs=Show tabs in page theme color
passwordManager=Password Manager
Expand Down Expand Up @@ -302,7 +284,6 @@ site=Site
sitePermissions=Saved Site Permissions
sitePermissionsExceptions=Saved Site Exceptions
sl=Slovenian
smartphoneTitle=Use your smartphone app to transfer Bitcoin
startsWith=Brave starts with
startsWithOptionHomePage=Home page
startsWithOptionLastTime=My windows / tabs from last time
Expand Down Expand Up @@ -368,7 +349,6 @@ timeSpent=Time Spent
toolbarUserInterfaceScale=Toolbar and UI elements scale
totalAmount=Total Amount
tr-TR=Turkish (Turkey)
transferTime=Transfer may take up to 40 minutes
uk=Ukrainian
update=Update
updateToPreviewReleases=Update to preview releases *
Expand All @@ -385,4 +365,4 @@ visits=Visits
wideURLbar=Use wide URL bar
widevine=Run Google Widevine
widevineSection=Google Widevine Support
zh-CN=Chinese
zh-CN=Chinese
1 change: 0 additions & 1 deletion app/locale.js
Original file line number Diff line number Diff line change
Expand Up @@ -213,7 +213,6 @@ var rendererIdentifiers = function () {
'turnOffNotifications',
'copyToClipboard',
'smartphoneTitle',
'displayQRCode',
'updateLater',
'updateHello',
'notificationPasswordWithUserName',
Expand Down
18 changes: 18 additions & 0 deletions app/renderer/components/preferences/payment/addFounds.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/. */

const React = require('react')

// Components
const ImmutableComponent = require('../../immutableComponent')

class AddFounds extends ImmutableComponent {
render () {
return <section data-test-id='addFounds'>
Add founds
</section>
}
}

module.exports = AddFounds
Loading

0 comments on commit 9038bf2

Please sign in to comment.