summaryrefslogtreecommitdiffstats
path: root/sesman/sesman.c
diff options
context:
space:
mode:
Diffstat (limited to 'sesman/sesman.c')
-rw-r--r--sesman/sesman.c50
1 files changed, 37 insertions, 13 deletions
diff --git a/sesman/sesman.c b/sesman/sesman.c
index d18096bb..a4d5d8d1 100644
--- a/sesman/sesman.c
+++ b/sesman/sesman.c
@@ -32,6 +32,9 @@
#include <netinet/in.h>
#include <netinet/tcp.h>
#include <sys/socket.h>
+#include <sys/stat.h>
+
+#include "d3des.h"
#include <security/pam_userpass.h>
@@ -51,6 +54,8 @@ struct session_item
int bpp;
};
+static unsigned char s_fixedkey[8] = {23, 82, 107, 6, 35, 78, 88, 7};
+
struct session_item session_items[100];
/******************************************************************************/
@@ -189,7 +194,29 @@ int get_next_display(void)
}
/******************************************************************************/
-int start_session(int width, int height, int bpp, char* username)
+int check_password_file(char* filename, char* password)
+{
+ char encryptedPasswd[16];
+ int fd;
+
+ g_memset(encryptedPasswd, 0, 16);
+ g_strncpy(encryptedPasswd, password, 8);
+ rfbDesKey(s_fixedkey, 0);
+ rfbDes(encryptedPasswd, encryptedPasswd);
+ fd = g_file_open(filename);
+ if (fd == 0)
+ {
+ return 1;
+ }
+ g_file_write(fd, encryptedPasswd, 8);
+ g_file_close(fd);
+ chmod(filename, S_IRUSR | S_IWUSR);
+ return 0;
+}
+
+/******************************************************************************/
+int start_session(int width, int height, int bpp, char* username,
+ char* password)
{
int display;
int pid;
@@ -198,6 +225,7 @@ int start_session(int width, int height, int bpp, char* username)
int xpid;
struct passwd* pwd_1;
char text[256];
+ char passwd_file[256];
char geometry[32];
char depth[32];
char screen[32];
@@ -221,6 +249,7 @@ int start_session(int width, int height, int bpp, char* username)
pwd_1 = getpwnam(username);
if (pwd_1 != 0)
{
+ setgid(pwd_1->pw_gid);
uid = pwd_1->pw_uid;
if (setuid(uid) == 0)
{
@@ -238,6 +267,9 @@ int start_session(int width, int height, int bpp, char* username)
g_sprintf(geometry, "%dx%d", width, height);
g_sprintf(depth, "%d", bpp);
g_sprintf(screen, ":%d", display);
+ mkdir(".vnc", S_IRWXU);
+ g_sprintf(passwd_file, "%s/.vnc/.sesman_passwd", pwd_1->pw_dir);
+ check_password_file(passwd_file, password);
wmpid = fork();
if (wmpid == -1)
{
@@ -249,6 +281,7 @@ int start_session(int width, int height, int bpp, char* username)
if (x_server_running(display))
{
execlp("startkde", NULL);
+ //execlp("blackbox", NULL);
// should not get here
}
g_printf("error\n");
@@ -262,17 +295,8 @@ int start_session(int width, int height, int bpp, char* username)
}
else if (xpid == 0) // child
{
- g_sprintf(text, "%s/.vnc/passwd", pwd_1->pw_dir);
- if (access(text, F_OK) == 0)
- {
- execlp("Xvnc", "Xvnc", screen, "-geometry", geometry,
- "-depth", depth, "-bs", "-rfbauth", text, NULL);
- }
- else
- {
- execlp("Xvnc", "Xvnc", screen, "-geometry", geometry,
- "-depth", depth, "-bs", NULL);
- }
+ execlp("Xvnc", "Xvnc", screen, "-geometry", geometry,
+ "-depth", depth, "-bs", "-rfbauth", passwd_file, NULL);
// should not get here
g_printf("error\n");
_exit(0);
@@ -384,7 +408,7 @@ start session\n");
}
else
{
- display = start_session(width, height, bpp, user);
+ display = start_session(width, height, bpp, user, pass);
}
if (display == 0)
{