Merge pull request #1018 from solidsnakedev/main
fix: Plutus V3 NoDatum
This commit is contained in:
commit
a1045352d7
|
@ -831,13 +831,13 @@ pub fn find_script(
|
||||||
|
|
||||||
let lookup_datum = |datum: Option<DatumOption>| match datum {
|
let lookup_datum = |datum: Option<DatumOption>| match datum {
|
||||||
Some(DatumOption::Hash(hash)) => match lookup_table.datum.get(&hash) {
|
Some(DatumOption::Hash(hash)) => match lookup_table.datum.get(&hash) {
|
||||||
Some(d) => Ok(d.clone()),
|
Some(d) => Ok(Some(d.clone())),
|
||||||
None => Err(Error::MissingRequiredDatum {
|
None => Err(Error::MissingRequiredDatum {
|
||||||
hash: hash.to_string(),
|
hash: hash.to_string(),
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
Some(DatumOption::Data(data)) => Ok(data.0.clone()),
|
Some(DatumOption::Data(data)) => Ok(Some(data.0.clone())),
|
||||||
_ => Err(Error::MissingRequiredInlineDatumOrHash),
|
None => Ok(None),
|
||||||
};
|
};
|
||||||
|
|
||||||
match redeemer.tag {
|
match redeemer.tag {
|
||||||
|
@ -908,12 +908,16 @@ pub fn find_script(
|
||||||
.and_then(|input| match output_address(&input.resolved) {
|
.and_then(|input| match output_address(&input.resolved) {
|
||||||
Address::Shelley(shelley_address) => {
|
Address::Shelley(shelley_address) => {
|
||||||
let hash = shelley_address.payment().as_hash();
|
let hash = shelley_address.payment().as_hash();
|
||||||
|
let (script, _) = lookup_script(hash)?;
|
||||||
|
let datum = lookup_datum(output_datum(&input.resolved))?;
|
||||||
|
|
||||||
let script = lookup_script(hash);
|
if datum.is_none()
|
||||||
|
&& matches!(script, ScriptVersion::V1(..) | ScriptVersion::V2(..))
|
||||||
|
{
|
||||||
|
return Err(Error::MissingRequiredInlineDatumOrHash);
|
||||||
|
}
|
||||||
|
|
||||||
let datum = lookup_datum(output_datum(&input.resolved));
|
Ok((script, datum))
|
||||||
|
|
||||||
script.and_then(|(script, _)| Ok((script, Some(datum?))))
|
|
||||||
}
|
}
|
||||||
_ => Err(Error::NonScriptStakeCredential),
|
_ => Err(Error::NonScriptStakeCredential),
|
||||||
}),
|
}),
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
[
|
||||||
|
{ 0: h'70{{ simple_spend_no_datum.simple_spend.spend.hash }}'
|
||||||
|
, 1: 1000000000
|
||||||
|
}
|
||||||
|
]
|
|
@ -0,0 +1,33 @@
|
||||||
|
[
|
||||||
|
{ 0:
|
||||||
|
[ [h'0000000000000000000000000000000000000000000000000000000000000000', 0]
|
||||||
|
]
|
||||||
|
|
||||||
|
, 1:
|
||||||
|
[]
|
||||||
|
|
||||||
|
, 2: 42
|
||||||
|
|
||||||
|
, 11: h'FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF'
|
||||||
|
|
||||||
|
, 13:
|
||||||
|
[ [h'0000000000000000000000000000000000000000000000000000000000000000', 0]
|
||||||
|
]
|
||||||
|
|
||||||
|
, 16:
|
||||||
|
[ h'6000000000000000000000000000000000000000000000000000000000', 1000000000
|
||||||
|
]
|
||||||
|
|
||||||
|
, 17: 1
|
||||||
|
},
|
||||||
|
|
||||||
|
{ 5: [[0, 0, 121([]), [1000000, 100000000]]]
|
||||||
|
|
||||||
|
, 7: [h'{{ simple_spend_no_datum.simple_spend.spend.cbor }}']
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
|
true,
|
||||||
|
|
||||||
|
null
|
||||||
|
]
|
|
@ -0,0 +1,49 @@
|
||||||
|
use aiken/collection/dict
|
||||||
|
use cardano/address.{Address, Script}
|
||||||
|
use cardano/assets
|
||||||
|
use cardano/transaction.{Input, NoDatum, Output, OutputReference, Transaction}
|
||||||
|
|
||||||
|
validator simple_spend {
|
||||||
|
spend(
|
||||||
|
datum: Option<Void>,
|
||||||
|
_redeemer: Void,
|
||||||
|
_output_ref: OutputReference,
|
||||||
|
transaction: Transaction,
|
||||||
|
) {
|
||||||
|
expect None = datum
|
||||||
|
|
||||||
|
assert_inputs(transaction.inputs)
|
||||||
|
|
||||||
|
expect [] == dict.to_pairs(transaction.datums)
|
||||||
|
|
||||||
|
True
|
||||||
|
}
|
||||||
|
|
||||||
|
else(_ctx) {
|
||||||
|
fail
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn assert_inputs(inputs: List<Input>) {
|
||||||
|
expect [
|
||||||
|
Input {
|
||||||
|
output_reference: OutputReference { transaction_id, output_index: 0 },
|
||||||
|
output: Output {
|
||||||
|
address,
|
||||||
|
value: resolved_input_value,
|
||||||
|
datum: NoDatum,
|
||||||
|
reference_script: None,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
] = inputs
|
||||||
|
|
||||||
|
expect
|
||||||
|
transaction_id == #"0000000000000000000000000000000000000000000000000000000000000000"
|
||||||
|
|
||||||
|
expect resolved_input_value == assets.from_lovelace(1000000000)
|
||||||
|
|
||||||
|
expect Address { payment_credential: Script(_), stake_credential: None } =
|
||||||
|
address
|
||||||
|
|
||||||
|
Void
|
||||||
|
}
|
Loading…
Reference in New Issue