@li0ard/crapto1_ts
Version:
Crapto1 TypeScript implement
74 lines (73 loc) • 2.94 kB
TypeScript
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;