Skip to content

Commit

Permalink
Added reg cert
Browse files Browse the repository at this point in the history
  • Loading branch information
Soupstraw committed Nov 21, 2024
1 parent 363b1f6 commit d61a6c9
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 9 deletions.
26 changes: 18 additions & 8 deletions src/Ledger/Certs.lagda
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ record PoolParams : Type where
\begin{code}
data DCert : Type where
delegate : Credential → Maybe VDeleg → Maybe KeyHash → Coin → DCert
reg : Credential → Coin → DCert
dereg : Credential → Coin → DCert
regpool : KeyHash → PoolParams → DCert
retirepool : KeyHash → Epoch → DCert
Expand All @@ -58,14 +59,15 @@ data DCert : Type where
\end{code}
\begin{NoConway}
\begin{code}
cwitness : DCert → Credential
cwitness (delegate c _ _ _) = c
cwitness (dereg c _) = c
cwitness (regpool kh _) = KeyHashObj kh
cwitness (retirepool kh _) = KeyHashObj kh
cwitness (regdrep c _ _) = c
cwitness (deregdrep c _) = c
cwitness (ccreghot c _) = c
cwitness : DCert → Maybe Credential
cwitness (delegate c _ _ _) = just c
cwitness (dereg c _) = just c
cwitness (regpool kh _) = just $ KeyHashObj kh
cwitness (retirepool kh _) = just $ KeyHashObj kh
cwitness (regdrep c _ _) = just c
cwitness (deregdrep c _) = just c
cwitness (ccreghot c _) = just c
cwitness (reg _ _) = nothing
\end{code}
\end{NoConway}
\end{AgdaMultiCode}
Expand Down Expand Up @@ -322,6 +324,14 @@ data _⊢_⇀⦇_,DELEG⦈_ where
⟦ vDelegs , sDelegs , rwds ⟧ᵈ ⇀⦇ delegate c mv mkh d ,DELEG⦈
⟦ insertIfJust c mv vDelegs , insertIfJust c mkh sDelegs , rwds ∪ˡ ❴ c , 0 ❵ ⟧ᵈ

DELEG-reg : let open PParams pp in
∙ c ∉ dom rwds
∙ d ≡ keyDeposit
────────────────────────────────
⟦ pp , pools , delegatees ⟧ᵈᵉ ⊢
⟦ vDelegs , sDelegs , rwds ⟧ᵈ ⇀⦇ reg c d ,DELEG⦈
⟦ insertIfJust c mv vDelegs , insertIfJust c mkh sDelegs , rwds ∪ˡ ❴ c , 0 ❵ ⟧ᵈ

DELEG-dereg :
∙ (c , 0) ∈ rwds
────────────────────────────────
Expand Down
1 change: 1 addition & 0 deletions src/Ledger/Conway/Conformance/Certs.agda
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ certRefund _ = ∅

updateCertDeposit : PParams DCert Deposits Deposits
updateCertDeposit pp (delegate c _ _ v) deposits = deposits ∪⁺ ❴ CredentialDeposit c , v ❵
updateCertDeposit pp (reg c _) deposits = deposits ∪⁺ ❴ CredentialDeposit c , pp .PParams.keyDeposit ❵
updateCertDeposit pp (regdrep c v _) deposits = deposits ∪⁺ ❴ DRepDeposit c , v ❵
updateCertDeposit pp (dereg c _) deposits = deposits ∣ ❴ CredentialDeposit c ❵ ᶜ
updateCertDeposit pp (deregdrep c _) deposits = deposits ∣ ❴ DRepDeposit c ❵ ᶜ
Expand Down
4 changes: 4 additions & 0 deletions src/Ledger/ScriptValidation.agda
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ txInfo l pp utxo tx = record
} where open Tx tx; open TxBody body

