OpenVAS Scanner  22.7.9
arc4.c
Go to the documentation of this file.
1 /* SPDX-FileCopyrightText: 2023 Greenbone AG
2  * SPDX-FileCopyrightText: 2005 Jeremy Allison
3  *
4  * SPDX-License-Identifier: GPL-2.0-or-later
5  */
6 
7 #include "proto.h"
8 
9 #include <stdlib.h>
10 /*****************************************************************
11  Initialize state for an arc4 crypt/decrpyt.
12  arc4 state is 258 bytes - last 2 bytes are the index bytes.
13 *****************************************************************/
14 
15 void
16 smb_arc4_init_ntlmssp (unsigned char arc4_state_out[258],
17  const unsigned char *key, size_t keylen)
18 {
19  size_t ind;
20  unsigned char j = 0;
21 
22  for (ind = 0; ind < 256; ind++)
23  {
24  arc4_state_out[ind] = (unsigned char) ind;
25  }
26 
27  for (ind = 0; ind < 256; ind++)
28  {
29  unsigned char tc;
30 
31  j += (arc4_state_out[ind] + key[ind % keylen]);
32 
33  tc = arc4_state_out[ind];
34  arc4_state_out[ind] = arc4_state_out[j];
35  arc4_state_out[j] = tc;
36  }
37  arc4_state_out[256] = 0;
38  arc4_state_out[257] = 0;
39 }
40 
41 /*****************************************************************
42  Do the arc4 crypt/decrpyt.
43  arc4 state is 258 bytes - last 2 bytes are the index bytes.
44 *****************************************************************/
45 
46 void
47 smb_arc4_crypt_ntlmssp (unsigned char arc4_state_inout[258],
48  unsigned char *data, size_t len)
49 {
50  unsigned char index_i = arc4_state_inout[256];
51  unsigned char index_j = arc4_state_inout[257];
52  size_t ind;
53 
54  for (ind = 0; ind < len; ind++)
55  {
56  unsigned char tc;
57  unsigned char t;
58 
59  index_i++;
60  index_j += arc4_state_inout[index_i];
61 
62  tc = arc4_state_inout[index_i];
63  arc4_state_inout[index_i] = arc4_state_inout[index_j];
64  arc4_state_inout[index_j] = tc;
65 
66  t = arc4_state_inout[index_i] + arc4_state_inout[index_j];
67  data[ind] = data[ind] ^ arc4_state_inout[t];
68  }
69 
70  arc4_state_inout[256] = index_i;
71  arc4_state_inout[257] = index_j;
72 }
smb_arc4_crypt_ntlmssp
void smb_arc4_crypt_ntlmssp(unsigned char arc4_state_inout[258], unsigned char *data, size_t len)
Definition: arc4.c:47
proto.h
smb_arc4_init_ntlmssp
void smb_arc4_init_ntlmssp(unsigned char arc4_state_out[258], const unsigned char *key, size_t keylen)
Definition: arc4.c:16
len
uint8_t len
Definition: nasl_packet_forgery.c:1