eni

EnigmaKit

Enigma encryption in Swift

Showing:

Popularity

Downloads/wk

0

GitHub Stars

108

Maintenance

Last Commit

2yrs ago

Contributors

0

Package

Dependencies

0

License

MIT

Categories

Readme

𝕰𝖓𝖎𝖌𝖒𝖆𝕶𝖎𝖙

CI Status Version License Platform Alt text

𝖀𝖘𝖆𝖌𝖊

// Will create an Enigma with an empty plugboard, rotors I, II, III and reflector B (wide).
let enigma = Enigma()
// Will output "ILBDA AMTAZ"
let result = enigma.encode("HELLO WORLD")
let enigma = Enigma()
// "HELLO WORLD"
let result = enigma.encode("ILBDA AMTAZ")

𝕮𝖔𝖒𝖕𝖔𝖓𝖊𝖓𝖙𝖘

𝕻𝖑𝖚𝖌𝖇𝖔𝖆𝖗𝖉

// Create a plugboard and add a patch between A and D
let plugboard = Plugboard()
plugboard.add(("A", "D"))

𝕽𝖔𝖙𝖔𝖗

// III rotor. EnigmaKit comes prebuilt with rotors I-VIII
let rotor = Rotor.III
rotor.setting = 5 // Ringstellung
rotor.position = 6 // Grundstellung

// Or initialize your own
let rotor = Rotor(name: "My custom rotor", wiring: "VZBRGITYUPSDNHLXAWMJQOFECK", notch: "QV")

𝕽𝖊𝖋𝖑𝖊𝖈𝖙𝖔𝖗

// EnigmaKit comes with reflectors A-C (wide) and B-C (thin)
let reflector = Reflector.B

// Or you can create your own reflector
let reflector = Reflector(name: "My custom reflector", wiring: "VZBRGITYUPSDNHLXAWMJQOFECK")

𝕰𝖓𝖎𝖌𝖒𝖆

// Create an enigma with your own plugboard, rotors and reflector of choice
let enigma = Enigma(reflector: Reflector.C, rotors: [Rotor.III, Rotor.IV, Rotor.II], plugboard: Plugboard())

𝕽𝖊𝖖𝖚𝖎𝖗𝖊𝖒𝖊𝖓𝖙𝖘

Don't mention the war

𝕴𝖓𝖘𝖙𝖆𝖑𝖑𝖆𝖙𝖎𝖔𝖓

EnigmaKit is available through Swift Package Manager, CocoaPods.

𝕬𝖚𝖙𝖍𝖔𝖗

Joakim Gyllström, joakim@backslashed.se

𝕷𝖎𝖈𝖊𝖓𝖘𝖊

EnigmaKit is available under the MIT license. See the LICENSE file for more info.

Rate & Review

Great Documentation0
Easy to Use0
Performant0
Highly Customizable0
Bleeding Edge0
Responsive Maintainers0
Poor Documentation0
Hard to Use0
Slow0
Buggy0
Abandoned0
Unwelcoming Community0
100