summaryrefslogtreecommitdiffstats
path: root/sesman/scp.c
blob: d26b254b50086ece5188b1d8231b8baa3b8d911f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*
   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2 of the License, or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software
   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

   xrdp: A Remote Desktop Protocol server.
   Copyright (C) Jay Sorg 2005-2008
*/

/**
 *
 * @file scp.c
 * @brief scp (sesman control protocol) common code
 *        scp (sesman control protocol) common code
 *        This code controls which version is being used and starts the
 *        appropriate process
 * @author Jay Sorg, Simone Fedele
 *
 */

#include "sesman.h"

extern int g_thread_sck; /* in thread.c */
extern struct config_sesman g_cfg;

/******************************************************************************/
void* DEFAULT_CC
scp_process_start(void* sck)
{
  struct SCP_CONNECTION scon;
  struct SCP_SESSION* sdata;

  /* making a local copy of the socket (it's on the stack) */
  /* probably this is just paranoia                        */
  scon.in_sck = g_thread_sck;
  LOG_DBG(&(g_cfg.log), "started scp thread on socket %d", scon.in_sck);

  /* unlocking g_thread_sck */
  lock_socket_release();

  make_stream(scon.in_s);
  make_stream(scon.out_s);

  init_stream(scon.in_s, 8192);
  init_stream(scon.out_s, 8192);

  switch (scp_vXs_accept(&scon, &(sdata)))
  {
    case SCP_SERVER_STATE_OK:
      if (sdata->version == 0)
      {
        /* starts processing an scp v0 connection */
        LOG_DBG(&(g_cfg.log), "accept ok, go on with scp v0\n",0);
        scp_v0_process(&scon, sdata);
      }
      else
      {
        LOG_DBG(&(g_cfg.log), "accept ok, go on with scp v1\n",0);
        /*LOG_DBG(&(g_cfg.log), "user: %s\npass: %s",sdata->username, sdata->password);*/
        scp_v1_process(&scon, sdata);
      }
      break;
    case SCP_SERVER_STATE_START_MANAGE:
      /* starting a management session */
      log_message(&(g_cfg.log), LOG_LEVEL_WARNING,
        "starting a sesman management session...");
      scp_v1_mng_process(&scon, sdata);
      break;
    case SCP_SERVER_STATE_VERSION_ERR:
      /* an unknown scp version was requested, so we shut down the */
      /* connection (and log the fact)                             */
      log_message(&(g_cfg.log), LOG_LEVEL_WARNING,
        "unknown protocol version specified. connection refused.");
      break;
    case SCP_SERVER_STATE_NETWORK_ERR:
      log_message(&(g_cfg.log), LOG_LEVEL_WARNING, "libscp network error.");
      break;
    case SCP_SERVER_STATE_SEQUENCE_ERR:
      log_message(&(g_cfg.log), LOG_LEVEL_WARNING, "libscp sequence error.");
      break;
    case SCP_SERVER_STATE_INTERNAL_ERR:
      /* internal error occurred (eg. malloc() error, ecc.) */
      log_message(&(g_cfg.log), LOG_LEVEL_ERROR, "libscp internal error occurred.");
      break;
    default:
      log_message(&(g_cfg.log), LOG_LEVEL_ALWAYS, "unknown return from scp_vXs_accept()");
  }
  g_tcp_close(scon.in_sck);
  free_stream(scon.in_s);
  free_stream(scon.out_s);
  return 0;
}