classic-ui/modules/account/store/actions/utils.js

84 lines
2.1 KiB
JavaScript
Raw Permalink Normal View History

import { fetchEvents } from '@/services'
2022-06-10 02:41:41 +10:00
import networkConfig from '@/networkConfig'
2022-04-22 13:05:56 +10:00
function createMutation({ commit, rootState }, { type, payload }) {
const { netId } = rootState.metamask
commit(type, { ...payload, netId })
}
function clearState({ dispatch }, { key }) {
dispatch('createMutation', {
type: 'CLEAR_STATE',
payload: { key }
})
}
2022-06-10 02:41:41 +10:00
async function getEventsFromBlockPart({ echoContract, address, currentBlockNumber, netId }) {
try {
// const { events: graphEvents, lastSyncBlock } = await graph.getNoteAccounts({ address, netId })
const { events: allEvents, lastSyncBlock } = await fetchEvents({
type: 'echo',
netId
})
const graphEvents = allEvents.filter((el) => address === el.address)
2022-06-10 02:41:41 +10:00
if (graphEvents.length) {
return graphEvents
}
let { NOTE_ACCOUNT_BLOCK: fromBlock } = networkConfig[`netId${netId}`].constants
if (lastSyncBlock) {
fromBlock = lastSyncBlock
}
const blockDifference = Math.ceil(currentBlockNumber - lastSyncBlock)
let blockRange = blockDifference
if (Number(netId) === 56) {
blockRange = 4950
}
let numberParts = blockDifference === 0 ? 1 : Math.ceil(blockDifference / blockRange)
const part = Math.ceil(blockDifference / numberParts)
let events = []
let toBlock = lastSyncBlock + part
if (toBlock >= currentBlockNumber) {
toBlock = 'latest'
numberParts = 1
}
for (let i = 0; i < numberParts; i++) {
const partOfEvents = await echoContract.getEvents({
fromBlock,
toBlock,
address
})
if (partOfEvents) {
events = events.concat(
partOfEvents.map((event) => ({
address: event.returnValues.who,
encryptedAccount: event.returnValues.data
}))
)
2022-06-10 02:41:41 +10:00
}
fromBlock = toBlock
toBlock += part
}
events = graphEvents.concat(events)
return events
} catch (err) {
console.log(`getEventsFromBlock has error: ${err.message}`)
return false
}
}
export { clearState, createMutation, getEventsFromBlockPart }