Added dvm_file_editor.
It works with qrexec - reads/writes data from stdin/stdout.
This commit is contained in:
parent
9f3fcc862a
commit
7342404846
@ -1,6 +1,8 @@
|
|||||||
CC=gcc
|
CC=gcc
|
||||||
CFLAGS=-Wall
|
CFLAGS=-Wall
|
||||||
all: qubes_penctl qubes_add_pendrive_script qvm-open-in-dvm
|
all: qubes_penctl qubes_add_pendrive_script qvm-open-in-dvm dvm_file_editor
|
||||||
|
dvm_file_editor: dvm_file_editor.o
|
||||||
|
$(CC) -o dvm_file_editor dvm_file_editor.o
|
||||||
qubes_penctl: qubes_penctl.o
|
qubes_penctl: qubes_penctl.o
|
||||||
$(CC) -o qubes_penctl qubes_penctl.o -lxenstore
|
$(CC) -o qubes_penctl qubes_penctl.o -lxenstore
|
||||||
qubes_add_pendrive_script: qubes_add_pendrive_script.o
|
qubes_add_pendrive_script: qubes_add_pendrive_script.o
|
||||||
@ -8,4 +10,4 @@ qubes_add_pendrive_script: qubes_add_pendrive_script.o
|
|||||||
qvm-open-in-dvm: qvm-open-in-dvm.o
|
qvm-open-in-dvm: qvm-open-in-dvm.o
|
||||||
$(CC) -o qvm-open-in-dvm qvm-open-in-dvm.o -lxenstore
|
$(CC) -o qvm-open-in-dvm qvm-open-in-dvm.o -lxenstore
|
||||||
clean:
|
clean:
|
||||||
rm -f qubes_penctl qubes_add_pendrive_script qvm-open-in-dvm *.o *~
|
rm -f dvm_file_editor qubes_penctl qubes_add_pendrive_script qvm-open-in-dvm *.o *~
|
||||||
|
1
appvm/dvm2.h
Normal file
1
appvm/dvm2.h
Normal file
@ -0,0 +1 @@
|
|||||||
|
#define DVM_FILENAME_SIZE 256
|
126
appvm/dvm_file_editor.c
Normal file
126
appvm/dvm_file_editor.c
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
#include <sys/stat.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include "dvm2.h"
|
||||||
|
|
||||||
|
int write_all(int fd, void *buf, int size)
|
||||||
|
{
|
||||||
|
int written = 0;
|
||||||
|
int ret;
|
||||||
|
while (written < size) {
|
||||||
|
ret = write(fd, (char *) buf + written, size - written);
|
||||||
|
if (ret <= 0) {
|
||||||
|
perror("write");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
written += ret;
|
||||||
|
}
|
||||||
|
// fprintf(stderr, "sent %d bytes\n", size);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int read_all(int fd, void *buf, int size)
|
||||||
|
{
|
||||||
|
int got_read = 0;
|
||||||
|
int ret;
|
||||||
|
while (got_read < size) {
|
||||||
|
ret = read(fd, (char *) buf + got_read, size - got_read);
|
||||||
|
if (ret == 0) {
|
||||||
|
fprintf(stderr, "EOF\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (ret < 0) {
|
||||||
|
perror("read");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
got_read += ret;
|
||||||
|
}
|
||||||
|
// fprintf(stderr, "read %d bytes\n", size);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *get_filename()
|
||||||
|
{
|
||||||
|
char buf[DVM_FILENAME_SIZE];
|
||||||
|
static char retname[sizeof(buf) + sizeof("/tmp/")];
|
||||||
|
if (!read_all(0, buf, sizeof(buf)))
|
||||||
|
exit(1);
|
||||||
|
if (index(buf, '/')) {
|
||||||
|
fprintf(stderr, "filename contains /");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
snprintf(retname, sizeof(retname), "/tmp/%s", buf);
|
||||||
|
return retname;
|
||||||
|
}
|
||||||
|
|
||||||
|
void copy_all(int fdout, int fdin)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
char buf[4096];
|
||||||
|
for (;;) {
|
||||||
|
ret = read(fdin, buf, sizeof(buf));
|
||||||
|
if (!ret)
|
||||||
|
break;
|
||||||
|
if (ret < 0) {
|
||||||
|
perror("read");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (!write_all(fdout, buf, ret)) {
|
||||||
|
perror("write");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void copy_file(char *filename)
|
||||||
|
{
|
||||||
|
int fd = open(filename, O_WRONLY | O_CREAT, 0600);
|
||||||
|
if (fd < 0) {
|
||||||
|
perror("open file");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
copy_all(fd, 0);
|
||||||
|
close(fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
void send_file_back(char * filename)
|
||||||
|
{
|
||||||
|
int fd = open(filename, O_RDONLY);
|
||||||
|
if (fd < 0) {
|
||||||
|
perror("open file");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
copy_all(1, fd);
|
||||||
|
close(fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
main()
|
||||||
|
{
|
||||||
|
char cmdbuf[512];
|
||||||
|
struct stat stat_pre, stat_post;
|
||||||
|
char *filename = get_filename();
|
||||||
|
|
||||||
|
copy_file(filename);
|
||||||
|
if (stat(filename, &stat_pre)) {
|
||||||
|
perror("stat pre");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
snprintf(cmdbuf, sizeof(cmdbuf),
|
||||||
|
"HOME=/home/user DISPLAY=:0 /usr/bin/mimeopen -n -M '%s' 2>&1 > /tmp/kde-open.log </dev/null",
|
||||||
|
filename);
|
||||||
|
if (system(cmdbuf))
|
||||||
|
system
|
||||||
|
("HOME=/home/user DISPLAY=:0 /usr/bin/kdialog --sorry 'Unable to handle mimetype of the requested file!'");
|
||||||
|
if (stat(filename, &stat_post)) {
|
||||||
|
perror("stat post");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (stat_pre.st_mtime != stat_post.st_mtime)
|
||||||
|
send_file_back(filename);
|
||||||
|
return 0;
|
||||||
|
}
|
@ -76,6 +76,7 @@ cp qubes_timestamp qvm-copy-to-vm qvm-open-in-dvm $RPM_BUILD_ROOT/usr/bin
|
|||||||
mkdir -p $RPM_BUILD_ROOT/usr/lib/qubes
|
mkdir -p $RPM_BUILD_ROOT/usr/lib/qubes
|
||||||
cp qubes_add_pendrive_script qubes_penctl qvm-copy-to-vm.kde $RPM_BUILD_ROOT/usr/lib/qubes
|
cp qubes_add_pendrive_script qubes_penctl qvm-copy-to-vm.kde $RPM_BUILD_ROOT/usr/lib/qubes
|
||||||
cp ../qrexec/qrexec_agent $RPM_BUILD_ROOT/usr/lib/qubes
|
cp ../qrexec/qrexec_agent $RPM_BUILD_ROOT/usr/lib/qubes
|
||||||
|
cp dvm_file_editor $RPM_BUILD_ROOT/usr/lib/qubes
|
||||||
ln -s /usr/bin/qvm-open-in-dvm $RPM_BUILD_ROOT/usr/lib/qubes/qvm-dvm-transfer
|
ln -s /usr/bin/qvm-open-in-dvm $RPM_BUILD_ROOT/usr/lib/qubes/qvm-dvm-transfer
|
||||||
cp ../common/meminfo-writer $RPM_BUILD_ROOT/usr/lib/qubes
|
cp ../common/meminfo-writer $RPM_BUILD_ROOT/usr/lib/qubes
|
||||||
mkdir -p $RPM_BUILD_ROOT/%{kde_service_dir}
|
mkdir -p $RPM_BUILD_ROOT/%{kde_service_dir}
|
||||||
@ -208,6 +209,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%attr(4755,root,root) /usr/bin/qvm-open-in-dvm
|
%attr(4755,root,root) /usr/bin/qvm-open-in-dvm
|
||||||
/usr/lib/qubes/qvm-dvm-transfer
|
/usr/lib/qubes/qvm-dvm-transfer
|
||||||
/usr/lib/qubes/meminfo-writer
|
/usr/lib/qubes/meminfo-writer
|
||||||
|
/usr/lib/qubes/dvm_file_editor
|
||||||
%{kde_service_dir}/qvm-copy.desktop
|
%{kde_service_dir}/qvm-copy.desktop
|
||||||
%{kde_service_dir}/qvm-dvm.desktop
|
%{kde_service_dir}/qvm-dvm.desktop
|
||||||
%attr(4755,root,root) /usr/lib/qubes/qubes_penctl
|
%attr(4755,root,root) /usr/lib/qubes/qubes_penctl
|
||||||
|
Loading…
Reference in New Issue
Block a user