# Encipher and Decipher nKode ## Customer Policy - max nkode length: 10 - number of keys: 6 - properties per key: 9 - total number of properties: 54 ## Customer Cipher - property key: [40493 16536 22567 8632 16931 48077 38465 62133 61510 60074 30483 15029 32328 35555 12264 4839 56666 52299 23010 54024 11530 38809 33384 9334 53340 25808 36388 7068 48724 2963 19292 41164 31037 24848 7109 29039 26458 18532 7462 19458 51071 45191 60228 22739 41943 36765 29356 35589 3387 28997 31698 23822 30837 4299] - position key: [ 8625 16938 65018 7492 24125 667 1225 54737 47670] --- ## User Cipher - property key: [57486 43228 16207 60359 59029 6255 7588 52492 24710 2551 40990 56898 56863 1051 48892 2945 40292 31660 45216 53538 40537 15451 52595 37467 3706 19342 38794 33132 21407 3639 12679 9190 10068 50771 64668 35246 60714 28831 4623 8674 56989 23715 57671 23914 51409 36438 10577 34976 29440 9581 47915 29410 39979 5656] - passcode key: [21257 32848 55275 58059 52662 31196 41361 14925 10153 11854] - combined position key: [34963 12677 35658 5478 60936 17345 54640 40685 50309] - mask key: [23832 11427 59440 48739 10483 30872 4800 48753 55621 53879] ### Combined Postion Key ```mermaid block-beta columns 2 user_pos["user position key:\n[58068 33848 20979 58547 24202 53969 27574 25558 64861]"] customer_pos["customer position key:\n[ 8625 16938 65018 7492 24125 667 1225 54737 47670]"] space:2 xor(("XOR")):2 user_pos --> xor customer_pos --> xor space:2 comb_pos["combined position key\n[34963 12677 35658 5478 60936 17345 54640 40685 50309]"]:2 xor --> comb_pos ``` ## User Keypad - keypad: - user passcode indices: [22, 34, 45, 43] ## nKode Cipher ### Passcode Hash ```mermaid block-beta columns 2 cprop["customer_property_key\n[40493 16536 22567 8632 16931 48077 38465 62133 61510 60074 30483 15029 32328 35555 12264 4839 56666 52299 23010 54024 11530 38809 33384 9334 53340 25808 36388 7068 48724 2963 19292 41164 31037 24848 7109 29039 26458 18532 7462 19458 51071 45191 60228 22739 41943 36765 29356 35589 3387 28997 31698 23822 30837 4299]"] uprop["user_property_key\n[57486 43228 16207 60359 59029 6255 7588 52492 24710 2551 40990 56898 56863 1051 48892 2945 40292 31660 45216 53538 40537 15451 52595 37467 3706 19342 38794 33132 21407 3639 12679 9190 10068 50771 64668 35246 60714 28831 4623 8674 56989 23715 57671 23914 51409 36438 10577 34976 29440 9581 47915 29410 39979 5656]"] space:2 xor1(("XOR")):2 cprop --> xor1 uprop --> xor1 space:2 prop["combined_property_key\n[62032 50130 36776 54558 8506 61182 6770 6684 21325 58903 51619 53457 24017 10096 25891 36737 43828 60364 23965 63299 43548 43762 63289 61210 16490 21923 14215 6365 4383 48550 62830 53206 5237 2426 49278 33751 21542 2104 49342 42984 62776 19754 59167 25211 60 58461 118 9841 52387 3482 40915 54740 30225 8961]"] xor1 --> prop pass["user_passcode_indices\n[22, 34, 45, 43]"] space:2 sel(("select\nproperties")):2 pass --> sel prop --> sel space:2 passcode["user passcode properties:\n[63289 49278 58461 25211]"]:2 sel --> passcode space:2 pad["zero pad to\nmax nkode length: 10"]:2 passcode -->pad space:2 paddedpasscode["padded passcode:\n[63289 49278 58461 25211 0 0 0 0 0 0]"] pad --> paddedpasscode passkey["passcode key:\n[21257 32848 55275 58059 52662 31196 41361 14925 10153 11854]"] space:2 xor2(("XOR")):2 passkey --> xor2 paddedpasscode --> xor2 space:2 cipheredpass["ciphered passcode:\n[42032 16430 13238 32944 52662 31196 41361 14925 10153 11854]"]:2 xor2 --> cipheredpass space:2 hash(("hash")):2 cipheredpass --> hash space:2 cipheredhashed["hashed ciphered passcode:\n$2b$12$c62ezzyLW3QzUMjYUPSioexdMtSuJKzSM4KLkdKhWIiuNzcxOfT8m"]:2 hash --> cipheredhashed ``` ### Mask Encipher ```mermaid block-beta columns 3 passcode_idx["passcode indices:\n[22, 34, 45, 43]"] comb_pos["combined position key:\n[34963 12677 35658 5478 60936 17345 54640 40685 50309]"] cust_pos["customer position key:\n[ 8625 16938 65018 7492 24125 667 1225 54737 47670]"] space:3 propidx(["Get Position Idx:\nmap each to element mod props_per_key"]) passcode_idx-->propidx space:1 xor1(("XOR")) comb_pos --> xor1 cust_pos --> xor1 space:3 passcode_position_idx["passcode poition indices:\n[4, 7, 0, 7]"] propidx --> passcode_position_idx space:5 pad1(("Pad with\nrandom indices")) passcode_position_idx --> pad1 space:5 posidx["Padded Passcode Position Indices:\n[4, 7, 0, 7, 2, 2, 0, 3, 7, 8]"] pad1 --> posidx space:1 user_pos["user position key:\n[58068 33848 20979 58547 24202 53969 27574 25558 64861]"] xor1 --> user_pos space:4 sel(("select positions")) user_pos --> sel posidx --> sel space:5 passcode_pos["ordered user passcode positions:\n[24202 25558 58068 25558 20979 20979 58068 58547 25558 64861]"] sel --> passcode_pos mask_key["mask key\n[23832 11427 59440 48739 10483 30872 4800 48753 55621 53879]"] space:4 xor2(("XOR")) mask_key --> xor2 passcode_pos --> xor2 space:5 mask["enciphered mask:\n [ 914 20341 2788 56757 30976 10603 61460 23234 47763 12074]"] xor2 --> mask ``` ### Validate nKode ```mermaid block-beta columns 3 selected_keys["selected keys:\n[5, 3, 2, 2]"] login_keypad["login keypad:\nKey 0: [18 19 11 30 40 41 24 52 26] Key 1: [36 1 47 12 49 32 42 25 35] Key 2: [45 46 29 39 13 50 33 43 17] Key 3: [27 37 2 3 31 5 6 34 8] Key 4: [ 9 10 20 21 4 23 15 7 53] Key 5: [ 0 28 38 48 22 14 51 16 44] "] space:4 selectkeys(("select keys")) mask["enciphered mask:\n [ 914 20341 2788 56757 30976 10603 61460 23234 47763 12074]"] mask_key["mask key:\n[23832 11427 59440 48739 10483 30872 4800 48753 55621 53879]"] space:2 xor1(("XOR")) mask --> xor1 mask_key --> xor1 selected_keys --> selectkeys login_keypad --> selectkeys space:3 ordered_keys["ordered keys:\n[[ 0 28 38 48 22 14 51 16 44] [27 37 2 3 31 5 6 34 8] [45 46 29 39 13 50 33 43 17] [45 46 29 39 13 50 33 43 17]]"] user_position_key["user position key:\n[58068 33848 20979 58547 24202 53969 27574 25558 64861]"] passcode_pos["ordered user passcode positions:\n[24202 25558 58068 25558 20979 20979 58068 58547 25558 64861]"] selectkeys --> ordered_keys xor1 --> passcode_pos space:8 get_passcode_idxs(("recover passcode\nposition indices")) user_position_key --> get_passcode_idxs passcode_pos --> get_passcode_idxs space:8 passcode_pos_idxs["padded passcode position indices:\n[4, 7, 0, 7, 2, 2, 0, 3, 7, 8]"] get_passcode_idxs --> passcode_pos_idxs space:3 get_presumed_idxs(("recover passcode\nproperty indices")) ordered_keys --> get_presumed_idxs passcode_pos_idxs --> get_presumed_idxs space:5 passcode_prop_idxs["presumed passcode property indices:\n[22, 34, 45, 43]"] prop["combined_property_key\n[62032 50130 36776 54558 8506 61182 6770 6684 21325 58903 51619 53457 24017 10096 25891 36737 43828 60364 23965 63299 43548 43762 63289 61210 16490 21923 14215 6365 4383 48550 62830 53206 5237 2426 49278 33751 21542 2104 49342 42984 62776 19754 59167 25211 60 58461 118 9841 52387 3482 40915 54740 30225 8961]"] cipheredhashed["hashed ciphered passcode:\n$2b$12$c62ezzyLW3QzUMjYUPSioexdMtSuJKzSM4KLkdKhWIiuNzcxOfT8m"] get_presumed_idxs --> passcode_prop_idxs space:3 sel(("select\nproperties")) passcode_prop_idxs --> sel prop --> sel space:5 passcode_prop["presumed passcode properties:\n[63289 49278 58461 25211]"] sel --> passcode_prop space:5 cipher(("encipher")) passcode_prop --> cipher space:5 cipheredpass["ciphered passcode:\n[42032 16430 13238 32944 52662 31196 41361 14925 10153 11854]"] cipher --> cipheredpass space:7 comp{"compare"} cipheredpass --> comp cipheredhashed --> comp space:5 suc(("success")) comp --"Equal"--> suc ``` ### Renew nKode nKode renewal is a three step process: 1. Renew Customer Properties 2. Renew User Keys 3. Refresh User on Login ```mermaid flowchart subgraph Renew Customer Properties old_prop["`old customer property key:
[ 4830 27406 45287 16089 51119 63121 2006 55056 13259 61408 27069 3731 33742 9067 56287 33792 13904 36960 60733 9825 13381 38569 14922 32065 19984 7725 40973 39345 17024 45969 50409 60464 13089 53033 15586 2681 47372 30887 53937 34314 11173 4489 1624 16145 51437 27147 10535 44753 49059 10487 9464 42806 59962 13593]`"] new_prop["`new customer property key:
[40493 16536 22567 8632 16931 48077 38465 62133 61510 60074 30483 15029 32328 35555 12264 4839 56666 52299 23010 54024 11530 38809 33384 9334 53340 25808 36388 7068 48724 2963 19292 41164 31037 24848 7109 29039 26458 18532 7462 19458 51071 45191 60228 22739 41943 36765 29356 35589 3387 28997 31698 23822 30837 4299]`"] old_pos["`old customer position key:
[27207 46525 55993 61909 45186 37136 48838 64827 14808]`"] new_pos["`new customer position key:
[ 8625 16938 65018 7492 24125 667 1225 54737 47670]`"] xor1(("XOR")) xor2(("XOR")) xor_prop["`xor property key:
[36083 11158 59584 8033 34188 19804 37271 9637 50061 1354 7854 13350 64902 43400 62519 38631 60170 23595 46303 62825 6479 304 47138 22839 40524 31485 11817 33325 64724 47106 36789 19708 18972 44601 10023 31510 56918 12483 53143 51720 60634 41230 60700 26562 27450 58774 23435 9684 45720 22962 24362 64056 37455 9682]`"] xor_pos["`xor position key:
[19446 63383 10051 60561 61119 37771 47631 10474 33774]`"] old_prop --> xor1 new_prop --> xor1 xor1 --> xor_prop old_pos --> xor2 new_pos --> xor2 xor2 --> xor_pos end subgraph Renew User Keys users@{shape: procs, label: "users"} users --> eachuser subgraph eachuser [for each user] subgraph old user keys old_user_pos["`combined position key:
[58068 33848 20979 58547 24202 53969 27574 25558 64861]`"] old_user_prop["`property key:
[57486 43228 16207 60359 59029 6255 7588 52492 24710 2551 40990 56898 56863 1051 48892 2945 40292 31660 45216 53538 40537 15451 52595 37467 3706 19342 38794 33132 21407 3639 12679 9190 10068 50771 64668 35246 60714 28831 4623 8674 56989 23715 57671 23914 51409 36438 10577 34976 29440 9581 47915 29410 39979 5656]`"] old_renew["renew: False"] end xor3(("XOR")) xor4(("XOR")) old_user_pos --> xor3 xor_pos --> xor3 xor3 --> inter_user_pos old_user_prop --> xor4 xor_prop --> xor4 xor4 --> inter_user_prop subgraph inter_user[intermediate user keys] inter_user_pos["`combined position key:
[50021 50706 44041 63991 183 53322 28543 46599 18283]`"] inter_user_prop["`property key:
[27773 33610 55183 62630 25369 21811 35891 59561 41739 3261 48816 60004 9113 44435 19147 40294 30318 10119 1151 9291 34582 15723 30033 52076 36918 12659 47523 833 44875 46645 48690 28442 27976 26730 56251 62136 13180 16476 56728 60394 12871 64941 3163 15016 41963 27584 29402 44404 49560 31967 58369 35034 3684 13258]`"] inter_renew["renew: True"] end end end subgraph Refresh User on Login login["First login post renew"] inter_user --> login subgraph new_user [New User Keys] new_user_pos["`combined position key:
[41920 44706 35397 43292 52009 11204 43818 26002 28955]`"] new_user_prop["`property key:
[50355 56723 59762 39268 44255 59491 12736 62545 3731 51049 48946 10598 23999 55461 35771 20498 38352 13185 17075 30409 22199 3533 32360 12423 10680 48407 6174 11559 44174 8103 37520 52514 30628 49367 7063 8839 30149 1724 51332 64105 26257 48370 17405 42481 4953 43432 15038 37511 62432 22826 16312 39525 13907 33285]`"] new_renew["renew: False"] end login --> new_user end ```