1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
| /**
| * @param {string} value
| * @returns {RegExp}
| * */
|
| /**
| * @param {RegExp | string } re
| * @returns {string}
| */
| function source(re) {
| if (!re) return null;
| if (typeof re === "string") return re;
|
| return re.source;
| }
|
| /**
| * @param {...(RegExp | string) } args
| * @returns {string}
| */
| function concat(...args) {
| const joined = args.map((x) => source(x)).join("");
| return joined;
| }
|
| /**
| * Any of the passed expresssions may match
| *
| * Creates a huge this | this | that | that match
| * @param {(RegExp | string)[] } args
| * @returns {string}
| */
| function either(...args) {
| const joined = '(' + args.map((x) => source(x)).join("|") + ")";
| return joined;
| }
|
| /*
| Language: Apache Access Log
| Author: Oleg Efimov <efimovov@gmail.com>
| Description: Apache/Nginx Access Logs
| Website: https://httpd.apache.org/docs/2.4/logs.html#accesslog
| Audit: 2020
| */
|
| /** @type LanguageFn */
| function accesslog(_hljs) {
| // https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods
| const HTTP_VERBS = [
| "GET",
| "POST",
| "HEAD",
| "PUT",
| "DELETE",
| "CONNECT",
| "OPTIONS",
| "PATCH",
| "TRACE"
| ];
| return {
| name: 'Apache Access Log',
| contains: [
| // IP
| {
| className: 'number',
| begin: /^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}(:\d{1,5})?\b/,
| relevance: 5
| },
| // Other numbers
| {
| className: 'number',
| begin: /\b\d+\b/,
| relevance: 0
| },
| // Requests
| {
| className: 'string',
| begin: concat(/"/, either(...HTTP_VERBS)),
| end: /"/,
| keywords: HTTP_VERBS,
| illegal: /\n/,
| relevance: 5,
| contains: [
| {
| begin: /HTTP\/[12]\.\d'/,
| relevance: 5
| }
| ]
| },
| // Dates
| {
| className: 'string',
| // dates must have a certain length, this prevents matching
| // simple array accesses a[123] and [] and other common patterns
| // found in other languages
| begin: /\[\d[^\]\n]{8,}\]/,
| illegal: /\n/,
| relevance: 1
| },
| {
| className: 'string',
| begin: /\[/,
| end: /\]/,
| illegal: /\n/,
| relevance: 0
| },
| // User agent / relevance boost
| {
| className: 'string',
| begin: /"Mozilla\/\d\.\d \(/,
| end: /"/,
| illegal: /\n/,
| relevance: 3
| },
| // Strings
| {
| className: 'string',
| begin: /"/,
| end: /"/,
| illegal: /\n/,
| relevance: 0
| }
| ]
| };
| }
|
| module.exports = accesslog;
|
|