Line | Count | Source |
1 | | /* Copyright 2026 Google LLC |
2 | | |
3 | | Licensed under the Apache License, Version 2.0 (the "License"); |
4 | | you may not use this file except in compliance with the License. |
5 | | You may obtain a copy of the License at |
6 | | |
7 | | http://www.apache.org/licenses/LICENSE-2.0 |
8 | | |
9 | | Unless required by applicable law or agreed to in writing, software |
10 | | distributed under the License is distributed on an "AS IS" BASIS, |
11 | | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
12 | | See the License for the specific language governing permissions and |
13 | | limitations under the License. |
14 | | */ |
15 | | |
16 | | #include <stdio.h> |
17 | | #include <stdlib.h> |
18 | | #include <stdint.h> |
19 | | #include <string.h> |
20 | | |
21 | | #include "first.h" |
22 | | #include "buffer.h" |
23 | | #include "base64.h" |
24 | | |
25 | 1.40k | int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) { |
26 | 1.40k | if (size < 2) { |
27 | 1 | return 0; |
28 | 1 | } |
29 | | |
30 | 1.40k | uint8_t action = data[0]; |
31 | 1.40k | data++; |
32 | 1.40k | size--; |
33 | | |
34 | 1.40k | buffer *b = buffer_init(); |
35 | 1.40k | buffer_copy_string_len(b, (const char *)data, size); |
36 | | |
37 | 1.40k | switch (action % 12) { |
38 | 162 | case 0: |
39 | 162 | buffer_urldecode_path(b); |
40 | 162 | break; |
41 | 222 | case 1: |
42 | 222 | buffer_path_simplify(b); |
43 | 222 | break; |
44 | 1 | case 2: |
45 | 1 | buffer_is_valid_UTF8(b); |
46 | 1 | break; |
47 | 45 | case 3: |
48 | 45 | buffer_to_lower(b); |
49 | 45 | break; |
50 | 36 | case 4: |
51 | 36 | buffer_to_upper(b); |
52 | 36 | break; |
53 | 44 | case 5: |
54 | 44 | { |
55 | 44 | buffer *dest = buffer_init(); |
56 | 44 | buffer_append_string_encoded(dest, b->ptr, buffer_clen(b), ENCODING_REL_URI); |
57 | 44 | buffer_free(dest); |
58 | 44 | } |
59 | 44 | break; |
60 | 148 | case 6: |
61 | 148 | { |
62 | 148 | buffer *dest = buffer_init(); |
63 | 148 | buffer_append_string_encoded(dest, b->ptr, buffer_clen(b), ENCODING_HTML); |
64 | 148 | buffer_free(dest); |
65 | 148 | } |
66 | 148 | break; |
67 | 135 | case 7: |
68 | 135 | { |
69 | 135 | buffer *dest = buffer_init(); |
70 | 135 | buffer_append_string_c_escaped(dest, b->ptr, buffer_clen(b)); |
71 | 135 | buffer_free(dest); |
72 | 135 | } |
73 | 135 | break; |
74 | 165 | case 8: |
75 | 165 | { |
76 | 165 | buffer *dest = buffer_init(); |
77 | 165 | buffer_append_bs_escaped(dest, b->ptr, buffer_clen(b)); |
78 | 165 | buffer_free(dest); |
79 | 165 | } |
80 | 165 | break; |
81 | 237 | case 9: |
82 | 237 | { |
83 | 237 | buffer *dest = buffer_init(); |
84 | 237 | buffer_append_bs_escaped_json(dest, b->ptr, buffer_clen(b)); |
85 | 237 | buffer_free(dest); |
86 | 237 | } |
87 | 237 | break; |
88 | 80 | case 10: |
89 | 80 | { |
90 | 80 | buffer *dest = buffer_init(); |
91 | 80 | buffer_append_base64_enc(dest, (const unsigned char *)b->ptr, buffer_clen(b), BASE64_STANDARD, 1); |
92 | 80 | buffer_free(dest); |
93 | 80 | } |
94 | 80 | break; |
95 | 132 | case 11: |
96 | 132 | { |
97 | 132 | buffer *dest = buffer_init(); |
98 | 132 | buffer_append_base64_decode(dest, b->ptr, buffer_clen(b), BASE64_STANDARD); |
99 | 132 | buffer_free(dest); |
100 | 132 | } |
101 | 132 | break; |
102 | 1.40k | } |
103 | | |
104 | 1.40k | buffer_free(b); |
105 | | |
106 | 1.40k | return 0; |
107 | 1.40k | } |