mirror of
https://github.com/oceanprotocol/ocean-subgraph.git
synced 2024-12-02 05:57:29 +01:00
Bug/fix non ocean pools (#75)
* fix non ocean pools * fixed fre bugs * fix lint
This commit is contained in:
parent
c092e64835
commit
52e8fb1e30
@ -169,13 +169,33 @@ export function updatePoolTransactionToken(
|
|||||||
feeValue: BigDecimal
|
feeValue: BigDecimal
|
||||||
): void {
|
): void {
|
||||||
log.warning('WWWWWWWWWW ---- started update ptx with id {}', [poolTx])
|
log.warning('WWWWWWWWWW ---- started update ptx with id {}', [poolTx])
|
||||||
|
log.warning('updatePoolTransactionToken({}, {} , {} , {} , {}}', [
|
||||||
|
poolTx,
|
||||||
|
poolTokenId,
|
||||||
|
amount.toString(),
|
||||||
|
balance.toString(),
|
||||||
|
feeValue.toString()
|
||||||
|
])
|
||||||
const ptx = PoolTransaction.load(poolTx)
|
const ptx = PoolTransaction.load(poolTx)
|
||||||
const poolToken = PoolToken.load(poolTokenId)
|
const poolToken = PoolToken.load(poolTokenId)
|
||||||
const pool = PoolEntity.load(poolToken.poolId)
|
const pool = PoolEntity.load(poolToken.poolId)
|
||||||
|
if (!ptx) {
|
||||||
|
log.error('Cannot load PoolTransaction {}', [poolTx])
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if (!poolToken) {
|
||||||
|
log.error('Cannot load PoolToken {}', [poolTokenId])
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if (!pool) {
|
||||||
|
log.error('Cannot load PoolEntity {}', [poolToken.poolId])
|
||||||
|
return
|
||||||
|
}
|
||||||
const ptxTokenValuesId = poolTx.concat('-').concat(poolToken.tokenAddress)
|
const ptxTokenValuesId = poolTx.concat('-').concat(poolToken.tokenAddress)
|
||||||
let ptxTokenValues = PoolTransactionTokenValues.load(ptxTokenValuesId)
|
let ptxTokenValues = PoolTransactionTokenValues.load(ptxTokenValuesId)
|
||||||
if (ptxTokenValues == null) {
|
if (ptxTokenValues == null) {
|
||||||
ptxTokenValues = new PoolTransactionTokenValues(ptxTokenValuesId)
|
ptxTokenValues = new PoolTransactionTokenValues(ptxTokenValuesId)
|
||||||
|
log.warning('created PoolTransactionTokenValues for {}', [ptxTokenValuesId])
|
||||||
}
|
}
|
||||||
ptxTokenValues.txId = poolTx
|
ptxTokenValues.txId = poolTx
|
||||||
ptxTokenValues.poolToken = poolTokenId
|
ptxTokenValues.poolToken = poolTokenId
|
||||||
@ -193,7 +213,7 @@ export function updatePoolTransactionToken(
|
|||||||
}
|
}
|
||||||
|
|
||||||
ptxTokenValues.save()
|
ptxTokenValues.save()
|
||||||
|
log.warning('ptxTokenValues {} saved', [ptxTokenValues.id])
|
||||||
if (ptxTokenValues.tokenAddress == OCEAN) {
|
if (ptxTokenValues.tokenAddress == OCEAN) {
|
||||||
const factory = PoolFactory.load('1')
|
const factory = PoolFactory.load('1')
|
||||||
factory.totalOceanLiquidity =
|
factory.totalOceanLiquidity =
|
||||||
@ -225,8 +245,9 @@ export function updatePoolTransactionToken(
|
|||||||
// ptxTokenValues.tokenReserve.toString(),
|
// ptxTokenValues.tokenReserve.toString(),
|
||||||
// poolToken.poolId
|
// poolToken.poolId
|
||||||
// ])
|
// ])
|
||||||
|
log.warning('saving ptx {} ', [ptx.id.toString()])
|
||||||
ptx.save()
|
ptx.save()
|
||||||
|
log.warning('saving pool {} ', [pool.id.toString()])
|
||||||
pool.save()
|
pool.save()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { BigInt, ethereum } from '@graphprotocol/graph-ts'
|
import { BigInt, ethereum, log } from '@graphprotocol/graph-ts'
|
||||||
import {
|
import {
|
||||||
ExchangeCreated,
|
ExchangeCreated,
|
||||||
ExchangeActivated,
|
ExchangeActivated,
|
||||||
@ -23,6 +23,10 @@ export function handleExchangeCreated(event: ExchangeCreated): void {
|
|||||||
fixedrateexchange.datatoken = event.params.dataToken.toHexString()
|
fixedrateexchange.datatoken = event.params.dataToken.toHexString()
|
||||||
fixedrateexchange.baseToken = event.params.baseToken.toHexString()
|
fixedrateexchange.baseToken = event.params.baseToken.toHexString()
|
||||||
fixedrateexchange.active = false
|
fixedrateexchange.active = false
|
||||||
|
log.info('for new exchange {} for rate {}', [
|
||||||
|
event.params.exchangeId.toHexString(),
|
||||||
|
event.params.fixedRate.toString()
|
||||||
|
])
|
||||||
fixedrateexchange.rate = tokenToDecimal(
|
fixedrateexchange.rate = tokenToDecimal(
|
||||||
event.params.fixedRate.toBigDecimal(),
|
event.params.fixedRate.toBigDecimal(),
|
||||||
BigInt.fromI32(18).toI32()
|
BigInt.fromI32(18).toI32()
|
||||||
@ -71,10 +75,20 @@ export function handleExchangeRateChanged(event: ExchangeRateChanged): void {
|
|||||||
const fixedrateexchange = FixedRateExchange.load(
|
const fixedrateexchange = FixedRateExchange.load(
|
||||||
event.params.exchangeId.toHexString()
|
event.params.exchangeId.toHexString()
|
||||||
)
|
)
|
||||||
|
if (!fixedrateexchange) {
|
||||||
|
log.error('Cannot update unknown FRE {}', [
|
||||||
|
event.params.exchangeId.toHexString()
|
||||||
|
])
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
const freupdate = new FixedRateExchangeUpdate(id)
|
const freupdate = new FixedRateExchangeUpdate(id)
|
||||||
freupdate.exchangeId = fixedrateexchange.id
|
freupdate.exchangeId = fixedrateexchange.id
|
||||||
freupdate.oldRate = fixedrateexchange.rate
|
freupdate.oldRate = fixedrateexchange.rate
|
||||||
|
log.info('for new exchange {} for rate {}', [
|
||||||
|
id,
|
||||||
|
event.params.newRate.toString()
|
||||||
|
])
|
||||||
freupdate.newRate = tokenToDecimal(
|
freupdate.newRate = tokenToDecimal(
|
||||||
event.params.newRate.toBigDecimal(),
|
event.params.newRate.toBigDecimal(),
|
||||||
BigInt.fromI32(18).toI32()
|
BigInt.fromI32(18).toI32()
|
||||||
|
@ -6,10 +6,11 @@ import { Datatoken, MetadataUpdate } from '../@types/schema'
|
|||||||
export function handleMetadataEvent(
|
export function handleMetadataEvent(
|
||||||
event: ethereum.Event,
|
event: ethereum.Event,
|
||||||
dtAddress: string,
|
dtAddress: string,
|
||||||
updatedBy: string
|
updatedBy: string,
|
||||||
|
created: boolean
|
||||||
): void {
|
): void {
|
||||||
const datatoken = Datatoken.load(dtAddress)
|
const datatoken = Datatoken.load(dtAddress)
|
||||||
|
if (datatoken) {
|
||||||
const tx = event.transaction.hash
|
const tx = event.transaction.hash
|
||||||
const id = tx.toHexString().concat('-').concat(dtAddress)
|
const id = tx.toHexString().concat('-').concat(dtAddress)
|
||||||
const metadataUpdate = new MetadataUpdate(id)
|
const metadataUpdate = new MetadataUpdate(id)
|
||||||
@ -19,20 +20,20 @@ export function handleMetadataEvent(
|
|||||||
metadataUpdate.datatokenAddress = dtAddress
|
metadataUpdate.datatokenAddress = dtAddress
|
||||||
metadataUpdate.userAddress = updatedBy
|
metadataUpdate.userAddress = updatedBy
|
||||||
metadataUpdate.datatokenId = dtAddress
|
metadataUpdate.datatokenId = dtAddress
|
||||||
|
|
||||||
metadataUpdate.save()
|
metadataUpdate.save()
|
||||||
|
|
||||||
datatoken.metadataUpdateCount = datatoken.metadataUpdateCount.plus(
|
datatoken.metadataUpdateCount = datatoken.metadataUpdateCount.plus(
|
||||||
BigInt.fromI32(1)
|
BigInt.fromI32(1)
|
||||||
)
|
)
|
||||||
datatoken.save()
|
datatoken.save()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export function handleMetadataUpdated(event: MetadataUpdated): void {
|
export function handleMetadataUpdated(event: MetadataUpdated): void {
|
||||||
handleMetadataEvent(
|
handleMetadataEvent(
|
||||||
event,
|
event,
|
||||||
event.params.dataToken.toHexString(),
|
event.params.dataToken.toHexString(),
|
||||||
event.params.updatedBy.toHexString()
|
event.params.updatedBy.toHexString(),
|
||||||
|
false
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -40,6 +41,7 @@ export function handleMetadataCreated(event: MetadataCreated): void {
|
|||||||
handleMetadataEvent(
|
handleMetadataEvent(
|
||||||
event,
|
event,
|
||||||
event.params.dataToken.toHexString(),
|
event.params.dataToken.toHexString(),
|
||||||
event.params.createdBy.toHexString()
|
event.params.createdBy.toHexString(),
|
||||||
|
true
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { BigInt, Address, BigDecimal } from '@graphprotocol/graph-ts'
|
import { BigInt, Address, BigDecimal, log } from '@graphprotocol/graph-ts'
|
||||||
import {
|
import {
|
||||||
LOG_CALL,
|
LOG_CALL,
|
||||||
LOG_JOIN,
|
LOG_JOIN,
|
||||||
@ -66,6 +66,16 @@ export function handleSetPublicSwap(event: LOG_CALL): void {
|
|||||||
export function handleFinalize(event: LOG_CALL): void {
|
export function handleFinalize(event: LOG_CALL): void {
|
||||||
const poolId = event.address.toHex()
|
const poolId = event.address.toHex()
|
||||||
const pool = Pool.load(poolId)
|
const pool = Pool.load(poolId)
|
||||||
|
if (pool === null) {
|
||||||
|
log.error('Cannot handle finalize for unknown pool {} ', [poolId])
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if (pool.tokenCount == BigInt.fromI32(0)) {
|
||||||
|
log.error('Cannot mark pool {} finalized, because we have 0 tokenCount', [
|
||||||
|
poolId
|
||||||
|
])
|
||||||
|
return
|
||||||
|
}
|
||||||
pool.finalized = true
|
pool.finalized = true
|
||||||
pool.symbol = 'BPT'
|
pool.symbol = 'BPT'
|
||||||
pool.publicSwap = true
|
pool.publicSwap = true
|
||||||
@ -157,6 +167,10 @@ export function handleSetup(event: LOG_CALL): void {
|
|||||||
const baseTokenWeight = data.slice(330, 394) // (74+(4*64),74+(5*64))
|
const baseTokenWeight = data.slice(330, 394) // (74+(4*64),74+(5*64))
|
||||||
const swapFee = data.slice(394) // (74+(5*64), END)
|
const swapFee = data.slice(394) // (74+(5*64), END)
|
||||||
|
|
||||||
|
if (baseTokenAddress != OCEAN) {
|
||||||
|
log.error('baseTokenAddress is not Ocean, but is {}', [baseTokenAddress])
|
||||||
|
return
|
||||||
|
}
|
||||||
const poolTokenId = poolId.concat('-').concat(baseTokenAddress)
|
const poolTokenId = poolId.concat('-').concat(baseTokenAddress)
|
||||||
const poolToken = PoolToken.load(poolTokenId)
|
const poolToken = PoolToken.load(poolTokenId)
|
||||||
if (poolToken != null) return
|
if (poolToken != null) return
|
||||||
|
Loading…
Reference in New Issue
Block a user