Advertisement
and_cesbo

triple_des_set_key (partial)

Apr 10th, 2024
697
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Go 2.54 KB | Cybersecurity | 0 0
  1. func desSetOddParity(key []byte) {
  2.     kOddParity := []byte{
  3.         1, 1, 2, 2, 4, 4, 7, 7, 8, 8, 11, 11, 13, 13, 14,
  4.         14, 16, 16, 19, 19, 21, 21, 22, 22, 25, 25, 26, 26, 28, 28,
  5.         31, 31, 32, 32, 35, 35, 37, 37, 38, 38, 41, 41, 42, 42, 44,
  6.         44, 47, 47, 49, 49, 50, 50, 52, 52, 55, 55, 56, 56, 59, 59,
  7.         61, 61, 62, 62, 64, 64, 67, 67, 69, 69, 70, 70, 73, 73, 74,
  8.         74, 76, 76, 79, 79, 81, 81, 82, 82, 84, 84, 87, 87, 88, 88,
  9.         91, 91, 93, 93, 94, 94, 97, 97, 98, 98, 100, 100, 103, 103, 104,
  10.         104, 107, 107, 109, 109, 110, 110, 112, 112, 115, 115, 117, 117, 118, 118,
  11.         121, 121, 122, 122, 124, 124, 127, 127, 128, 128, 131, 131, 133, 133, 134,
  12.         134, 137, 137, 138, 138, 140, 140, 143, 143, 145, 145, 146, 146, 148, 148,
  13.         151, 151, 152, 152, 155, 155, 157, 157, 158, 158, 161, 161, 162, 162, 164,
  14.         164, 167, 167, 168, 168, 171, 171, 173, 173, 174, 174, 176, 176, 179, 179,
  15.         181, 181, 182, 182, 185, 185, 186, 186, 188, 188, 191, 191, 193, 193, 194,
  16.         194, 196, 196, 199, 199, 200, 200, 203, 203, 205, 205, 206, 206, 208, 208,
  17.         211, 211, 213, 213, 214, 214, 217, 217, 218, 218, 220, 220, 223, 223, 224,
  18.         224, 227, 227, 229, 229, 230, 230, 233, 233, 234, 234, 236, 236, 239, 239,
  19.         241, 241, 242, 242, 244, 244, 247, 247, 248, 248, 251, 251, 253, 253, 254,
  20.         254,
  21.     }
  22.  
  23.     for i := 0; i < len(key); i++ {
  24.         key[i] = kOddParity[key[i]]
  25.     }
  26. }
  27.  
  28. func TripleDesSchedule(deskey []byte, key []byte) []byte {
  29.     if len(deskey) != 14 {
  30.         panic("deskey must be 14 bytes")
  31.     }
  32.  
  33.     tmp := make([]byte, 14)
  34.     copy(tmp, deskey[:])
  35.  
  36.     for i := 0; i < len(key); i++ {
  37.         tmp[(i % len(tmp))] ^= key[i]
  38.     }
  39.  
  40.     tripleDesKey := make([]byte, 16)
  41.     tripleDesKey[0] = tmp[0] & 0xfe
  42.     tripleDesKey[1] = ((tmp[0] << 7) | (tmp[1] >> 1)) & 0xfe
  43.     tripleDesKey[2] = ((tmp[1] << 6) | (tmp[2] >> 2)) & 0xfe
  44.     tripleDesKey[3] = ((tmp[2] << 5) | (tmp[3] >> 3)) & 0xfe
  45.     tripleDesKey[4] = ((tmp[3] << 4) | (tmp[4] >> 4)) & 0xfe
  46.     tripleDesKey[5] = ((tmp[4] << 3) | (tmp[5] >> 5)) & 0xfe
  47.     tripleDesKey[6] = ((tmp[5] << 2) | (tmp[6] >> 6)) & 0xfe
  48.     tripleDesKey[7] = tmp[6] << 1
  49.     tripleDesKey[8] = tmp[7] & 0xfe
  50.     tripleDesKey[9] = ((tmp[7] << 7) | (tmp[8] >> 1)) & 0xfe
  51.     tripleDesKey[10] = ((tmp[8] << 6) | (tmp[9] >> 2)) & 0xfe
  52.     tripleDesKey[11] = ((tmp[9] << 5) | (tmp[10] >> 3)) & 0xfe
  53.     tripleDesKey[12] = ((tmp[10] << 4) | (tmp[11] >> 4)) & 0xfe
  54.     tripleDesKey[13] = ((tmp[11] << 3) | (tmp[12] >> 5)) & 0xfe
  55.     tripleDesKey[14] = ((tmp[12] << 2) | (tmp[13] >> 6)) & 0xfe
  56.     tripleDesKey[15] = tmp[13] << 1
  57.  
  58.     desSetOddParity(tripleDesKey[:8])
  59.     desSetOddParity(tripleDesKey[8:])
  60.  
  61.     return tripleDesKey
  62. }
  63.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement