org.ergoplatform.wallet.interpreter
ErgoProvingInterpreter
Companion object ErgoProvingInterpreter
class ErgoProvingInterpreter extends ErgoInterpreter with ProverInterpreter
A class which is holding secrets and signing transactions.
Currently it just generates some number of secrets (the number is provided via "dlogSecretsNumber" setting in the "wallet" section) from a seed and sign a transaction (against input boxes to spend and blockchain state) by using the secrets (no additional inputs, e.g. hash function preimages required in scripts, are supported. Here, signing a transaction means spending proofs generation for all of its input boxes.
- Alphabetic
- By Inheritance
- ErgoProvingInterpreter
- ProverInterpreter
- AttributionCore
- AttributionCommon
- ErgoInterpreter
- ErgoLikeInterpreter
- Interpreter
- ScorexLogging
- StrictLogging
- AnyRef
- Any
- Hide All
- Show All
- Public
- All
Instance Constructors
-
new
ErgoProvingInterpreter(secretKeys: IndexedSeq[ExtendedSecretKey], params: ErgoLikeParameters)(implicit IR: IRContext)
- secretKeys
- secrets in extended form to be used by prover
- params
- ergo network parameters
Type Members
-
type
CTX = ErgoLikeContext
- Definition Classes
- ErgoInterpreter → ErgoLikeInterpreter → Interpreter
-
class
CachedAttribute[T, U] extends Attribute[T, U]
- Definition Classes
- AttributionCore
-
class
CachedDynamicAttribute[T, U] extends CachedAttribute[T, U]
- Definition Classes
- AttributionCore
-
class
CachedParamAttribute[A, T, U] extends (A) ⇒ Attribute[T, U]
- Definition Classes
- AttributionCore
-
class
CircularAttribute[T, U] extends Attribute[T, U]
- Definition Classes
- AttributionCore
-
class
ConstantAttribute[T, U] extends Attribute[T, U]
- Definition Classes
- AttributionCommon
-
class
MutableCell[T] extends AnyRef
- Definition Classes
- Interpreter
-
type
ProofT = UncheckedTree
- Definition Classes
- ProverInterpreter → Interpreter
Value Members
-
final
def
!=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
final
def
##(): Int
- Definition Classes
- AnyRef → Any
-
final
def
==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
implicit
val
IR: IRContext
- Definition Classes
- ErgoLikeInterpreter → Interpreter
-
def
applyDeserializeContext(context: CTX, exp: Value[SType]): (BoolValue, CTX)
- Definition Classes
- Interpreter
-
final
def
asInstanceOf[T0]: T0
- Definition Classes
- Any
-
macro
def
attr[T, U](f: (T) ⇒ U): CachedAttribute[T, U]
- Definition Classes
- AttributionCore
-
def
attrWithName[T, U](name: String, f: (T) ⇒ U): CachedAttribute[T, U]
- Definition Classes
- AttributionCore
-
def
calcResult(context: special.sigma.Context, calcF: sigmastate.eval.IRContext.Ref[(sigmastate.eval.IRContext.Context) ⇒ Any]): SigmaProp
- Definition Classes
- Interpreter
-
def
checkCost(context: CTX, exp: Value[SType], costF: sigmastate.eval.IRContext.Ref[((Int, sigmastate.eval.IRContext.Size[sigmastate.eval.IRContext.Context])) ⇒ Int]): Int
- Definition Classes
- Interpreter
-
def
checkExpiredBox(box: ErgoBox, output: ErgoBoxCandidate, currentHeight: ErgoLikeContext.Height): Boolean
Check that expired box is spent in a proper way
Check that expired box is spent in a proper way
- box
- box being spent
- output
- newly created box
- currentHeight
- current height of the blockchain (at the moment of spending)
- returns
whether the box is spent properly according to the storage fee rule
- Attributes
- protected
- Definition Classes
- ErgoInterpreter
-
macro
def
circular[T, U](init: U)(f: (T) ⇒ U): CircularAttribute[T, U]
- Definition Classes
- AttributionCore
-
def
circularWithName[T, U](name: String, init: U)(f: (T) ⇒ U): CircularAttribute[T, U]
- Definition Classes
- AttributionCore
-
def
clone(): AnyRef
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws( ... ) @native() @HotSpotIntrinsicCandidate()
-
val
computeCommitments: Strategy
- Definition Classes
- Interpreter
-
def
constant[T, U](name: String, u: ⇒ U): Attribute[T, U]
- Definition Classes
- AttributionCommon
-
macro
def
constant[T, U](u: ⇒ U): Attribute[T, U]
- Definition Classes
- AttributionCommon
-
val
convertToUnchecked: (ProofTree) ⇒ UncheckedSigmaTree
- Definition Classes
- ProverInterpreter
-
def
convertToUnproven(sigmaTree: SigmaBoolean): UnprovenTree
- Definition Classes
- ProverInterpreter
-
def
deserializeMeasured(context: CTX, scriptBytes: Array[Byte]): (CTX, Value[SType])
- Definition Classes
- Interpreter
-
macro
def
dynAttr[T, U](f: (T) ⇒ U): CachedDynamicAttribute[T, U]
- Definition Classes
- AttributionCore
-
def
dynAttrWithName[T, U](name: String, f: (T) ⇒ U): CachedDynamicAttribute[T, U]
- Definition Classes
- AttributionCore
-
final
def
eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
def
equals(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
def
extractChallenge(pt: ProofTree): Option[Array[Byte]]
- Definition Classes
- ProverInterpreter
-
final
def
getClass(): Class[_]
- Definition Classes
- AnyRef → Any
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
def
hashCode(): Int
- Definition Classes
- AnyRef → Any
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
implicit
def
internalToDynamicAttribute[T, U](f: (T) ⇒ U): CachedDynamicAttribute[T, U]
- Definition Classes
- AttributionCore
-
final
def
isInstanceOf[T0]: Boolean
- Definition Classes
- Any
-
def
log: Logger
- Attributes
- protected
- Definition Classes
- ScorexLogging
- Annotations
- @inline()
-
val
logger: Logger
- Attributes
- protected
- Definition Classes
- StrictLogging
-
val
markReal: Strategy
- Definition Classes
- ProverInterpreter
-
final
def
ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
final
def
notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
final
def
notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
macro
def
paramAttr[V, T, U](f: (V) ⇒ (T) ⇒ U): CachedParamAttribute[V, T, U]
- Definition Classes
- AttributionCore
-
def
paramAttrWithName[V, T, U](name: String, f: (V) ⇒ (T) ⇒ U): CachedParamAttribute[V, T, U]
- Definition Classes
- AttributionCore
-
val
polishSimulated: Strategy
- Definition Classes
- ProverInterpreter
-
def
propositionFromErgoTree(tree: ErgoTree, ctx: CTX): SigmaPropValue
- Definition Classes
- Interpreter
-
def
prove(env: ScriptEnv, tree: ErgoTree, ctx: CTX, message: Array[Byte]): Try[CostedProverResult]
- Definition Classes
- ProverInterpreter
-
def
prove(exp: ErgoTree, context: CTX, message: Array[Byte]): Try[CostedProverResult]
- Definition Classes
- ProverInterpreter
-
def
prove(unprovenTree: UnprovenTree, message: Array[Byte]): ProofT
- Attributes
- protected
- Definition Classes
- ProverInterpreter
-
val
proving: Strategy
- Definition Classes
- ProverInterpreter
- val pubKeys: IndexedSeq[ProveDlog]
-
def
reduceToCrypto(context: CTX, exp: Value[SType]): Try[ReductionResult]
- Definition Classes
- Interpreter
-
def
reduceToCrypto(context: CTX, env: ScriptEnv, exp: Value[SType]): Try[ReductionResult]
- Definition Classes
- Interpreter
- val secretKeys: IndexedSeq[ExtendedSecretKey]
-
val
secrets: IndexedSeq[DLogProverInput]
- Definition Classes
- ErgoProvingInterpreter → ProverInterpreter
-
def
sign(unsignedTx: UnsignedErgoLikeTransaction, boxesToSpend: IndexedSeq[ErgoBox], dataBoxes: IndexedSeq[ErgoBox], stateContext: ErgoLikeStateContext): Try[ErgoLikeTransaction]
- Note
requires
unsignedTxandboxesToSpendhave the same boxIds in the same order.
-
val
simulateAndCommit: Strategy
- Definition Classes
- ProverInterpreter
-
def
substDeserialize(context: CTX, updateContext: (CTX) ⇒ Unit, node: SValue): Option[SValue]
- Definition Classes
- ErgoLikeInterpreter → Interpreter
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
- Definition Classes
- AnyRef
-
def
toString(): String
- Definition Classes
- AnyRef → Any
-
def
toValidScriptType(exp: SValue): BoolValue
- Definition Classes
- Interpreter
-
def
verify(env: ScriptEnv, exp: ErgoTree, context: CTX, proof: Array[Byte], message: Array[Byte]): Try[VerificationResult]
Checks that given exp evaluates to
true.Checks that given exp evaluates to
true.- env
- environment to use during expression evaluation
- exp
- expression to check
- context
- expression evaluation context
- proof
- cryptographic proof
- message
- message
- Definition Classes
- ErgoInterpreter → Interpreter
-
def
verify(exp: ErgoTree, context: CTX, proof: ErgoProvingInterpreter.ProofT, message: Array[Byte]): Try[VerificationResult]
- Definition Classes
- Interpreter
-
def
verify(env: ScriptEnv, exp: ErgoTree, context: CTX, proverResult: ProverResult, message: Array[Byte]): Try[VerificationResult]
- Definition Classes
- Interpreter
-
def
verify(exp: ErgoTree, context: CTX, proverResult: ProverResult, message: Array[Byte]): Try[VerificationResult]
- Definition Classes
- Interpreter
-
final
def
wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
-
final
def
wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
-
final
def
wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... ) @native()
Deprecated Value Members
-
def
finalize(): Unit
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws( classOf[java.lang.Throwable] ) @Deprecated @deprecated
- Deprecated
(Since version ) see corresponding Javadoc for more information.