Skip to content

Commit

Permalink
Workaround a ledger issue with unregistered pools
Browse files Browse the repository at this point in the history
  • Loading branch information
kderme committed Oct 22, 2023
1 parent d2227a1 commit d651fe6
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 9 deletions.
2 changes: 1 addition & 1 deletion cardano-db-sync/src/Cardano/DbSync/Era/Shelley/Genesis.hs
Original file line number Diff line number Diff line change
Expand Up @@ -292,7 +292,7 @@ insertStaking tracer cache blkId genesis = do
let stakes = zip [0 ..] $ ListMap.toList (sgsStake $ sgStaking genesis)
forM_ stakes $ \(n, (keyStaking, keyPool)) -> do
insertStakeRegistration (EpochNo 0) txId (2 * n) (Generic.annotateStakingCred network (KeyHashObj keyStaking))
insertDelegation cache network 0 0 txId (2 * n + 1) Nothing (KeyHashObj keyStaking) keyPool
insertDelegation tracer cache network 0 0 txId (2 * n + 1) Nothing (KeyHashObj keyStaking) keyPool

-- -----------------------------------------------------------------------------

Expand Down
31 changes: 23 additions & 8 deletions cardano-db-sync/src/Cardano/DbSync/Era/Shelley/Insert.hs
Original file line number Diff line number Diff line change
Expand Up @@ -516,7 +516,7 @@ insertCertificate tracer cache isMember network blkId txId epochNo slotNo redeem
Left (ShelleyTxCertMir mir) -> insertMirCert tracer cache network txId idx mir
Left (ShelleyTxCertGenesisDeleg _gen) ->
liftIO $ logWarning tracer "insertCertificate: Unhandled DCertGenesis certificate"
Right (ConwayTxCertDeleg deleg) -> insertConwayDelegCert cache network txId idx mRedeemerId epochNo slotNo deleg
Right (ConwayTxCertDeleg deleg) -> insertConwayDelegCert tracer cache network txId idx mRedeemerId epochNo slotNo deleg
Right (ConwayTxCertPool pool) -> insertPoolCert tracer cache isMember network epochNo blkId txId idx pool
Right (ConwayTxCertGov c) -> case c of
ConwayRegDRep cred coin anchor ->
Expand Down Expand Up @@ -629,14 +629,15 @@ insertDelegCert ::
SlotNo ->
ShelleyDelegCert StandardCrypto ->
ExceptT SyncNodeError (ReaderT SqlBackend m) ()
insertDelegCert _tracer cache network txId idx mRedeemerId epochNo slotNo dCert =
insertDelegCert tracer cache network txId idx mRedeemerId epochNo slotNo dCert =
case dCert of
ShelleyRegCert cred -> insertStakeRegistration epochNo txId idx $ Generic.annotateStakingCred network cred
ShelleyUnRegCert cred -> insertStakeDeregistration cache network epochNo txId idx mRedeemerId cred
ShelleyDelegCert cred poolkh -> insertDelegation cache network epochNo slotNo txId idx mRedeemerId cred poolkh
ShelleyDelegCert cred poolkh -> insertDelegation tracer cache network epochNo slotNo txId idx mRedeemerId cred poolkh

insertConwayDelegCert ::
(MonadBaseControl IO m, MonadIO m) =>
Trace IO Text ->
Cache ->
Ledger.Network ->
DB.TxId ->
Expand All @@ -646,7 +647,7 @@ insertConwayDelegCert ::
SlotNo ->
ConwayDelegCert StandardCrypto ->
ExceptT SyncNodeError (ReaderT SqlBackend m) ()
insertConwayDelegCert cache network txId idx mRedeemerId epochNo slotNo dCert =
insertConwayDelegCert trce cache network txId idx mRedeemerId epochNo slotNo dCert =
case dCert of
ConwayRegCert cred _dep -> insertStakeRegistration epochNo txId idx $ Generic.annotateStakingCred network cred
ConwayUnRegCert cred _dep -> insertStakeDeregistration cache network epochNo txId idx mRedeemerId cred
Expand All @@ -656,10 +657,10 @@ insertConwayDelegCert cache network txId idx mRedeemerId epochNo slotNo dCert =
insertDeleg cred delegatee
where
insertDeleg cred = \case
DelegStake poolkh -> insertDelegation cache network epochNo slotNo txId idx mRedeemerId cred poolkh
DelegStake poolkh -> insertDelegation trce cache network epochNo slotNo txId idx mRedeemerId cred poolkh
DelegVote drep -> insertDelegationVote cache network txId idx cred drep
DelegStakeVote poolkh drep -> do
insertDelegation cache network epochNo slotNo txId idx mRedeemerId cred poolkh
insertDelegation trce cache network epochNo slotNo txId idx mRedeemerId cred poolkh
insertDelegationVote cache network txId idx cred drep

insertPoolRegister ::
Expand Down Expand Up @@ -860,6 +861,7 @@ insertStakeDeregistration cache network epochNo txId idx mRedeemerId cred = do

insertDelegation ::
(MonadBaseControl IO m, MonadIO m) =>
Trace IO Text ->
Cache ->
Ledger.Network ->
EpochNo ->
Expand All @@ -870,9 +872,22 @@ insertDelegation ::
StakeCred ->
Ledger.KeyHash 'Ledger.StakePool StandardCrypto ->
ExceptT SyncNodeError (ReaderT SqlBackend m) ()
insertDelegation cache network (EpochNo epoch) slotNo txId idx mRedeemerId cred poolkh = do
insertDelegation trce cache network (EpochNo epoch) slotNo txId idx mRedeemerId cred poolkh = do
addrId <- liftLookupFail "insertDelegation" $ queryStakeAddrWithCache cache CacheNew network cred
poolHashId <- liftLookupFail "insertDelegation" $ queryPoolKeyWithCache cache CacheNew poolkh
-- poolHashId <- liftLookupFail "insertDelegation" $ queryPoolKeyWithCache cache CacheNew poolkh
poolHashId <- do
mpoolHashId <- lift $ queryPoolKeyWithCache cache CacheNew poolkh
case mpoolHashId of
Left _err -> do
liftIO $ logWarning trce $
mconcat
["insertDelegation to an unregistered pool "
, textShow poolkh
, ". We will assume that the pool exists and move on."
, " See issue https://github.com/input-output-hk/cardano-ledger/issues/3802"
]
lift $ insertPoolKeyWithCache cache CacheNew poolkh
Right poolHashId -> pure poolHashId
void . lift . DB.insertDelegation $
DB.Delegation
{ DB.delegationAddrId = addrId
Expand Down

0 comments on commit d651fe6

Please sign in to comment.