added nicer support for Xrdp
fixed some errors in Makefiles when installing
This commit is contained in:
parent
ebb1afd2e8
commit
ec7498b5f9
4
Makefile
4
Makefile
@ -19,9 +19,11 @@ base:
|
||||
|
||||
nopam: base
|
||||
make -C sesman nopam
|
||||
make -C sesman tools
|
||||
|
||||
kerberos: base
|
||||
make -C sesman kerberos
|
||||
make -C sesman tools
|
||||
|
||||
clean:
|
||||
make -C vnc clean
|
||||
@ -44,6 +46,6 @@ install:
|
||||
make -C sesman install
|
||||
make -C xup install
|
||||
make -C docs install
|
||||
install instfiles/pam.d/sesman /etc/pam.d/sesman
|
||||
if [ -d /etc/pam.d ]; then install instfiles/pam.d/sesman /etc/pam.d/sesman; fi
|
||||
install instfiles/xrdpstart.sh $(DESTDIR)/xrdpstart.sh
|
||||
install instfiles/xrdp_control.sh $(DESTDIR)/xrdp_control.sh
|
||||
|
@ -22,7 +22,11 @@ CC = gcc
|
||||
|
||||
all: pam tools
|
||||
|
||||
nopam: $(SESMANOBJ) verify_user.o
|
||||
nopam: no-pam tools
|
||||
|
||||
kerberos: kerberos-base tools
|
||||
|
||||
no-pam: $(SESMANOBJ) verify_user.o
|
||||
$(CC) $(LDFLAGS) -o sesman $(SESMANOBJ) verify_user.o -ldl -lcrypt
|
||||
|
||||
pam: $(SESMANOBJ) verify_user_pam.o
|
||||
@ -31,7 +35,7 @@ pam: $(SESMANOBJ) verify_user_pam.o
|
||||
pam_userpass: $(SESMANOBJ) verify_user_pam_userpass.o
|
||||
$(CC) $(LDFLAGS) -o sesman $(SESMANOBJ) verify_user_pam_userpass.o -ldl -lpam -lpam_userpass
|
||||
|
||||
kerberos: $(SESMANOBJ) verify_user_kerberos.o
|
||||
kerberos-base: $(SESMANOBJ) verify_user_kerberos.o
|
||||
$(CC) $(LDFLAGS) -o sesman $(SESMANOBJ) verify_user_kerberos.o -ldl -lkrb5
|
||||
|
||||
tools: $(SESRUNOBJ)
|
||||
|
@ -37,7 +37,7 @@ struct session_item g_session_items[100]; /* sesman.h */
|
||||
extern int g_session_count;
|
||||
#endif
|
||||
struct config_sesman g_cfg; /* config.h */
|
||||
int g_server_type = 0; /* Xvnc 0 Xrdp 10 */
|
||||
//int g_server_type = 0; /* Xvnc 0 Xrdp 10 */
|
||||
|
||||
/**
|
||||
*
|
||||
@ -137,7 +137,7 @@ sesman_main_loop()
|
||||
in_uint16_be(in_s, code);
|
||||
if (code == 0 || code == 10) /* check username - password, */
|
||||
{ /* start session */
|
||||
g_server_type = code;
|
||||
//g_server_type = code;
|
||||
in_uint16_be(in_s, i);
|
||||
in_uint8a(in_s, user, i);
|
||||
user[i] = 0;
|
||||
@ -165,8 +165,18 @@ sesman_main_loop()
|
||||
if (1==access_login_allowed(user))
|
||||
{
|
||||
log_message(LOG_LEVEL_INFO, "granted TS access to user %s", user);
|
||||
display = session_start(width, height, bpp, user, pass,
|
||||
data);
|
||||
if (0 == code)
|
||||
{
|
||||
log_message(LOG_LEVEL_INFO, "starting Xvnc session...");
|
||||
display = session_start(width, height, bpp, user, pass,
|
||||
data, SESMAN_SESSION_TYPE_XVNC);
|
||||
}
|
||||
else
|
||||
{
|
||||
log_message(LOG_LEVEL_INFO, "starting Xrdp session...");
|
||||
display = session_start(width, height, bpp, user, pass,
|
||||
data, SESMAN_SESSION_TYPE_XRDP);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -27,7 +27,7 @@
|
||||
|
||||
extern unsigned char g_fixedkey[8];
|
||||
extern struct config_sesman g_cfg; /* config.h */
|
||||
extern int g_server_type;
|
||||
//extern int g_server_type;
|
||||
#ifdef OLDSESSION
|
||||
extern struct session_item g_session_items[100]; /* sesman.h */
|
||||
#else
|
||||
@ -98,7 +98,7 @@ x_server_running(int display)
|
||||
/* returns 0 if error else the display number the session was started on */
|
||||
int DEFAULT_CC
|
||||
session_start(int width, int height, int bpp, char* username, char* password,
|
||||
long data)
|
||||
long data, unsigned char type)
|
||||
{
|
||||
int display;
|
||||
int pid;
|
||||
@ -206,19 +206,24 @@ session_start(int width, int height, int bpp, char* username, char* password,
|
||||
{
|
||||
env_set_user(username, passwd_file, display);
|
||||
env_check_password_file(passwd_file, password);
|
||||
if (g_server_type == 0)
|
||||
if (type == SESMAN_SESSION_TYPE_XVNC)
|
||||
{
|
||||
g_execlp11("Xvnc", "Xvnc", screen, "-geometry", geometry,
|
||||
"-depth", depth, "-bs", "-rfbauth", passwd_file, 0);
|
||||
}
|
||||
else if (g_server_type == 10)
|
||||
else if (type == SESMAN_SESSION_TYPE_XRDP)
|
||||
{
|
||||
g_execlp11("Xrdp", "Xrdp", screen, "-geometry", geometry,
|
||||
"-depth", depth, "-bs", 0, 0, 0);
|
||||
}
|
||||
else
|
||||
{
|
||||
log_message(LOG_LEVEL_ALWAYS, "bad session type - user %s - pid %d", username, g_getpid());
|
||||
g_exit(1);
|
||||
}
|
||||
/* should not get here */
|
||||
log_message(LOG_LEVEL_ALWAYS,"error doing execve for user %s - pid %d",username,g_getpid());
|
||||
g_exit(0);
|
||||
g_exit(1);
|
||||
}
|
||||
else /* parent */
|
||||
{
|
||||
@ -245,8 +250,16 @@ session_start(int width, int height, int bpp, char* username, char* password,
|
||||
g_session_items[display].connect_time=g_time1();
|
||||
g_session_items[display].disconnect_time=(time_t) 0;
|
||||
g_session_items[display].idle_time=(time_t) 0;
|
||||
|
||||
g_session_items[display].type=SESMAN_SESSION_TYPE_XVNC;
|
||||
|
||||
i/*if (type==0)
|
||||
{
|
||||
g_session_items[display].type=SESMAN_SESSION_TYPE_XVNC;
|
||||
}
|
||||
else
|
||||
{
|
||||
g_session_items[display].type=SESMAN_SESSION_TYPE_XRDP;
|
||||
}*/
|
||||
g_session_items[display].type=type;
|
||||
g_session_items[display].status=SESMAN_SESSION_STATUS_ACTIVE;
|
||||
|
||||
g_session_count++;
|
||||
@ -263,7 +276,16 @@ session_start(int width, int height, int bpp, char* username, char* password,
|
||||
temp->item->disconnect_time=(time_t) 0;
|
||||
temp->item->idle_time=(time_t) 0;
|
||||
|
||||
temp->item->type=SESMAN_SESSION_TYPE_XVNC;
|
||||
/* if (type==0)
|
||||
{
|
||||
temp->item->type=SESMAN_SESSION_TYPE_XVNC;
|
||||
}
|
||||
else
|
||||
{
|
||||
temp->item->type=SESMAN_SESSION_TYPE_XRDP;
|
||||
}*/
|
||||
|
||||
temp->item->type=type;
|
||||
temp->item->status=SESMAN_SESSION_STATUS_ACTIVE;
|
||||
|
||||
/*THREAD-FIX lock the chain*/
|
||||
|
@ -86,7 +86,7 @@ session_get_bydata(char* name, int width, int height, int bpp);
|
||||
*/
|
||||
int DEFAULT_CC
|
||||
session_start(int width, int height, int bpp, char* username, char* password,
|
||||
long data);
|
||||
long data, unsigned char type);
|
||||
|
||||
/**
|
||||
*
|
||||
|
Loading…
Reference in New Issue
Block a user