OpenVAS Scanner 23.32.3
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
15void
16smb_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
46void
47smb_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}
void smb_arc4_crypt_ntlmssp(unsigned char arc4_state_inout[258], unsigned char *data, size_t len)
Definition arc4.c:47
void smb_arc4_init_ntlmssp(unsigned char arc4_state_out[258], const unsigned char *key, size_t keylen)
Definition arc4.c:16
uint8_t len