|
| 1 | +/* eslint-disable @typescript-eslint/naming-convention */ |
| 2 | +import { MigrationBuilder, ColumnDefinitions } from 'node-pg-migrate'; |
| 3 | + |
| 4 | +export const shorthands: ColumnDefinitions | undefined = undefined; |
| 5 | + |
| 6 | +export function up(pgm: MigrationBuilder): void { |
| 7 | + pgm.sql(` |
| 8 | + UPDATE reward_set_signers rss |
| 9 | + SET |
| 10 | + signer_stacked_amount_percentage = (rss.signer_stacked_amount::numeric / total.total_stacked), |
| 11 | + signer_weight_percentage = (rss.signer_weight::float / total.total_weight), |
| 12 | + signer_stacked_amount_rank = ranked.rank |
| 13 | + FROM |
| 14 | + (SELECT cycle_number, SUM(signer_stacked_amount::numeric) as total_stacked, SUM(signer_weight) as total_weight FROM reward_set_signers GROUP BY cycle_number) total, |
| 15 | + (SELECT signer_key, cycle_number, RANK() OVER (PARTITION BY cycle_number ORDER BY signer_stacked_amount::numeric DESC, signer_key ASC) as rank FROM reward_set_signers) ranked |
| 16 | + WHERE rss.cycle_number = total.cycle_number AND rss.cycle_number = ranked.cycle_number AND rss.signer_key = ranked.signer_key |
| 17 | + `); |
| 18 | + pgm.sql(` |
| 19 | + UPDATE reward_set_signers rss |
| 20 | + SET |
| 21 | + proposals_accepted_count = COALESCE(agg.accepted_count, 0), |
| 22 | + proposals_rejected_count = COALESCE(agg.rejected_count, 0), |
| 23 | + proposals_missed_count = COALESCE(agg.missed_count, 0), |
| 24 | + average_response_time_ms = COALESCE(agg.avg_ms, 0), |
| 25 | + last_response_time = agg.last_time, |
| 26 | + last_response_metadata_server_version = agg.last_version |
| 27 | + FROM |
| 28 | + ( |
| 29 | + WITH signer_proposal_data AS ( |
| 30 | + SELECT |
| 31 | + rss.signer_key, |
| 32 | + rss.cycle_number, |
| 33 | + bp.block_hash, |
| 34 | + bp.received_at AS proposal_received_at, |
| 35 | + br.accepted, |
| 36 | + br.received_at AS response_received_at, |
| 37 | + br.metadata_server_version, |
| 38 | + EXTRACT(EPOCH FROM (br.received_at - bp.received_at)) * 1000 AS response_time_ms |
| 39 | + FROM reward_set_signers rss |
| 40 | + JOIN block_proposals bp ON bp.reward_cycle = rss.cycle_number |
| 41 | + LEFT JOIN block_responses br ON br.signer_sighash = bp.block_hash AND br.signer_key = rss.signer_key |
| 42 | + ), |
| 43 | + aggregated_data AS ( |
| 44 | + SELECT |
| 45 | + signer_key, |
| 46 | + cycle_number, |
| 47 | + COUNT(CASE WHEN accepted = true THEN 1 END)::integer AS accepted_count, |
| 48 | + COUNT(CASE WHEN accepted = false THEN 1 END)::integer AS rejected_count, |
| 49 | + COUNT(CASE WHEN accepted IS NULL THEN 1 END)::integer AS missed_count, |
| 50 | + ROUND(AVG(response_time_ms), 3)::float8 AS avg_ms |
| 51 | + FROM signer_proposal_data |
| 52 | + GROUP BY signer_key, cycle_number |
| 53 | + ), |
| 54 | + latest_response AS ( |
| 55 | + SELECT |
| 56 | + signer_key, |
| 57 | + cycle_number, |
| 58 | + MAX(response_received_at) AS last_time, |
| 59 | + (array_agg(metadata_server_version ORDER BY response_received_at DESC))[1] AS last_version |
| 60 | + FROM signer_proposal_data |
| 61 | + WHERE response_received_at IS NOT NULL |
| 62 | + GROUP BY signer_key, cycle_number |
| 63 | + ) |
| 64 | + SELECT |
| 65 | + agg.signer_key, |
| 66 | + agg.cycle_number, |
| 67 | + agg.accepted_count, |
| 68 | + agg.rejected_count, |
| 69 | + agg.missed_count, |
| 70 | + agg.avg_ms, |
| 71 | + lr.last_time, |
| 72 | + lr.last_version |
| 73 | + FROM aggregated_data agg |
| 74 | + LEFT JOIN latest_response lr ON lr.signer_key = agg.signer_key AND lr.cycle_number = agg.cycle_number |
| 75 | + ) agg |
| 76 | + WHERE rss.signer_key = agg.signer_key AND rss.cycle_number = agg.cycle_number |
| 77 | + `); |
| 78 | + |
| 79 | + // Drop old unused table that was not dropped in a previous migration. |
| 80 | + pgm.dropTable('reward_set_signers_old-no-slot-index'); |
| 81 | +} |
| 82 | + |
| 83 | +export function down(pgm: MigrationBuilder): void { |
| 84 | + pgm.sql(` |
| 85 | + UPDATE reward_set_signers |
| 86 | + SET |
| 87 | + last_response_time = NULL, |
| 88 | + last_response_metadata_server_version = NULL, |
| 89 | + proposals_accepted_count = 0, |
| 90 | + proposals_rejected_count = 0, |
| 91 | + proposals_missed_count = 0, |
| 92 | + average_response_time_ms = 0, |
| 93 | + signer_stacked_amount_percentage = 0, |
| 94 | + signer_stacked_amount_rank = 0, |
| 95 | + signer_weight_percentage = 0 |
| 96 | + `); |
| 97 | +} |
0 commit comments