import { Crypto1State } from "./state";
/**
 * Rollback the shift register in order to get previous states (for bits)
 * @param s State
 * @param input Input bit
 * @param isEncrypted Is input bit encrypted?
 * @returns {number} LFSR output bit
 */
export declare const lfsr_rollback_bit: (s: Crypto1State, input: number, isEncrypted?: boolean) => number;
/**
 * Rollback the shift register in order to get previous states (for bytes)
 * @param s State
 * @param input Input byte
 * @param isEncrypted Is input byte encrypted?
 * @returns {number} LFSR output byte
 */
export declare const lfsr_rollback_byte: (s: Crypto1State, input: number, isEncrypted?: boolean) => number;
/**
 * Rollback the shift register in order to get previous states (for words (uint32))
 * @param s State
 * @param input Input word
 * @param isEncrypted Is input word encrypted?
 * @returns {number} LFSR output word
 */
export declare const lfsr_rollback_word: (s: Crypto1State, input: number, isEncrypted?: boolean) => number;
/**
 * Recovery possible states from keystream from two's partial auth's
 * @param ks2 Keystream (32 -> 63)
 * @param input Value that was fed into lfsr at time keystream was generated
 * @returns {Crypto1State[]}
 */
export declare const lfsr_recovery32: (ks2: number, input: number) => Crypto1State[];
/**
 * Recovery possible states from keystreams from one full auth
 * @param ks2 Keystream (32 -> 63)
 * @param ks3 Keystream (64 -> 95)
 * @returns {Crypto1State[]}
 */
export declare const lfsr_recovery64: (ks2: number, ks3: number) => Crypto1State[];
/**
 * Recovery by two sets of 32 bit keystream authentication
 * @param uid UID
 * @param chal Tag challenge #1 (aka `nt`)
 * @param rchal Reader challenge #1 (aka `{nr_0}`)
 * @param rresp Reader response #1 (aka `{ar_0}`)
 * @param chal2 Tag challenge #2 (aka `nt1`)
 * @param rchal2 Reader challenge #2 (aka `{nr_1}`)
 * @param rresp2 Reader response #2 (aka `{ar_1}`)
 * @returns {bigint}
 */
export declare const recovery32: (uid: number, chal: number, rchal: number, rresp: number, chal2: number, rchal2: number, rresp2: number) => bigint;
/**
 * Recovery by one set of full 64 bit keystream authentication
 * @param uid UID
 * @param chal Tag challenge (aka `nt`)
 * @param rchal Reader challenge (aka `{nr}`)
 * @param rresp Reader response (aka `{ar}`)
 * @param tresp Tag response (aka `{at}`)
 * @returns {bigint}
 */
export declare const recovery64: (uid: number, chal: number, rchal: number, rresp: number, tresp: number) => bigint;
/**
 * Recovery by partial nested authentication
 *
 * @author doegox
 * @param uid UID
 * @param chal Tag challenge (aka `nt`)
 * @param enc_chal Encrypted tag challenge (aka `{nt}`)
 * @param rchal Reader challenge (aka `{nr}`)
 * @param rresp Reader response (aka `{ar}`)
 * @returns {bigint}
 */
export declare const recoveryNested: (uid: number, chal: number, enc_chal: number, rchal: number, rresp: number) => bigint;
