Merge pull request 'add makefile and some minor fixes :3' (#1) from afiw/kissy:mistress into mistress
This commit is contained in:
commit
1b43cf2487
4 changed files with 28 additions and 6 deletions
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
/kissy
|
||||||
19
Makefile
Normal file
19
Makefile
Normal file
|
|
@ -0,0 +1,19 @@
|
||||||
|
CC := gcc
|
||||||
|
CFLAGS := -O2 -pipe -Wall -Wextra
|
||||||
|
INSTALL := install
|
||||||
|
PREFIX := /usr/local
|
||||||
|
BINDIR := bin
|
||||||
|
|
||||||
|
.PHONY: all
|
||||||
|
all: kissy
|
||||||
|
|
||||||
|
kissy: kissy.c
|
||||||
|
$(CC) $(CFLAGS) -o kissy kissy.c
|
||||||
|
|
||||||
|
.PHONY: install
|
||||||
|
install:
|
||||||
|
$(INSTALL) -Dm2755 -oroot -gtty -s kissy $(DESTDIR)$(PREFIX)/$(BINDIR)/kissy
|
||||||
|
|
||||||
|
.PHONY: clean
|
||||||
|
clean:
|
||||||
|
rm -f kissy
|
||||||
|
|
@ -7,6 +7,8 @@ Ever wanted to kiss girls through a tty? Well now you can!
|
||||||
- run `sudo chown root:tty /path/to/kissy` (or whatever ownership it's supposed to have)
|
- run `sudo chown root:tty /path/to/kissy` (or whatever ownership it's supposed to have)
|
||||||
- run `sudo chmod 2755 /path/to/kissy` (or whatever permissions work for you. has to run with setgid)
|
- run `sudo chmod 2755 /path/to/kissy` (or whatever permissions work for you. has to run with setgid)
|
||||||
|
|
||||||
|
- alternatively, build kissy from source using `make` then `sudo make install`
|
||||||
|
|
||||||
### Usage:
|
### Usage:
|
||||||
`kissy [target] <message>`
|
`kissy [target] <message>`
|
||||||
|
|
||||||
|
|
@ -18,4 +20,4 @@ Have fun girlkissing! :3
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
This project is licensed with [GPLv3](https://www.gnu.org/licenses/gpl-3.0.txt)
|
This project is licensed with [GPLv3](https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||||
|
|
|
||||||
10
kissy.c
10
kissy.c
|
|
@ -53,7 +53,7 @@ int main (int argc, char **argv) {
|
||||||
printf("%s\n", "Cannot find target");
|
printf("%s\n", "Cannot find target");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
int target = pw->pw_uid;
|
uid_t target = pw->pw_uid;
|
||||||
|
|
||||||
// get current username
|
// get current username
|
||||||
struct passwd *pw2 = getpwuid(getuid());
|
struct passwd *pw2 = getpwuid(getuid());
|
||||||
|
|
@ -74,7 +74,7 @@ int main (int argc, char **argv) {
|
||||||
// iterate over all files in directory
|
// iterate over all files in directory
|
||||||
DIR *dir = opendir("/dev/pts");
|
DIR *dir = opendir("/dev/pts");
|
||||||
while (1) {
|
while (1) {
|
||||||
struct dirent *ent = readdir (dir);
|
struct dirent *ent = readdir(dir);
|
||||||
if (ent == NULL)
|
if (ent == NULL)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
@ -90,7 +90,7 @@ int main (int argc, char **argv) {
|
||||||
kissed = true;
|
kissed = true;
|
||||||
|
|
||||||
if (stats.st_gid != getegid()) { // are we running as the tty user?
|
if (stats.st_gid != getegid()) { // are we running as the tty user?
|
||||||
printf("%s\n", "Mismatch between file owner group and current effective group. Make sure this program is running with setgid.");
|
fprintf(stderr, "%s\n", "Mismatch between file owner group and current effective group. Make sure this program is running with setgid.");
|
||||||
} else {
|
} else {
|
||||||
FILE *tty = fopen(filepath, "a"); // write to terminal!
|
FILE *tty = fopen(filepath, "a"); // write to terminal!
|
||||||
fprintf(tty, "\n%s\n--%s\n", kiss, user);
|
fprintf(tty, "\n%s\n--%s\n", kiss, user);
|
||||||
|
|
@ -101,5 +101,5 @@ int main (int argc, char **argv) {
|
||||||
|
|
||||||
// print a message if a suitable terminal couldn't be found
|
// print a message if a suitable terminal couldn't be found
|
||||||
if (!kissed)
|
if (!kissed)
|
||||||
printf("%s\n", "Couldn't find any suitable terminals. User is not logged in or has not enabled messages.");
|
fprintf(stderr, "%s\n", "Couldn't find any suitable terminals. User is not logged in or has not enabled messages.");
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue