-
Notifications
You must be signed in to change notification settings - Fork 1
/
wrong8007.c
120 lines (104 loc) · 3.66 KB
/
wrong8007.c
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
/*
* Copyright (c) 2023, Piyush Raj (https://piyushraj.org/)
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of Gibson nor the names of its contributors may be used
* to endorse or promote products derived from this software without
* specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/slab.h>
#include <linux/moduleparam.h>
#include <linux/keyboard.h>
#include <linux/notifier.h>
#include <linux/version.h>
static char *phrase;
static char *exec;
module_param(phrase, charp, S_IRUGO);
module_param(exec, charp, S_IRUGO);
static int matches = 0;
static char *env[] = {
"USER=root",
"HOME=/",
"TERM=linux",
"SHELL=/bin/bash",
"PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin",
NULL
};
static int shell_exec(char *e) {
#ifdef DEBUG
printk(KERN_INFO "executing %s", e);
#endif
matches = 0;
struct subprocess_info *info;
char *argv[] = {"/bin/sh", "-c", e, NULL};
#if LINUX_VERSION_CODE > KERNEL_VERSION(4, 0, 0)
info = call_usermodehelper_setup(argv[0], argv, env, GFP_ATOMIC, NULL, NULL, NULL);
#elif
info = call_usermodehelper_setup(argv[0], argv, env, GFP_ATOMIC);
#endif
if (info == NULL){
#ifdef DEBUG
printk(KERN_ERR "error! *info struct is NULL");
#endif
return -ENOMEM;
}
int ret = call_usermodehelper_exec(info, UMH_NO_WAIT);
#ifdef DEBUG
if (ret != 0)
printk(KERN_INFO "return value: %d", ret);
#endif
return ret;
}
int _kb_call(struct notifier_block *nb, unsigned long code, void *p) {
struct keyboard_notifier_param *params = p;
if (code == KBD_POST_KEYSYM && !params->down) {
char p_char = params->value^0xfb00;
if (p_char == *(phrase+matches)) {
if (++matches == strlen(phrase))
shell_exec(exec);
return NOTIFY_OK;
}else
matches = 0;
}
return NOTIFY_OK;
}
static struct notifier_block nblock = {
.notifier_call = _kb_call
};
static int __init wrong8007_init(void) {
#ifdef DEBUG
printk(KERN_INFO "wrong8007 loaded...");
#endif
if (phrase == NULL || exec == NULL)
return -EINVAL;
register_keyboard_notifier(&nblock);
return 0;
}
static void __exit wrong8007_exit(void) {
unregister_keyboard_notifier(&nblock);
}
module_init( wrong8007_init );
module_exit( wrong8007_exit );
MODULE_LICENSE("GPL");