@li0ard/crapto1_ts
Version:
Crapto1 TypeScript implement
49 lines (48 loc) • 2.05 kB
TypeScript
import { Crypto1State } from "./index.js";
/**
* 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
*/
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)
*/
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;
export declare const lfsr_common_prefix: (pfx: number, ar: number, ks: number[], par: number[][], isZeroPar: boolean) => Crypto1State[];