watcher-ts/packages/uniswap/queries.md
Ashwin Phatak 69f4cf3513
Uniswap queries/mapping analysis (#91)
* List down view method in uniswap core contracts.

* List queries used in uniswap subgraph frontend.

* Analyse uniswap subgraph entities with mappings.

* Generate schema graphql file for uniswap subgraph.

* Schema graphql for queries used in subgraph frontend.

Co-authored-by: nikugogoi <95nikass@gmail.com>
2021-06-29 10:39:32 +05:30

13 KiB

Queries

  • uniswap-v3 endpoint (https://api.thegraph.com/subgraphs/name/ianlapham/uniswap-v3-alt)

    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/pools/chartData.ts

      query poolDayDatas($startTime: Int!, $skip: Int!, $address: Bytes!) {
        poolDayDatas(
          first: 1000
          skip: $skip
          where: { pool: $address, date_gt: $startTime }
          orderBy: date
          orderDirection: asc
        ) {
          date
          volumeUSD
          tvlUSD
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/pools/poolData.ts

      query pools {
        pools(where: {id_in: $poolString}, block: {number: $block}, orderBy: totalValueLockedUSD, orderDirection: desc) {
          id
          feeTier
          liquidity
          sqrtPrice
          tick
          token0 {
              id
              symbol
              name
              decimals
              derivedETH
          }
          token1 {
              id
              symbol
              name
              decimals
              derivedETH
          }
          token0Price
          token1Price
          volumeUSD
          txCount
          totalValueLockedToken0
          totalValueLockedToken1
          totalValueLockedUSD
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/pools/tickData.ts

      query surroundingTicks(
        $poolAddress: String!
        $tickIdxLowerBound: BigInt!
        $tickIdxUpperBound: BigInt!
        $skip: Int!
      ) {
        ticks(
          first: 1000
          skip: $skip
          where: { poolAddress: $poolAddress, tickIdx_lte: $tickIdxUpperBound, tickIdx_gte: $tickIdxLowerBound }
        ) {
          tickIdx
          liquidityGross
          liquidityNet
          price0
          price1
        }
      }
      
      query pool($poolAddress: String!) {
        pool(id: $poolAddress) {
          tick
          token0 {
            symbol
            id
            decimals
          }
          token1 {
            symbol
            id
            decimals
          }
          feeTier
          sqrtPrice
          liquidity
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/pools/topPools.ts

      query topPools {
        pools(first: 50, orderBy: totalValueLockedUSD, orderDirection: desc) {
          id
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/pools/transactions.ts

      query transactions($address: Bytes!) {
        mints(first: 100, orderBy: timestamp, orderDirection: desc, where: { pool: $address }) {
          timestamp
          transaction {
            id
          }
          pool {
            token0 {
              id
              symbol
            }
            token1 {
              id
              symbol
            }
          }
          owner
          sender
          origin
          amount0
          amount1
          amountUSD
        }
        swaps(first: 100, orderBy: timestamp, orderDirection: desc, where: { pool: $address }) {
          timestamp
          transaction {
            id
          }
          pool {
            token0 {
              id
              symbol
            }
            token1 {
              id
              symbol
            }
          }
          origin
          amount0
          amount1
          amountUSD
        }
        burns(first: 100, orderBy: timestamp, orderDirection: desc, where: { pool: $address }) {
          timestamp
          transaction {
            id
          }
          pool {
            token0 {
              id
              symbol
            }
            token1 {
              id
              symbol
            }
          }
          owner
          amount0
          amount1
          amountUSD
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/protocol/chart.ts

      query uniswapDayDatas($startTime: Int!, $skip: Int!) {
        uniswapDayDatas(first: 1000, skip: $skip, where: { date_gt: $startTime }, orderBy: date, orderDirection: asc) {
          id
          date
          volumeUSD
          tvlUSD
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/protocol/overview.ts

      query uniswapFactories {
        factories(
          block: { number: $block }
          first: 1) {
          txCount
          totalVolumeUSD
          totalFeesUSD
          totalValueLockedUSD
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/protocol/transactions.ts

      query transactions {
        transactions(first: 500, orderBy: timestamp, orderDirection: desc) {
          id
          timestamp
          mints {
            pool {
              token0 {
                id
                symbol
              }
              token1 {
                id
                symbol
              }
            }
            owner
            sender
            origin
            amount0
            amount1
            amountUSD
          }
          swaps {
            pool {
              token0 {
                id
                symbol
              }
              token1 {
                id
                symbol
              }
            }
            origin
            amount0
            amount1
            amountUSD
          }
          burns {
            pool {
              token0 {
                id
                symbol
              }
              token1 {
                id
                symbol
              }
            }
            owner
            origin
            amount0
            amount1
            amountUSD
          }
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/search/index.ts

      query tokens($value: String, $id: String) {
        asSymbol: tokens(where: { symbol_contains: $value }, orderBy: totalValueLockedUSD, orderDirection: desc) {
          id
          symbol
          name
          totalValueLockedUSD
        }
        asName: tokens(where: { name_contains: $value }, orderBy: totalValueLockedUSD, orderDirection: desc) {
          id
          symbol
          name
          totalValueLockedUSD
        }
        asAddress: tokens(where: { id: $id }, orderBy: totalValueLockedUSD, orderDirection: desc) {
          id
          symbol
          name
          totalValueLockedUSD
        }
      }
      
      query pools($tokens: [Bytes]!, $id: String) {
        as0: pools(where: { token0_in: $tokens }) {
          id
          feeTier
          token0 {
            id
            symbol
            name
          }
          token1 {
            id
            symbol
            name
          }
        }
        as1: pools(where: { token1_in: $tokens }) {
          id
          feeTier
          token0 {
            id
            symbol
            name
          }
          token1 {
            id
            symbol
            name
          }
        }
        asAddress: pools(where: { id: $id }) {
          id
          feeTier
          token0 {
            id
            symbol
            name
          }
          token1 {
            id
            symbol
            name
          }
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/tokens/chartData.ts

      query tokenDayDatas($startTime: Int!, $skip: Int!, $address: Bytes!) {
        tokenDayDatas(
          first: 1000
          skip: $skip
          where: { token: $address, date_gt: $startTime }
          orderBy: date
          orderDirection: asc
        ) {
          date
          volumeUSD
          totalValueLockedUSD
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/tokens/poolsForToken.ts

      query topPools($address: Bytes!) {
        asToken0: pools(first: 200, orderBy: totalValueLockedUSD, orderDirection: desc, where: { token0: $address }) {
          id
        }
        asToken1: pools(first: 200, orderBy: totalValueLockedUSD, orderDirection: desc, where: { token1: $address }) {
          id
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/tokens/priceData.ts

      query blocks {
        tBlockTimestamp:token(id:$tokenAddress, block: { number: $blockNumber }) {
          derivedETH
        },
        bBlockTimestamp: bundle(id:"1", block: { number: $blockNumber }) {
          ethPriceUSD
        }
      }
      
      query tokenHourDatas($startTime: Int!, $skip: Int!, $address: Bytes!) {
        tokenHourDatas(
          first: 100
          skip: $skip
          where: { token: $address, periodStartUnix_gt: $startTime }
          orderBy: periodStartUnix
          orderDirection: asc
        ) {
          periodStartUnix
          high
          low
          open
          close
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/tokens/tokenData.ts

      query tokens {
        tokens(where: {id_in: $tokenString}, block: {number: $block}), orderBy: totalValueLockedUSD, orderDirection: desc) {
          id
          symbol
          name
          derivedETH
          volumeUSD
          volume
          txCount
          totalValueLocked
          feesUSD
          totalValueLockedUSD
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/tokens/topTokens.ts

      query topPools {
        tokens(first: 50, orderBy: totalValueLockedUSD, orderDirection: desc) {
          id
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/tokens/transactions.ts

      query transactions($address: Bytes!) {
        mintsAs0: mints(first: 500, orderBy: timestamp, orderDirection: desc, where: { token0: $address }) {
          timestamp
          transaction {
            id
          }
          pool {
            token0 {
              id
              symbol
            }
            token1 {
              id
              symbol
            }
          }
          owner
          sender
          origin
          amount0
          amount1
          amountUSD
        }
        mintsAs1: mints(first: 500, orderBy: timestamp, orderDirection: desc, where: { token0: $address }) {
          timestamp
          transaction {
            id
          }
          pool {
            token0 {
              id
              symbol
            }
            token1 {
              id
              symbol
            }
          }
          owner
          sender
          origin
          amount0
          amount1
          amountUSD
        }
        swapsAs0: swaps(first: 500, orderBy: timestamp, orderDirection: desc, where: { token0: $address }) {
          timestamp
          transaction {
            id
          }
          pool {
            token0 {
              id
              symbol
            }
            token1 {
              id
              symbol
            }
          }
          origin
          amount0
          amount1
          amountUSD
        }
        swapsAs1: swaps(first: 500, orderBy: timestamp, orderDirection: desc, where: { token1: $address }) {
          timestamp
          transaction {
            id
          }
          pool {
            token0 {
              id
              symbol
            }
            token1 {
              id
              symbol
            }
          }
          origin
          amount0
          amount1
          amountUSD
        }
        burnsAs0: burns(first: 500, orderBy: timestamp, orderDirection: desc, where: { token0: $address }) {
          timestamp
          transaction {
            id
          }
          pool {
            token0 {
              id
              symbol
            }
            token1 {
              id
              symbol
            }
          }
          owner
          amount0
          amount1
          amountUSD
        }
        burnsAs1: burns(first: 500, orderBy: timestamp, orderDirection: desc, where: { token1: $address }) {
          timestamp
          transaction {
            id
          }
          pool {
            token0 {
              id
              symbol
            }
            token1 {
              id
              symbol
            }
          }
          owner
          amount0
          amount1
          amountUSD
        }
      }
      
    • https://github.com/Uniswap/uniswap-v3-info/blob/master/src/hooks/useEthPrices.ts

      query prices($block24: Int!, $block48: Int!, $blockWeek: Int!) {
        current: bundles(first: 1) {
          ethPriceUSD
        }
        oneDay: bundles(first: 1, block: { number: $block24 }) {
          ethPriceUSD
        }
        twoDay: bundles(first: 1, block: { number: $block48 }) {
          ethPriceUSD
        }
        oneWeek: bundles(first: 1, block: { number: $blockWeek }) {
          ethPriceUSD
        }
      }
      
  • ethereum-blocks endpoint (https://api.thegraph.com/subgraphs/name/blocklytics/ethereum-blocks)

    https://github.com/Uniswap/uniswap-v3-info/blob/master/src/hooks/useBlocksFromTimestamps.ts

    query blocks {
      tTimestamp1:blocks(first: 1, orderBy: timestamp, orderDirection: desc, where: { timestamp_gt: $timestamp1, timestamp_lt: $timestamp1Plus600 }) {
        number
      }
    
      tTimestamp2:blocks(first: 1, orderBy: timestamp, orderDirection: desc, where: { timestamp_gt: $timestamp2, timestamp_lt: $timestamp2Plus600 }) {
        number
      }
    }
    
  • Checking subgraph health (https://thegraph.com/docs/deploy-a-subgraph#checking-subgraph-health)

    https://github.com/Uniswap/uniswap-v3-info/blob/master/src/data/application/index.ts

    query health {
      indexingStatusForCurrentVersion(subgraphName: "uniswap/uniswap-v2") {
        synced
        health
        chains {
          chainHeadBlock {
            number
          }
          latestBlock {
            number
          }
        }
      }
    }