data DelegateOrDeReg : DCert Type where instance
reg : {x y} DelegateOrDeReg (reg x y)
delegate : {x y z w} DelegateOrDeReg (delegate x y z w)
dereg : {x y} DelegateOrDeReg (dereg x y)
regdrep : {x y z} DelegateOrDeReg (regdrep x y z)
Expand All @@ -87,6 +88,7 @@ instance
Dec-DelegateOrDeReg : DelegateOrDeReg ⁇¹
Dec-DelegateOrDeReg {dc} .dec with dc
... | delegate _ _ _ _ = yes it
... | reg _ _ = yes it
... | dereg _ _ = yes it
... | regdrep _ _ _ = yes it
... | deregdrep _ _ = yes it
Expand Down Expand Up @@ -125,6 +127,8 @@ certScripts d with ¿ DelegateOrDeReg d ¿
... | no ¬p = nothing
certScripts c@(delegate (KeyHashObj x) _ _ _) | yes p = nothing
certScripts c@(delegate (ScriptObj y) _ _ _) | yes p = just (Cert c , y)
certScripts c@(reg (KeyHashObj x) _) | yes p = nothing
certScripts c@(reg (ScriptObj y) _) | yes p = just (Cert c , y)
certScripts c@(dereg (KeyHashObj x) _) | yes p = nothing
certScripts c@(dereg (ScriptObj y) _) | yes p = just (Cert c , y)
certScripts c@(regdrep (KeyHashObj x) _ _) | yes p = nothing
Expand Down
5 changes: 5 additions & 0 deletions src/Ledger/Utxo.lagda
Original file line number Diff line number Diff line change
Expand Up @@ -245,6 +245,9 @@ data ValidCertDeposits (pp : PParams) (deps : Deposits) : List DCert → Set
regdrep : ∀ {c v a certs}
→ ValidCertDeposits pp (deps ∪⁺ ❴ DRepDeposit c , v ❵) certs
→ ValidCertDeposits pp deps (regdrep c v a ∷ certs)
reg : ∀ {c v certs}
→ ValidCertDeposits pp (deps ∪⁺ ❴ CredentialDeposit c , v ❵) certs
→ ValidCertDeposits pp deps (reg c v ∷ certs)
dereg : ∀ {c d certs}
→ (CredentialDeposit c , d) ∈ deps
→ ValidCertDeposits pp (deps ∣ ❴ CredentialDeposit c ❵ ᶜ) certs
Expand Down Expand Up @@ -273,6 +276,8 @@ private
mapDec retirepool (λ where (retirepool p) → p) (validCertDeposits? _ _)
validCertDeposits? deps (ccreghot _ _ ∷ certs) =
mapDec ccreghot (λ where (ccreghot p) → p) (validCertDeposits? _ _)
validCertDeposits? deps (reg _ _ ∷ certs) =
mapDec reg (λ where (reg p) → p) (validCertDeposits? _ _)
validCertDeposits? deps (dereg c d ∷ certs) with ¿ (CredentialDeposit c , d) ∈ deps ¿
... | yes p = mapDec (dereg p) (λ where (dereg _ d) → d) (validCertDeposits? _ _)
... | no ¬p = no (λ where (dereg p _) → ¬p p)
Expand Down
2 changes: 1 addition & 1 deletion src/Ledger/Utxow.lagda
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ credsNeeded : UTxO → TxBody → ℙ (ScriptPurpose × Credential)
credsNeeded utxo txb
= mapˢ (λ (i , o) → (Spend i , payCred (proj₁ o))) ((utxo ∣ txins) ˢ)
∪ mapˢ (λ a → (Rwrd a , stake a)) (dom (txwdrls .proj₁))
mapˢ (λ c → (Cert c , cwitness c)) (fromList txcerts)
mapPartial (λ c → (Cert c ,_) <$> cwitness c) (fromList txcerts)
∪ mapˢ (λ x → (Mint x , ScriptObj x)) (policies mint)
∪ mapˢ (λ v → (Vote v , proj₂ v)) (fromList (map voter txvote))
∪ mapPartial (λ p → case p .policy of
Expand Down

0 comments on commit d61a6c9

Please sign in to comment.