session-ios/Signal/src/network/rtp/zrtp/ShortAuthenticationStringGe...

92 lines
6.7 KiB
Objective-C

#import "Constraints.h"
#import "ShortAuthenticationStringGenerator.h"
#import "Util.h"
#define MIN_SAS_BYTES 2
const char* PGP_LIST_EVEN[] = {
"aardvark", "absurd", "accrue", "acme", "adrift", "adult", "afflict", "ahead", "aimless",
"Algol", "allow", "alone", "ammo", "ancient", "apple", "artist", "assume", "Athens", "atlas",
"Aztec", "baboon", "backfield", "backward", "banjo", "beaming", "bedlamp", "beehive", "beeswax",
"befriend", "Belfast", "berserk", "billiard", "bison", "blackjack", "blockade", "blowtorch",
"bluebird", "bombast", "bookshelf", "brackish", "breadline", "breakup", "brickyard",
"briefcase", "Burbank", "button", "buzzard", "cement", "chairlift", "chatter", "checkup",
"chisel", "choking", "chopper", "Christmas", "clamshell", "classic", "classroom", "cleanup",
"clockwork", "cobra", "commence", "concert", "cowbell", "crackdown", "cranky", "crowfoot",
"crucial", "crumpled", "crusade", "cubic", "dashboard", "deadbolt", "deckhand", "dogsled",
"dragnet", "drainage", "dreadful", "drifter", "dropper", "drumbeat", "drunken", "Dupont",
"dwelling", "eating", "edict", "egghead", "eightball", "endorse", "endow", "enlist", "erase",
"escape", "exceed", "eyeglass", "eyetooth", "facial", "fallout", "flagpole", "flatfoot",
"flytrap", "fracture", "framework", "freedom", "frighten", "gazelle", "Geiger", "glitter",
"glucose", "goggles", "goldfish", "gremlin", "guidance", "hamlet", "highchair", "hockey",
"indoors", "indulge", "inverse", "involve", "island", "jawbone", "keyboard", "kickoff", "kiwi",
"klaxon", "locale", "lockup", "merit", "minnow", "miser", "Mohawk", "mural", "music",
"necklace", "Neptune", "newborn", "nightbird", "Oakland", "obtuse", "offload", "optic",
"orca", "payday", "peachy", "pheasant", "physique", "playhouse", "Pluto", "preclude", "prefer",
"preshrunk", "printer", "prowler", "pupil", "puppy", "python", "quadrant", "quiver", "quota",
"ragtime", "ratchet", "rebirth", "reform", "regain", "reindeer", "rematch", "repay", "retouch",
"revenge", "reward", "rhythm", "ribcage", "ringbolt", "robust", "rocker", "ruffled", "sailboat",
"sawdust", "scallion", "scenic", "scorecard", "Scotland", "seabird", "select", "sentence",
"shadow", "shamrock", "showgirl", "skullcap", "skydive", "slingshot", "slowdown", "snapline",
"snapshot", "snowcap", "snowslide", "solo", "southward", "soybean", "spaniel", "spearhead",
"spellbind", "spheroid", "spigot", "spindle", "spyglass", "stagehand", "stagnate", "stairway",
"standard", "stapler", "steamship", "sterling", "stockman", "stopwatch", "stormy", "sugar",
"surmount", "suspense", "sweatband", "swelter", "tactics", "talon", "tapeworm", "tempest",
"tiger", "tissue", "tonic", "topmost", "tracker", "transit", "trauma", "treadmill", "Trojan",
"trouble", "tumor", "tunnel", "tycoon", "uncut", "unearth", "unwind", "uproot", "upset",
"upshot", "vapor", "village", "virus", "Vulcan", "waffle", "wallet", "watchword", "wayside",
"willow", "woodlark", "Zulu"};
const char* PGP_LIST_ODD[] = {
"adroitness", "adviser", "aftermath", "aggregate", "alkali", "almighty", "amulet", "amusement",
"antenna", "applicant", "Apollo", "armistice", "article", "asteroid", "Atlantic", "atmosphere",
"autopsy", "Babylon", "backwater", "barbecue", "belowground", "bifocals", "bodyguard",
"bookseller", "borderline", "bottomless", "Bradbury", "bravado", "Brazilian", "breakaway",
"Burlington", "businessman", "butterfat", "Camelot", "candidate", "cannonball", "Capricorn",
"caravan", "caretaker", "celebrate", "cellulose", "certify", "chambermaid", "Cherokee",
"Chicago", "clergyman", "coherence", "combustion", "commando", "company", "component",
"concurrent", "confidence", "conformist", "congregate", "consensus", "consulting", "corporate",
"corrosion", "councilman", "crossover", "crucifix", "cumbersome", "customer", "Dakota",
"decadence", "December", "decimal", "designing", "detector", "detergent", "determine",
"dictator", "dinosaur", "direction", "disable", "disbelief", "disruptive", "distortion",
"document", "embezzle", "enchanting", "enrollment", "enterprise", "equation", "equipment",
"escapade", "Eskimo", "everyday", "examine", "existence", "exodus", "fascinate", "filament",
"finicky", "forever", "fortitude", "frequency", "gadgetry", "Galveston", "getaway", "glossary",
"gossamer", "graduate", "gravity", "guitarist", "hamburger", "Hamilton", "handiwork",
"hazardous", "headwaters", "hemisphere", "hesitate", "hideaway", "holiness", "hurricane",
"hydraulic", "impartial", "impetus", "inception", "indigo", "inertia", "infancy", "inferno",
"informant", "insincere", "insurgent", "integrate", "intention", "inventive", "Istanbul",
"Jamaica", "Jupiter", "leprosy", "letterhead", "liberty", "maritime", "matchmaker", "maverick",
"Medusa", "megaton", "microscope", "microwave", "midsummer", "millionaire", "miracle",
"misnomer", "molasses", "molecule", "Montana", "monument", "mosquito", "narrative", "nebula",
"newsletter", "Norwegian", "October", "Ohio", "onlooker", "opulent", "Orlando", "outfielder",
"Pacific", "pandemic", "Pandora", "paperweight", "paragon", "paragraph", "paramount",
"passenger", "pedigree", "Pegasus", "penetrate", "perceptive", "performance", "pharmacy",
"phonetic", "photograph", "pioneer", "pocketful", "politeness", "positive", "potato",
"processor", "provincial", "proximate", "puberty", "publisher", "pyramid", "quantity",
"racketeer", "rebellion", "recipe", "recover", "repellent", "replica", "reproduce", "resistor",
"responsive", "retraction", "retrieval", "retrospect", "revenue", "revival", "revolver",
"sandalwood", "sardonic", "Saturday", "savagery", "scavenger", "sensation", "sociable",
"souvenir", "specialist", "speculate", "stethoscope", "stupendous", "supportive", "surrender",
"suspicious", "sympathy", "tambourine", "telephone", "therapist", "tobacco", "tolerance",
"tomorrow", "torpedo", "tradition", "travesty", "trombonist", "truncated", "typewriter",
"ultimate", "undaunted", "underfoot", "unicorn", "unify", "universe", "unravel", "upcoming",
"vacancy", "vagabond", "vertigo", "Virginia", "visitor", "vocalist", "voyager", "warranty",
"Waterloo", "whimsical", "Wichita", "Wilmington", "Wyoming", "yesteryear", "Yucatan"};
@implementation ShortAuthenticationStringGenerator
+(NSString*) generateFromData:(NSData*)sasBytes {
require(sasBytes != nil);
require(sasBytes.length >= MIN_SAS_BYTES);
uint8_t wordIndexOne = [sasBytes uint8At:0];
uint8_t wordIndexTwo = [sasBytes uint8At:1];
return [NSString stringWithFormat:@"%@ %@",
@(PGP_LIST_EVEN[wordIndexOne]),
@(PGP_LIST_ODD[wordIndexTwo])];
}
@end