All files / src/Rewards/DbSyncRewardProvider queries.ts

100% Statements 10/10
100% Branches 4/4
100% Functions 1/1
100% Lines 7/7

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 8540x                                                                             40x 11x 11x 11x 11x 11x                                                                                
export const findAccountBalance = `
    WITH current_epoch AS (
        SELECT
            e."no" AS epoch_no,
            optimal_pool_count
        FROM epoch e
        JOIN epoch_param ep ON
            ep.epoch_no = e."no"
        ORDER BY e.no DESC LIMIT 1
    ),
    combined_rewards AS (
        SELECT
            reward.amount,
            reward.addr_id,
            reward.spendable_epoch
        FROM reward
        UNION ALL
        SELECT
            reward_rest.amount,
            reward_rest.addr_id,
            reward_rest.spendable_epoch
        FROM reward_rest
    )
    SELECT 
    (
        SELECT COALESCE(SUM(r.amount),0) 
        FROM combined_rewards r
        JOIN stake_address ON 
            stake_address.id = r.addr_id
        WHERE stake_address.view = $1
        AND r.spendable_epoch <= (SELECT epoch_no FROM current_epoch)
    ) - (
        SELECT COALESCE(SUM(w.amount),0) 
        FROM withdrawal w
        JOIN stake_address ON stake_address.id = w.addr_id
        WHERE stake_address.view = $1
    ) AS balance
`;
 
export const findRewardsHistory = (lowerBound?: number, upperBound?: number) => {
  const whereConditions = [];
  if (lowerBound) whereConditions.push(`"no" >= ${lowerBound}`);
  if (upperBound) whereConditions.push(`"no" <= ${upperBound}`);
  const whereSentence = whereConditions.length > 0 ? `WHERE ${whereConditions.join(' AND ')}` : '';
  return `
  WITH epochs AS (
      SELECT 
          id,
          no AS epoch_no
      FROM epoch
      ${whereSentence}
  ),
  combined_rewards AS (
      SELECT
          reward.amount,
          reward.addr_id,
          reward.earned_epoch,
          reward.pool_id
      FROM reward
      UNION ALL
      SELECT
          reward_rest.amount,
          reward_rest.addr_id,
          reward_rest.earned_epoch,
          NULL as pool_id
      FROM reward_rest
  )
  SELECT
      SUM(r.amount) AS quantity,
      sa."view" AS address,
      r.earned_epoch AS epoch,
      ph."view" as pool_id
  FROM combined_rewards r
  JOIN stake_address sa ON
      sa.id = r.addr_id AND 
      sa."view" = ANY($1)
  JOIN epochs ON 
      r.earned_epoch = epochs.epoch_no
  LEFT JOIN pool_hash ph ON 
      r.pool_id = ph.id
  GROUP BY sa."view", r.earned_epoch, ph."view"
  ORDER BY quantity ASC
`;
};