Skip to content

Commit

Permalink
Improves verified-caching
Browse files Browse the repository at this point in the history
Resolves brave#12272

Auditors:

Test Plan:
  • Loading branch information
NejcZdovc committed Jan 3, 2018
1 parent ab25724 commit 5492ea0
Show file tree
Hide file tree
Showing 7 changed files with 285 additions and 127 deletions.
134 changes: 90 additions & 44 deletions app/browser/api/ledger.js
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ let balanceTimeoutId = false
let runTimeoutId
let promotionTimeoutId
let togglePromotionTimeoutId
let verifiedTimeoutId = false

// Database
let v2RulesetDB
Expand Down Expand Up @@ -149,12 +150,24 @@ const paymentPresent = (state, tabId, present) => {
if (!balanceTimeoutId) {
module.exports.getBalance(state)
}

getPublisherTimestamp(true)
} else if (balanceTimeoutId) {
clearTimeout(balanceTimeoutId)
balanceTimeoutId = false
}
}

const getPublisherTimestamp = (updateList) => {
client.publisherTimestamp((err, result) => {
if (err) {
console.error('Error while retrieving publisher timestamp', err.toString())
return
}
appActions.onPublisherTimestamp(result.timestamp, updateList)
})
}

const addFoundClosed = (state) => {
if (balanceTimeoutId) {
clearTimeout(balanceTimeoutId)
Expand Down Expand Up @@ -185,13 +198,12 @@ const onBootStateFile = (state) => {
try {
clientprep()
client = ledgerClient(null, underscore.extend({roundtrip: roundtrip}, clientOptions), null)
client.publisherTimestamp((err, result) => {
if (err) {
console.error('Error while retrieving publisher timestamp', err.toString())
return
}
appActions.onPublisherTimestamp(result.timestamp)
})

getPublisherTimestamp()
if (verifiedTimeoutId) {
clearInterval(verifiedTimeoutId)
}
verifiedTimeoutId = setInterval(getPublisherTimestamp, 1 * ledgerUtil.milliseconds.hour)
} catch (ex) {
state = ledgerState.resetInfo(state)
bootP = false
Expand Down Expand Up @@ -540,21 +552,26 @@ const inspectP = (db, path, publisher, property, key, callback) => {

// TODO rename function name
const verifiedP = (state, publisherKey, callback) => {
client.publisherInfo(publisherKey, (err, result) => {
const clientCallback = (err, result) => {
if (err) {
console.error(`Error verifying publisher ${publisherKey}: `, err.toString())
return
}

if (callback) {
let data = false
if (result && result.properties && result.properties.verified) {
data = result.properties.verified
if (result) {
callback(null, result)
} else {
callback(err, {})
}

callback(null, data)
}
})
}

if (Array.isArray(publisherKey)) {
client.publishersInfo(publisherKey, clientCallback)
} else {
client.publisherInfo(publisherKey, clientCallback)
}

if (process.env.NODE_ENV === 'test') {
['brianbondy.com', 'clifton.io'].forEach((key) => {
Expand Down Expand Up @@ -689,30 +706,50 @@ const saveVisit = (state, publisherKey, options) => {
})
state = ledgerState.setPublisher(state, publisherKey, synopsis.publishers[publisherKey])
state = updatePublisherInfo(state)
state = checkVerifiedStatus(state, publisherKey)
state = module.exports.checkVerifiedStatus(state, publisherKey)

return state
}

const checkVerifiedStatus = (state, publisherKey) => {
if (publisherKey == null) {
const checkVerifiedStatus = (state, publisherKeys, publisherTimestamp) => {
if (publisherKeys == null) {
return state
}

const lastUpdate = parseInt(ledgerState.getLedgerValue(state, 'publisherTimestamp'))
const lastPublisherUpdate = parseInt(ledgerState.getPublisherOption(state, publisherKey, 'verifiedTimestamp') || 0)
if (!Array.isArray(publisherKeys)) {
publisherKeys = [publisherKeys]
}

if (lastUpdate > lastPublisherUpdate) {
state = module.exports.verifiedP(state, publisherKey, (error, result) => {
if (!error) {
appActions.onPublisherOptionUpdate(publisherKey, 'verified', result)
appActions.onPublisherOptionUpdate(publisherKey, 'verifiedTimestamp', lastUpdate)
savePublisherOption(publisherKey, 'verified', result)
savePublisherOption(publisherKey, 'verifiedTimestamp', lastUpdate)
}
})
const checkKeys = []
const lastUpdate = parseInt(publisherTimestamp || ledgerState.getLedgerValue(state, 'publisherTimestamp'))

publisherKeys.forEach(key => {
const lastPublisherUpdate = parseInt(ledgerState.getPublisherOption(state, key, 'verifiedTimestamp') || 0)

if (lastUpdate > lastPublisherUpdate) {
checkKeys.push(key)
}
})

if (checkKeys.length === 0) {
return state
}

state = module.exports.verifiedP(state, checkKeys, (error, result) => {
if (!error) {
const publisherKey = result.publisher

if (result && result.properties && result.properties) {
const verified = !!result.properties.verified
appActions.onPublisherOptionUpdate(publisherKey, 'verified', verified)
savePublisherOption(publisherKey, 'verified', verified)
}

appActions.onPublisherOptionUpdate(publisherKey, 'verifiedTimestamp', lastUpdate)
savePublisherOption(publisherKey, 'verifiedTimestamp', lastUpdate)
}
})

return state
}

Expand Down Expand Up @@ -1834,13 +1871,12 @@ const onInitRead = (state, parsedData) => {
client = ledgerClient(parsedData.personaId,
underscore.extend(parsedData.options, {roundtrip: roundtrip}, options),
parsedData)
client.publisherTimestamp((err, result) => {
if (err) {
console.error('Error while retrieving publisher timestamp', err.toString())
return
}
appActions.onPublisherTimestamp(result.timestamp)
})

getPublisherTimestamp()
if (verifiedTimeoutId) {
clearInterval(verifiedTimeoutId)
}
verifiedTimeoutId = setInterval(getPublisherTimestamp, 1 * ledgerUtil.milliseconds.hour)

// Scenario: User enables Payments, disables it, waits 30+ days, then
// enables it again -> reconcileStamp is in the past.
Expand Down Expand Up @@ -2268,13 +2304,7 @@ const transitionWalletToBat = () => {
}))
appActions.onBitcoinToBatTransitioned()
ledgerNotifications.showBraveWalletUpdated()
client.publisherTimestamp((err, result) => {
if (err) {
console.error('Error while retrieving publisher timestamp', err.toString())
return
}
appActions.onPublisherTimestamp(result.timestamp)
})
getPublisherTimestamp()
}
})
} catch (ex) {
Expand Down Expand Up @@ -2504,6 +2534,21 @@ const onPromotionResponse = (state, status) => {
return state
}

const onPublisherTimestamp = (state, oldTimestamp, newTimestamp) => {
if (oldTimestamp === newTimestamp) {
return
}

const publishers = ledgerState.getPublishers(state)
if (publishers.isEmpty()) {
return
}

publishers.forEach((publisher, key) => {
module.exports.checkVerifiedStatus(state, key, newTimestamp)
})
}

const getMethods = () => {
const publicMethods = {
backupKeys,
Expand Down Expand Up @@ -2546,7 +2591,9 @@ const getMethods = () => {
claimPromotion,
onPromotionResponse,
getBalance,
getPromotion
getPromotion,
onPublisherTimestamp,
checkVerifiedStatus
}

let privateMethods = {}
Expand Down Expand Up @@ -2580,7 +2627,6 @@ const getMethods = () => {
},
getCurrentMediaKey: (key) => currentMediaKey,
synopsisNormalizer,
checkVerifiedStatus,
roundtrip,
observeTransactions,
onWalletRecovery,
Expand Down
4 changes: 4 additions & 0 deletions app/browser/reducers/ledgerReducer.js
Original file line number Diff line number Diff line change
Expand Up @@ -402,7 +402,11 @@ const ledgerReducer = (state, action, immutableAction) => {
}
case appConstants.APP_ON_PUBLISHER_TIMESTAMP:
{
const oldValue = ledgerState.getLedgerValue(state, 'publisherTimestamp')
state = ledgerState.setLedgerValue(state, 'publisherTimestamp', action.get('timestamp'))
if (action.get('updateList')) {
ledgerApi.onPublisherTimestamp(state, oldValue, action.get('timestamp'))
}
break
}
case appConstants.APP_SAVE_LEDGER_PROMOTION:
Expand Down
26 changes: 13 additions & 13 deletions docs/state.md
Original file line number Diff line number Diff line change
Expand Up @@ -186,19 +186,19 @@ AppStore
},
info: {
addresses: {
BAT: string,
BTC: string,
CARD_ID: string,
ETH: string,
BAT: string,
BTC: string,
CARD_ID: string,
ETH: string,
LTC: string
},
balance: number, // confirmed balance in BAT.toFixed(2)
bravery: {
days: number,
days: number,
fee: {
amount: number,
currency: string
},
},
setting: string
},
converted: string,
Expand All @@ -210,9 +210,9 @@ AppStore
paymentId: string,
probi: number,
rates:{
BTC: string,
ETH: number,
EUR: number,
BTC: string,
ETH: number,
EUR: number,
USD: number
},
reconcileFrequency: number // duration between each reconciliation in days
Expand Down Expand Up @@ -265,7 +265,7 @@ AppStore
options: {
persist: boolean,
style: string
}
}
},
panel: {
optInMarkup: {
Expand All @@ -288,7 +288,7 @@ AppStore
options: {
persist: boolean,
style: string
}
}
},
panel: {
disclaimer: string,
Expand All @@ -313,7 +313,7 @@ AppStore
options: {
persist: boolean,
style: string
}
}
},
panel: {
disclaimer: string,
Expand Down Expand Up @@ -348,7 +348,7 @@ AppStore
options: {
exclude: boolean,
verified: boolean,
verifiedTimestamp: number, // timestamp of the last change
verifiedTimestamp: number, // timestamp of the last change
stickyP: boolean
},
pinPercentage: number,
Expand Down
5 changes: 3 additions & 2 deletions js/actions/appActions.js
Original file line number Diff line number Diff line change
Expand Up @@ -1826,10 +1826,11 @@ const appActions = {
})
},

onPublisherTimestamp: function (timestamp) {
onPublisherTimestamp: function (timestamp, updateList) {
dispatch({
actionType: appConstants.APP_ON_PUBLISHER_TIMESTAMP,
timestamp
timestamp,
updateList
})
},

Expand Down
Loading

0 comments on commit 5492ea0

Please sign in to comment.