queries

package
v0.4.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 28, 2024 License: Apache-2.0 Imports: 3 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	FirstUnprocessedBlock = `` /* 510-byte string literal not displayed */

	UnlockBlocksForProcessing = `` /* 153-byte string literal not displayed */

	// TakeXactLock acquires an exclusive lock (with lock ID $1), with custom semantics.
	// The lock is automatically unlocked at the end of the db transaction.
	TakeXactLock = `
    SELECT pg_advisory_xact_lock($1)`

	PickBlocksForProcessing = `` /* 2253-byte string literal not displayed */

	ProcessedSubrangeInfo = `` /* 941-byte string literal not displayed */

	IsBlockProcessedBySlowSync = `` /* 197-byte string literal not displayed */

	SoftEnqueueGapsInProcessedBlocks = `` /* 884-byte string literal not displayed */

	IndexingProgress = `` /* 143-byte string literal not displayed */

	NodeHeight = `
    SELECT height
    FROM chain.latest_node_heights
    WHERE layer = $1`

	NodeHeightUpsert = `` /* 175-byte string literal not displayed */

	ConsensusBlockUpsert = `` /* 627-byte string literal not displayed */

	ConsensusBlockAddSigners = `
    UPDATE chain.blocks
      SET signer_entity_ids = $2
      WHERE height = $1`

	ConsensusEpochUpsert = `` /* 266-byte string literal not displayed */

	ConsensusFastSyncEpochHeightInsert = `
    INSERT INTO todo_updates.epochs (epoch, height)
      VALUES ($1, $2)`

	ConsensusEpochsRecompute = `` /* 375-byte string literal not displayed */

	ConsensusTransactionInsert = `` /* 200-byte string literal not displayed */

	ConsensusAccountUpsert = `` /* 769-byte string literal not displayed */

	ConsensusAccountNonceUpsert = `
    INSERT INTO chain.accounts(address, nonce)
    VALUES ($1, $2)
    ON CONFLICT (address) DO UPDATE
      SET nonce = $2`

	ConsensusAccountFirstActivityUpsert = `` /* 201-byte string literal not displayed */

	ConsensusAccountsFirstActivityRecompute = `` /* 666-byte string literal not displayed */

	ConsensusCommissionsUpsert = `` /* 159-byte string literal not displayed */

	ConsensusEventInsert = `` /* 202-byte string literal not displayed */

	ConsensusEscrowEventInsert = `` /* 162-byte string literal not displayed */

	ConsensusRoothashMessageScheduleUpsert = `` /* 323-byte string literal not displayed */

	ConsensusRoothashMessageFinalizeUpsert = `` /* 335-byte string literal not displayed */

	ConsensusAccountRelatedTransactionInsert = `
    INSERT INTO chain.accounts_related_transactions (account_address, tx_block, tx_index)
      VALUES ($1, $2, $3)`

	ConsensusAccountRelatedEventInsert = `` /* 146-byte string literal not displayed */

	ConsensusRuntimeUpsert = `` /* 316-byte string literal not displayed */

	ConsensusRuntimeSuspendedUpdate = `
    UPDATE chain.runtimes
      SET suspended = $2
      WHERE id = $1`

	ConsensusClaimedNodeInsert = `
    INSERT INTO chain.claimed_nodes (entity_id, node_id) VALUES ($1, $2)
      ON CONFLICT (entity_id, node_id) DO NOTHING`

	ConsensusEntityUpsert = `` /* 201-byte string literal not displayed */

	ConsensusNodeUpsert = `` /* 900-byte string literal not displayed */

	ConsensusRuntimeNodesUpsert = `
    INSERT INTO chain.runtime_nodes (runtime_id, node_id) VALUES ($1, $2)
      ON CONFLICT (runtime_id, node_id) DO NOTHING`

	ConsensusRuntimeNodesDelete = `
    DELETE FROM chain.runtime_nodes WHERE node_id = $1`

	ConsensusNodeDelete = `
    DELETE FROM chain.nodes WHERE id = $1`

	ConsensusEntityMetaUpsert = `` /* 188-byte string literal not displayed */

	ConsensusIncreaseGeneralBalanceUpsert = `` /* 180-byte string literal not displayed */

	ConsensusDecreaseGeneralBalanceUpsert = `
    UPDATE chain.accounts
    SET
      general_balance = general_balance - $2
    WHERE address = $1`

	ConsensusAddEscrowBalanceUpsert = `` /* 323-byte string literal not displayed */

	ConsensusAddDelegationsUpsert = `` /* 189-byte string literal not displayed */

	ConsensusTakeEscrowUpdateGuessRatio = `` /* 357-byte string literal not displayed */

	ConsensusTakeEscrowUpdateExact = `` /* 186-byte string literal not displayed */

	ConsensusDebondingStartEscrowBalanceUpdate = `` /* 332-byte string literal not displayed */

	ConsensusDebondingStartDelegationsUpdate = `
    UPDATE chain.delegations
      SET shares = shares - $3
        WHERE delegatee = $1 AND delegator = $2`

	ConsensusDelegationDeleteIfZeroShares = `
    DELETE FROM chain.delegations
      WHERE delegatee = $1 AND delegator = $2 AND shares = 0`

	ConsensusDebondingStartDebondingDelegationsUpsert = `` /* 237-byte string literal not displayed */

	ConsensusReclaimEscrowBalanceUpdate = `` /* 202-byte string literal not displayed */

	// debond_end IN ($4::bigint, $4::bigint - 1, 0) is used because:
	// - Network upgrades delays debonding by 1 epoch.
	// - Some very old events might not have the debond_end set, so we have 0 in the Db.
	//   This should not be problematic in practice since nowadays we have fast-sync where
	//   we skip inserting debonding delegations for old epochs, so we should not encounter this.
	ConsensusDeleteDebondingDelegations = `` /* 156-byte string literal not displayed */

	ConsensusAllowanceChangeDelete = `
    DELETE FROM chain.allowances
      WHERE owner = $1 AND beneficiary = $2`

	ConsensusAllowanceOwnerUpsert = `
    INSERT INTO chain.accounts (address)
      VALUES ($1)
    ON CONFLICT (address) DO NOTHING`

	ConsensusAllowanceChangeUpdate = `` /* 179-byte string literal not displayed */

	ConsensusValidatorNodeResetVotingPowers = `
    UPDATE chain.nodes SET voting_power = 0`

	ConsensusValidatorNodeUpdateVotingPower = `
    UPDATE chain.nodes SET voting_power = $2
      WHERE id = $1`

	ConsensusCommitteeMemberInsert = `
    INSERT INTO chain.committee_members (node, valid_for, runtime, kind, role)
      VALUES ($1, $2, $3, $4, $5)`

	ConsensusCommitteeMembersTruncate = `
    TRUNCATE chain.committee_members`

	ConsensusProposalSubmissionInsert = `` /* 280-byte string literal not displayed */

	ConsensusProposalSubmissionCancelInsert = `` /* 186-byte string literal not displayed */

	ConsensusProposalSubmissionChangeParametersInsert = `` /* 227-byte string literal not displayed */

	ConsensusProposalExecutionsUpdate = `
    UPDATE chain.proposals
    SET executed = true
      WHERE id = $1`

	ConsensusProposalUpdate = `
    UPDATE chain.proposals
    SET state = $2
      WHERE id = $1`

	ConsensusProposalInvalidVotesUpdate = `
    UPDATE chain.proposals
    SET invalid_votes = $2
      WHERE id = $1`

	ConsensusVoteUpsert = `` /* 197-byte string literal not displayed */

	ValidatorStakingHistoryUnprocessedEpochs = `` /* 358-byte string literal not displayed */

	ValidatorBalanceInsert = `` /* 213-byte string literal not displayed */

	ValidatorStakingRewardUpdate = `
    UPDATE history.validators
    SET staking_rewards = $3
    WHERE 
      id = $1 AND
      epoch = $2`

	EpochValidatorsUpdate = `
    UPDATE chain.epochs
    SET validators = $2
      WHERE id = $1`

	ValidatorStakingHistoryUnprocessedCount = `` /* 196-byte string literal not displayed */

	RuntimeBlockInsert = `` /* 261-byte string literal not displayed */

	RuntimeTransactionSignerInsert = `` /* 152-byte string literal not displayed */

	RuntimeRelatedTransactionInsert = `` /* 128-byte string literal not displayed */

	RuntimeAccountNumTxsUpsert = `` /* 193-byte string literal not displayed */

	// Recomputes the number of related transactions for all runtime account in runtime $1.
	// Inteded for use after fast-sync that ran up to height $2 (inclusive).
	RuntimeAccountNumTxsRecompute = `` /* 422-byte string literal not displayed */

	RuntimeAccountTotalSentUpsert = `` /* 201-byte string literal not displayed */

	RuntimeAccountTotalSentRecompute = `` /* 431-byte string literal not displayed */

	RuntimeAccountTotalReceivedUpsert = `` /* 213-byte string literal not displayed */

	// $3 should be the symbol of the _native_ token.
	RuntimeAccountTotalReceivedRecompute = `` /* 473-byte string literal not displayed */

	RuntimeTransactionInsert = `` /* 791-byte string literal not displayed */

	// We use COALESCE here to avoid overwriting existing data with null values.
	RuntimeTransactionEvmParsedFieldsUpdate = `` /* 336-byte string literal not displayed */

	RuntimeEventInsert = `` /* 241-byte string literal not displayed */

	// We use COALESCE here to avoid overwriting existing data with null values.
	RuntimeEventEvmParsedFieldsUpdate = `` /* 335-byte string literal not displayed */

	RuntimeMintInsert = `` /* 131-byte string literal not displayed */

	RuntimeBurnInsert = `` /* 131-byte string literal not displayed */

	RuntimeTransferInsert = `` /* 129-byte string literal not displayed */

	RuntimeNativeBalanceUpsert = `` /* 220-byte string literal not displayed */

	RuntimeNativeBalanceAbsoluteUpsert = `` /* 199-byte string literal not displayed */

	AddressPreimageInsert = `` /* 158-byte string literal not displayed */

	RuntimeEVMContractCreationUpsert = `` /* 245-byte string literal not displayed */

	RuntimeEVMContractRuntimeBytecodeUpsert = `` /* 189-byte string literal not displayed */

	RuntimeAccountGasForCallingUpsert = `` /* 214-byte string literal not displayed */

	// Recomputes the total gas used for calling every runtime contract in runtime $1.
	// Inteded for use after fast-sync that ran up to height $2 (inclusive).
	RuntimeAccountGasForCallingRecompute = `` /* 546-byte string literal not displayed */

	RuntimeEVMContractCodeAnalysisInsert = `` /* 149-byte string literal not displayed */

	RuntimeEVMContractCodeAnalysisSetIsContract = `
    UPDATE analysis.evm_contract_code
    SET is_contract = $3
    WHERE runtime = $1 AND contract_candidate = $2`

	RuntimeEVMContractCodeAnalysisStale = `` /* 612-byte string literal not displayed */

	RuntimeEVMContractCodeAnalysisStaleCount = `` /* 176-byte string literal not displayed */

	RuntimeEVMTokenBalanceUpdate = `` /* 248-byte string literal not displayed */

	RuntimeEVMTokenBalanceAnalysisMutateRoundUpsert = `` /* 331-byte string literal not displayed */

	RuntimeFastSyncEVMTokenBalanceAnalysisMutateRoundInsert = `` /* 149-byte string literal not displayed */

	// Recomputes the last round at which a token balance was known to mutate.
	// Inteded for use after fast-sync.
	RuntimeEVMTokenBalanceAnalysisMutateRoundRecompute = `` /* 492-byte string literal not displayed */

	RuntimeEVMTokenAnalysisStale = `` /* 616-byte string literal not displayed */

	RuntimeEVMTokenAnalysisStaleCount = `` /* 202-byte string literal not displayed */

	// Upserts a new EVM token, but the column values are treated as deltas (!) to the existing values.
	// NOTE: Passing a 0 for last_mutate round causes that field to not be updated, effectively signalling
	//       "this upsert does not create a need for a subsequent download of info from the EVM runtime".
	RuntimeEVMTokenDeltaUpsert = `` /* 354-byte string literal not displayed */

	RuntimeFastSyncEVMTokenDeltaInsert = `` /* 154-byte string literal not displayed */

	RuntimeEVMTokenRecompute = `` /* 646-byte string literal not displayed */

	// Upserts a new EVM token with information that was downloaded from the EVM runtime (as opposed to dead-reckoned).
	RuntimeEVMTokenDownloadedUpsert = `` /* 503-byte string literal not displayed */

	// Updates the total_supply of an EVM token with information that was downloaded from the EVM runtime (as opposed to dead-reckoned).
	RuntimeEVMTokenDownloadedTotalSupplyUpdate = `
    UPDATE chain.evm_tokens
    SET
      total_supply = $3
    WHERE
      runtime = $1 AND
      token_address = $2`

	// Updates the last_download_round of an EVM token.
	RuntimeEVMTokenDownloadRoundUpdate = `
    UPDATE chain.evm_tokens
    SET
      last_download_round = $3
    WHERE
      runtime = $1 AND
      token_address = $2`

	RuntimeEVMNFTUpdate = `` /* 277-byte string literal not displayed */

	RuntimeEVMNFTUpsert = `` /* 215-byte string literal not displayed */

	RuntimeEVMNFTUpdateTransfer = `` /* 169-byte string literal not displayed */

	RuntimeEVMNFTAnalysisStale = `` /* 950-byte string literal not displayed */

	RuntimeEVMNFTAnalysisStaleCount = `` /* 170-byte string literal not displayed */

	RuntimeEVMTokenBalanceAnalysisStale = fmt.Sprintf(`
    WITH
    max_processed_round AS (
      SELECT MAX(height) AS height
      FROM analysis.processed_blocks
      WHERE analyzer = ($1::runtime)::text AND processed_time IS NOT NULL
    ),

    stale_evm_tokens AS (
      SELECT
        balance_analysis.token_address,
        balance_analysis.account_address,
        evm_tokens.token_type,
        COALESCE(evm_token_balances.balance, 0) AS balance, -- evm_token_balances entry can be absent in fast-sync mode
        token_preimage.context_identifier,
        token_preimage.context_version,
        token_preimage.address_data,
        account_preimage.context_identifier,
        account_preimage.context_version,
        account_preimage.address_data,
        max_processed_round.height AS download_round
      FROM max_processed_round,
      analysis.evm_token_balances AS balance_analysis
      -- No LEFT JOIN; we need to know the token's type to query its balance.
      -- We do not exclude tokens with type=0 (unsupported) so that we can move them off the DB index of stale tokens.
      JOIN chain.evm_tokens USING (runtime, token_address)
      LEFT JOIN chain.evm_token_balances USING (runtime, token_address, account_address)
      LEFT JOIN chain.address_preimages AS token_preimage ON
        token_preimage.address = balance_analysis.token_address
      LEFT JOIN chain.address_preimages AS account_preimage ON
        account_preimage.address = balance_analysis.account_address
      WHERE
        evm_tokens.token_type IS NOT NULL AND
        balance_analysis.runtime = $1 AND
        (
          balance_analysis.last_download_round IS NULL OR
          balance_analysis.last_mutate_round > balance_analysis.last_download_round
        )
    ),

    stale_native_tokens AS (
      SELECT
        balance_analysis.token_address,
        balance_analysis.account_address,
        %d AS token_type,
        COALESCE(balances.balance, 0) AS balance,
        '' AS token_context_identifier,
        -1 AS token_context_version,
        ''::BYTEA AS token_address_data,
        account_preimage.context_identifier,
        account_preimage.context_version,
        account_preimage.address_data,
        max_processed_round.height AS download_round
      FROM max_processed_round,
      analysis.evm_token_balances AS balance_analysis
      LEFT JOIN chain.runtime_sdk_balances AS balances ON (
        balances.runtime = balance_analysis.runtime AND
        balances.account_address = balance_analysis.account_address AND
        balances.symbol = $2
      )
      LEFT JOIN chain.address_preimages AS account_preimage ON
        account_preimage.address = balance_analysis.account_address
      WHERE
        balance_analysis.runtime = $1 AND
        balance_analysis.token_address = '%s' AND  -- Native token "address"
        (
          balance_analysis.last_download_round IS NULL OR
          balance_analysis.last_mutate_round > balance_analysis.last_download_round
        )
    )

    SELECT * FROM (
      SELECT * FROM stale_evm_tokens
      UNION ALL
      SELECT * FROM stale_native_tokens
    ) foo LIMIT $3`,
		common.TokenTypeNative,
		evm.NativeRuntimeTokenAddress,
	)

	RuntimeEVMTokenBalanceAnalysisStaleCount = `` /* 288-byte string literal not displayed */

	RuntimeEVMTokenBalanceAnalysisUpdate = `` /* 167-byte string literal not displayed */

	RuntimeEVMSwapPairUpsertCreated = `` /* 349-byte string literal not displayed */

	RuntimeEVMSwapPairUpsertSync = `` /* 309-byte string literal not displayed */

	RuntimeEVMUnverfiedContracts = `` /* 538-byte string literal not displayed */

	RuntimeEVMVerifiedContracts = `` /* 186-byte string literal not displayed */

	RuntimeEVMVerifyContractUpsert = `` /* 519-byte string literal not displayed */

	RuntimeEvmVerifiedContractTxs = `` /* 821-byte string literal not displayed */

	RuntimeEvmVerifiedContractEvents = `` /* 783-byte string literal not displayed */

)

Functions

This section is empty.

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL