aboutsummaryrefslogtreecommitdiff
path: root/src/lib/connection_close.c
blob: 39045e9f15b5ebd787cc7cd04320f02d37df9e54 (plain) (blame)
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
103
104
/*
  This file is part of libmicrohttpd
  Copyright (C) 2007-2018 Daniel Pittman and Christian Grothoff

  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Lesser General Public
  License as published by the Free Software Foundation; either
  version 2.1 of the License, or (at your option) any later version.

  This library 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
  Lesser General Public License for more details.

  You should have received a copy of the GNU Lesser General Public
  License along with this library; if not, write to the Free Software
  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
*/
/**
 * @file lib/connection_close.c
 * @brief functions to close a connection
 * @author Christian Grothoff
 */
#include "internal.h"
#include "connection_close.h"


/**
 * Mark connection as "closed".
 *
 * @remark To be called from any thread.
 *
 * @param connection connection to close
 */
void
MHD_connection_mark_closed_ (struct MHD_Connection *connection)
{
  const struct MHD_Daemon *daemon = connection->daemon;

  connection->request.state = MHD_REQUEST_CLOSED;
  connection->request.event_loop_info = MHD_EVENT_LOOP_INFO_CLEANUP;
  if (! daemon->enable_turbo) 
    {
#ifdef HTTPS_SUPPORT
      struct MHD_TLS_Plugin *tls;
      
      /* For TLS connection use shutdown of TLS layer
       * and do not shutdown TCP socket. This give more
       * chances to send TLS closure data to remote side.
       * Closure of TLS layer will be interpreted by
       * remote side as end of transmission. */
      if (NULL != (tls = daemon->tls_api))
        {
          if (MHD_YES !=
	      tls->shutdown_connection (tls->cls,
					connection->tls_cs))
	    {
	      (void) shutdown (connection->socket_fd,
			       SHUT_WR);
	      /* FIXME: log errors */
	    }
        }
      else /* Combined with next 'shutdown()'. */
#endif /* HTTPS_SUPPORT */
	{
	  (void) shutdown (connection->socket_fd,
			   SHUT_WR); /* FIXME: log errors */
	}
    }
}


/**
 * Close the given connection and give the specified termination code
 * to the user.
 *
 * @remark To be called only from thread that process
 * connection's recv(), send() and response.
 *
 * @param connection connection to close
 * @param cnc termination reason to give
 */
void
MHD_connection_close_ (struct MHD_Connection *connection,
                       enum MHD_ConnectionNotificationCode cnc)
{
  struct MHD_Daemon *daemon = connection->daemon;
  struct MHD_Response *resp = connection->request.response;

  MHD_connection_mark_closed_ (connection);
  if (NULL != resp)
    {
      connection->request.response = NULL;
      MHD_response_queue_for_destroy (resp);
    }
  if ( (NULL != daemon->notify_connection_cb) &&
       (connection->client_aware) )
    daemon->notify_connection_cb (daemon->notify_connection_cb_cls,
				  connection,
				  cnc);
  connection->client_aware = false;
}

/* end of connection_close.c */