Compare commits
2 Commits
5dff492663
...
8ca44dfab3
Author | SHA1 | Date | |
---|---|---|---|
8ca44dfab3 | |||
1b53a9638e |
18
Makefile
18
Makefile
@ -65,7 +65,7 @@ endif
|
||||
|
||||
default: $(TARGETS)
|
||||
|
||||
.PHONY: clean icfs_test clean-icfs clean-icfs_dialogue
|
||||
.PHONY: clean icfs_test clean-icfs clean-icfs_dialogue install uninstall
|
||||
|
||||
$(BUILD_DIR)/icfs_dialogue:
|
||||
make -C $(SOURCES_DIR)/gui TEST=$(TEST) DEBUG=$(shell realpath $(DEBUG)) SOURCES_DIR=$(shell realpath $(SOURCES_DIR)/gui) BUILD_DIR=$(shell realpath $(BUILD_DIR)) TESTS_DIR=$(shell realpath $(TESTS_DIR))
|
||||
@ -113,3 +113,19 @@ clean-icfs:
|
||||
|
||||
clean-icfs_dialogue:
|
||||
make -C $(SOURCES_DIR)/gui clean SOURCES_DIR=$(shell realpath $(SOURCES_DIR)/gui) BUILD_DIR=$(shell realpath $(BUILD_DIR)) TESTS_DIR=$(shell realpath $(TESTS_DIR))
|
||||
|
||||
install: $(BUILD_DIR)/icfs $(BUILD_DIR)/icfs_dialogue
|
||||
@echo "Install script needs superuser permission to:"
|
||||
@printf "\t1. Move executables to /usr/bin.\n"
|
||||
@printf "\t2. Create \"icfs\" user.\n"
|
||||
@printf "\t3. Set the setuid bit of icfs executable.\n"
|
||||
sudo cp $(BUILD_DIR)/icfs /usr/bin/icfs && sudo cp $(BUILD_DIR)/icfs_dialogue /usr/bin/icfs_dialogue
|
||||
id -u icfs &>/dev/null || sudo useradd --system --user-group icfs
|
||||
sudo chown icfs: /usr/bin/icfs && sudo chmod 4777 /usr/bin/icfs
|
||||
@read -p "Create /etc/icfs directory for permission databases [y/N]: " permd; if [[ $$permd == "y" ]]; then echo "sudo mkdir /etc/icfs && sudo chown :icfs /etc/icfs && sudo chmod g+rw,o= /etc/icfs;"; sudo mkdir /etc/icfs && sudo chown icfs:icfs /etc/icfs && sudo chmod g+rw,o= /etc/icfs; fi
|
||||
|
||||
uninstall:
|
||||
@echo "Install script needs superuser permission to remove executables in /usr/bin"
|
||||
sudo rm -f /usr/bin/icfs /usr/bin/icfs_dialogue
|
||||
@read -p "Remove /etc/icfs directory [y/N]: " permd; if [[ $$permd == "y" ]]; then echo "sudo rm -rf /etc/icfs"; sudo rm -rf /etc/icfs; fi
|
||||
|
||||
|
@ -244,9 +244,15 @@ int interactive_access(const char *filename, struct process_info proc_info,
|
||||
// the user might specify a different file in the dialogue, so we need to
|
||||
// check if it is valid
|
||||
|
||||
while (source_access(response.filename, F_OK)) {
|
||||
while (
|
||||
source_access(response.filename, F_OK) ||
|
||||
!(strncmp(response.filename, filename, strlen(response.filename)) == 0 &&
|
||||
((strlen(response.filename) < strlen(filename) &&
|
||||
response.filename[strlen(response.filename) - 1] == '/') ||
|
||||
(strlen(response.filename) == strlen(filename))))) {
|
||||
// if it is invalid, just ask again.
|
||||
fprintf(stderr, "[ICFS] Filename returned by zenty wasn't correct: %s\n",
|
||||
fprintf(stderr,
|
||||
"[ICFS] Filename returned by access dialogue wasn't correct: %s\n",
|
||||
response.filename);
|
||||
free(response.filename);
|
||||
response = ask_access(filename, proc_info);
|
||||
|
Loading…
x
Reference in New Issue
Block a user