Friday, November 8, 2024

transactions – Can somebody clarify nLockTime?

The locktime is a transaction area that can be utilized to stop a transaction from being included within the blockchain till some level sooner or later.

If each enter’s sequence quantity is about to the utmost 0xffffffff, the locktime on the transaction is inactive. Whatever the locktime worth, the transaction might be included at any peak.
If not less than one sequence quantity within the transaction is 0xfffffffe (MAX-1) or decrease, a transaction’s locktime might be enforced per the next consensus guidelines:

If the locktime is lower than 500,000,000, the locktime is interpreted as a block peak. The locktime defines the best block peak that can’t embrace the transaction¹. The transaction could also be included in any block with a higher block peak than its locktime.

Instance: A transaction¹ has a locktime of 800,000. The transaction is invalid till block 800,000 however could also be included in block 800,001 or any later block.

If the locktime is not less than 500,000,000, the locktime is interpreted as a Unix time (seconds since 00:00:00 UTC on 1 January 1970). A transaction could also be included in a block if the MedianTimePast on the previous block’s timestamp is bigger than the locktime. The MedianTimePast refers back to the median timestamp of the final eleven blocks.

Instance: A transaction¹ has a locktime of 1,702,483,200 (i.e. 2023-12-13T16:00:00). Block 821023 (see desk beneath) is the primary block with a higher timestamp than this locktime, however solely after a block is discovered the place this timestamp is the median component of the newest eleven blocks’ timestamps (together with the brand new block), the transaction could also be included within the following block. The thought of transaction is legitimate for inclusion in block 821029 or later, as block 821023’s timestamp is the median component of the timestamps from blocks 821018 via 821028 (each inclusive).

Peak Timestamp MTP Could embrace Tx
821031 2023-12-13 17:45:16 2023-12-13 17:01:24 sure
821030 2023-12-13 17:35:38 2023-12-13 16:49:14 sure
821029 2023-12-13 17:35:24 2023-12-13 16:19:05 sure
821028 2023-12-13 17:33:46 2023-12-13 16:02:03 no
821027 2023-12-13 17:21:32 2023-12-13 15:56:00 no
821026 2023-12-13 17:01:24 2023-12-13 15:41:28 no
821025 2023-12-13 16:49:14 2023-12-13 15:29:58 no
821024 2023-12-13 16:19:05 2023-12-13 15:24:19 no
821023 2023-12-13 16:02:03 2023-12-13 15:18:50 no
821022 2023-12-13 15:56:00 2023-12-13 15:10:06 no
821021 2023-12-13 15:41:28 2023-12-13 15:04:59 no
821020 2023-12-13 15:29:58 2023-12-13 14:59:44 no
821019 2023-12-13 15:24:19 2023-12-13 14:51:59 no
821018 2023-12-13 15:18:50 2023-12-13 14:28:53 no
821017 2023-12-13 15:10:06 2023-12-13 14:25:51 no
821016 2023-12-13 15:04:59 2023-12-13 14:21:23 no

Since timestamps are solely restricted to being higher than the MTP of the prior block and smaller than 2h into the way forward for the evaluating block’s community time, a sorted sequence of the timestamps might not essentially have the identical order because the corresponding blocks’ heights.


¹A transaction is non-final if the locktime is energetic and never smaller than the present block peak. From Bitcoin Core supply code: src/consensus/tx_verify.cpp:17–37

bool IsFinalTx(const CTransaction &tx, int nBlockHeight, int64_t nBlockTime)
{
    if (tx.nLockTime == 0)
        return true;
    if ((int64_t)tx.nLockTime < ((int64_t)tx.nLockTime < LOCKTIME_THRESHOLD ? (int64_t)nBlockHeight : nBlockTime))
        return true;

    // Even when tx.nLockTime is not happy by nBlockHeight/nBlockTime, a
    // transaction remains to be thought of closing if all inputs' nSequence ==
    // SEQUENCE_FINAL (0xffffffff), through which case nLockTime is ignored.
    //
    // Due to this habits OP_CHECKLOCKTIMEVERIFY/CheckLockTime() will
    // additionally verify that the spending enter's nSequence != SEQUENCE_FINAL,
    // making certain that an unhappy nLockTime worth will truly trigger
    // IsFinalTx() to return false right here:
    for (const auto& txin : tx.vin) {
        if (!(txin.nSequence == CTxIn::SEQUENCE_FINAL))
            return false;
    }
    return true;
}

² As talked about above, the instance transactions should every have not less than one sequence quantity decrease than the utmost, or the locktime wouldn’t be energetic.

Related Articles

LEAVE A REPLY

Please enter your comment!
Please enter your name here

Latest Articles