blob: ee9338e4f5e71f619c1d996c9062bb623ed2e9b9 [file] [log] [blame]
Damien Millerd7834352006-08-05 12:39:39 +10001/* $OpenBSD: session.h,v 1.29 2006/08/03 03:34:42 deraadt Exp $ */
Ben Lindstrom36579d32001-01-29 07:39:26 +00002
Damien Millere4340be2000-09-16 13:29:08 +11003/*
Ben Lindstrom44697232001-07-04 03:32:30 +00004 * Copyright (c) 2000, 2001 Markus Friedl. All rights reserved.
Damien Millere4340be2000-09-16 13:29:08 +11005 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
16 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
17 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
18 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
19 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
20 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
24 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 */
Damien Millerb38eff82000-04-01 11:09:21 +100026#ifndef SESSION_H
27#define SESSION_H
28
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000029#define TTYSZ 64
30typedef struct Session Session;
31struct Session {
32 int used;
33 int self;
34 struct passwd *pw;
35 Authctxt *authctxt;
36 pid_t pid;
Damien Miller1345e612006-03-26 00:06:32 +110037
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000038 /* tty */
39 char *term;
40 int ptyfd, ttyfd, ptymaster;
Ben Lindstroma9d2c892002-06-23 21:48:28 +000041 u_int row, col, xpixel, ypixel;
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000042 char tty[TTYSZ];
Damien Miller1345e612006-03-26 00:06:32 +110043
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000044 /* X11 */
Ben Lindstroma9d2c892002-06-23 21:48:28 +000045 u_int display_number;
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000046 char *display;
Ben Lindstroma9d2c892002-06-23 21:48:28 +000047 u_int screen;
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000048 char *auth_display;
49 char *auth_proto;
50 char *auth_data;
51 int single_connection;
Damien Miller1345e612006-03-26 00:06:32 +110052
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000053 /* proto 2 */
54 int chanid;
Damien Miller2b9b0452005-07-17 17:19:24 +100055 int *x11_chanids;
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000056 int is_subsystem;
Damien Millereccb9de2005-06-17 12:59:34 +100057 u_int num_env;
Darren Tucker46bc0752004-05-02 22:11:30 +100058 struct {
59 char *name;
60 char *val;
Damien Miller1345e612006-03-26 00:06:32 +110061 } *env;
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000062};
63
Ben Lindstrom4cc240d2001-07-04 04:46:56 +000064void do_authenticated(Authctxt *);
Darren Tucker3e33cec2003-10-02 16:12:36 +100065void do_cleanup(Authctxt *);
Damien Millerb38eff82000-04-01 11:09:21 +100066
Ben Lindstroma962c2f2002-07-04 00:14:17 +000067int session_open(Authctxt *, int);
Damien Millerc7ef63d2002-02-05 12:21:42 +110068int session_input_channel_req(Channel *, const char *);
Ben Lindstrom4cc240d2001-07-04 04:46:56 +000069void session_close_by_pid(pid_t, int);
70void session_close_by_channel(int, void *);
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000071void session_destroy_all(void (*)(Session *));
Darren Tucker3e33cec2003-10-02 16:12:36 +100072void session_pty_cleanup2(Session *);
Damien Millerefb4afe2000-04-12 18:45:05 +100073
Ben Lindstrom7a2073c2002-03-22 02:30:41 +000074Session *session_new(void);
75Session *session_by_tty(char *);
76void session_close(Session *);
77void do_setusercontext(struct passwd *);
Darren Tucker0efd1552003-08-26 11:49:55 +100078void child_set_env(char ***envp, u_int *envsizep, const char *name,
79 const char *value);
80
Damien Millerb38eff82000-04-01 11:09:21 +100081#endif