Qore Programming Language  1.12.1
QoreSocketObject.h
1 /* -*- mode: c++; indent-tabs-mode: nil -*- */
2 /*
3  QoreSocketObject.h
4 
5  Qore Programming Language
6 
7  Copyright (C) 2003 - 2022 Qore Technologies, s.r.o.
8 
9  provides a thread-safe interface to the QoreSocket object
10 
11  Permission is hereby granted, free of charge, to any person obtaining a
12  copy of this software and associated documentation files (the "Software"),
13  to deal in the Software without restriction, including without limitation
14  the rights to use, copy, modify, merge, publish, distribute, sublicense,
15  and/or sell copies of the Software, and to permit persons to whom the
16  Software is furnished to do so, subject to the following conditions:
17 
18  The above copyright notice and this permission notice shall be included in
19  all copies or substantial portions of the Software.
20 
21  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
24  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
25  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
26  FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
27  DEALINGS IN THE SOFTWARE.
28 
29  Note that the Qore library is released under a choice of three open-source
30  licenses: MIT (as above), LGPL 2+, or GPL 2+; see README-LICENSE for more
31  information.
32 */
33 
34 #ifndef _QORE_QORE_SOCKET_OBJECT_H
35 
36 #define _QORE_QORE_SOCKET_OBJECT_H
37 
38 #include <qore/QoreSocket.h>
39 #include <qore/AbstractPollableIoObjectBase.h>
40 #include <qore/QoreThreadLock.h>
41 
42 class QoreSSLCertificate;
43 class QoreSSLPrivateKey;
44 class Queue;
45 class my_socket_priv;
46 
47 class QoreSocketObject : public AbstractPollableIoObjectBase {
48  friend class my_socket_priv;
49  friend hashdecl qore_httpclient_priv;
50  friend class SocketConnectPollOperation;
51  friend class SocketSendPollOperation;
52  friend class SocketRecvPollOperationBase;
53  friend class SocketRecvPollOperation;
54  friend class SocketRecvUntilBytesPollOperation;
55  friend class SocketUpgradeClientSslPollOperation;
56  friend class HttpClientConnectPollOperation;
57 
58 public:
59  DLLEXPORT QoreSocketObject();
60 
61  DLLEXPORT virtual void deref(ExceptionSink* xsink);
62  DLLEXPORT virtual void deref();
63 
65 
69  DLLEXPORT void invalidate(ExceptionSink* xsink);
70 
72 
79  DLLEXPORT AbstractPollState* startConnect(ExceptionSink* xsink, const char* name);
80 
82 
90  DLLEXPORT AbstractPollState* startSslConnect(ExceptionSink* xsink, X509* cert = nullptr,
91  EVP_PKEY* pkey = nullptr);
92 
94 
103  DLLEXPORT AbstractPollState* startSend(ExceptionSink* xsink, const char* data, size_t size);
104 
106 
114  DLLEXPORT AbstractPollState* startRecv(ExceptionSink* xsink, size_t size);
115 
117 
127  DLLEXPORT AbstractPollState* startRecvUntilBytes(ExceptionSink* xsink, const char* pattern, size_t size);
128 
129  DLLEXPORT int connect(const char* name, int timeout_ms, ExceptionSink* xsink = nullptr);
130  DLLEXPORT int connectINET(const char* host, int port, int timeout_ms, ExceptionSink* xsink = nullptr);
131  DLLEXPORT int connectINET2(const char* host, const char* service, int family, int sock_type, int protocol,
132  int timeout_ms = -1, ExceptionSink* xsink = nullptr);
133  DLLEXPORT int connectUNIX(const char* p, int socktype, int protocol, ExceptionSink* xsink = nullptr);
134  DLLEXPORT int connectSSL(const char* name, int timeout_ms, ExceptionSink* xsink);
135  DLLEXPORT int connectINETSSL(const char* host, int port, int timeout_ms, ExceptionSink* xsink);
136  DLLEXPORT int connectINET2SSL(const char* host, const char* service, int family, int sock_type, int protocol,
137  int timeout_ms = -1, ExceptionSink* xsink = nullptr);
138  DLLEXPORT int connectUNIXSSL(const char* p, int socktype, int protocol, ExceptionSink* xsink);
139  // to bind to either a UNIX socket or an INET interface:port
140  DLLEXPORT int bind(const char* name, bool reuseaddr = false);
141  // to bind to an INET tcp port on all interfaces
142  DLLEXPORT int bind(int port, bool reuseaddr = false);
143  // to bind an open socket to an INET tcp port on a specific interface
144  DLLEXPORT int bind(const char* iface, int port, bool reuseaddr = false);
145 
146  DLLEXPORT int bindUNIX(const char* name, int socktype, int protocol, ExceptionSink* xsink);
147  DLLEXPORT int bindINET(const char* name, const char* service, bool reuseaddr, int family, int socktype,
148  int protocol, ExceptionSink* xsink);
149 
150  // get port number for INET sockets
151  DLLEXPORT int getPort();
152  DLLEXPORT QoreSocketObject* accept(SocketSource* source, ExceptionSink* xsink);
153  DLLEXPORT QoreSocketObject* acceptSSL(SocketSource* source, ExceptionSink* xsink);
154  DLLEXPORT QoreSocketObject* accept(int timeout_ms, ExceptionSink* xsink);
155  DLLEXPORT QoreSocketObject* acceptSSL(int timeout_ms, ExceptionSink* xsink);
156 
157  DLLEXPORT int listen(int backlog);
158  // send a buffer of a particular size
159  DLLEXPORT int send(const char* buf, int size);
160  DLLEXPORT int send(const char* buf, int size, int timeout_ms, ExceptionSink* xsink);
161  // send a null-terminated string
162  DLLEXPORT int send(const QoreStringNode& msg, int timeout_ms, ExceptionSink* xsink);
163  // send a binary object
164  DLLEXPORT int send(const BinaryNode* b);
165  DLLEXPORT int send(const BinaryNode* b, int timeout_ms, ExceptionSink* xsink);
166  // send a certain number of bytes (read from an InputStream)
167  DLLEXPORT void sendFromInputStream(InputStream* is, int64 size, int64 timeout_ms, ExceptionSink *xsink);
168 
169  // send from a file descriptor
170  DLLEXPORT int send(int fd, int size = -1);
171  // send bytes and convert to network order
172  DLLEXPORT int sendi1(char b, int timeout_ms, ExceptionSink* xsink);
173  DLLEXPORT int sendi2(short b, int timeout_ms, ExceptionSink* xsink);
174  DLLEXPORT int sendi4(int b, int timeout_ms, ExceptionSink* xsink);
175  DLLEXPORT int sendi8(int64 b, int timeout_ms, ExceptionSink* xsink);
176  DLLEXPORT int sendi2LSB(short b, int timeout_ms, ExceptionSink* xsink);
177  DLLEXPORT int sendi4LSB(int b, int timeout_ms, ExceptionSink* xsink);
178  DLLEXPORT int sendi8LSB(int64 b, int timeout_ms, ExceptionSink* xsink);
179  // receive a message
180  DLLEXPORT QoreStringNode* recv(int timeout, ExceptionSink* xsink);
181  // receive a certain number of bytes as a string
182  DLLEXPORT QoreStringNode* recv(qore_offset_t bufsize, int timeout_ms, ExceptionSink* xsink);
183  // receive a certain number of bytes as a binary object
184  DLLEXPORT BinaryNode* recvBinary(int bufsize, int timeout, ExceptionSink* xsink);
185  // receive a packet of bytes as a binary object
186  DLLEXPORT BinaryNode* recvBinary(int timeout, ExceptionSink* xsink);
187  // receive a certain number of bytes and write them to an OutputStream
188  DLLEXPORT void recvToOutputStream(OutputStream* os, int64 size, int64 timeout_ms, ExceptionSink *xsink);
189 
190  // receive and write data to a file descriptor
191  DLLEXPORT int recv(int fd, int size, int timeout);
192  // receive integers and convert from network byte order
193  DLLEXPORT int64 recvi1(int timeout, char* b, ExceptionSink* xsink);
194  DLLEXPORT int64 recvi2(int timeout, short* b, ExceptionSink* xsink);
195  DLLEXPORT int64 recvi4(int timeout, int* b, ExceptionSink* xsink);
196  DLLEXPORT int64 recvi8(int timeout, int64* b, ExceptionSink* xsink);
197  DLLEXPORT int64 recvi2LSB(int timeout, short* b, ExceptionSink* xsink);
198  DLLEXPORT int64 recvi4LSB(int timeout, int* b, ExceptionSink* xsink);
199  DLLEXPORT int64 recvi8LSB(int timeout, int64* b, ExceptionSink* xsink);
200  DLLEXPORT int64 recvu1(int timeout, unsigned char* b, ExceptionSink* xsink);
201  DLLEXPORT int64 recvu2(int timeout, unsigned short* b, ExceptionSink* xsink);
202  DLLEXPORT int64 recvu4(int timeout, unsigned int* b, ExceptionSink* xsink);
203  DLLEXPORT int64 recvu2LSB(int timeout, unsigned short* b, ExceptionSink* xsink);
204  DLLEXPORT int64 recvu4LSB(int timeout, unsigned int* b, ExceptionSink* xsink);
205 
206  // send HTTP message
207  DLLEXPORT int sendHTTPMessage(ExceptionSink* xsink, QoreHashNode* info, const char* method, const char* path,
208  const char* http_version, const QoreHashNode* headers, const void* ptr, int size, int source, int timeout_ms);
209  DLLEXPORT int sendHTTPMessage(ExceptionSink* xsink, QoreHashNode* info, const char* method, const char* path,
210  const char* http_version, const QoreHashNode* headers, const QoreStringNode& body, int source, int timeout_ms);
211  DLLEXPORT int sendHTTPMessageWithCallback(ExceptionSink* xsink, QoreHashNode* info, const char* method,
212  const char *path, const char *http_version, const QoreHashNode* headers,
213  const ResolvedCallReferenceNode& send_callback, int source, int timeout_ms, bool* aborted = nullptr);
214 
215  // send HTTP response
216  DLLEXPORT int sendHTTPResponse(ExceptionSink* xsink, QoreHashNode* info, int code, const char* desc,
217  const char* http_version, const QoreHashNode* headers, const void* data, size_t size, int source,
218  int timeout_ms);
219  DLLEXPORT int sendHTTPResponse(ExceptionSink* xsink, QoreHashNode* info, int code, const char* desc,
220  const char* http_version, const QoreHashNode* headers, const QoreStringNode& body, int source,
221  int timeout_ms);
222 
223  // send HTTP response from stream
224  DLLEXPORT int sendHTTPResponse(ExceptionSink* xsink, QoreHashNode* info, int code, const char* desc,
225  const char* http_version, const QoreHashNode* headers, InputStream* is, size_t max_chunked_size,
226  const ResolvedCallReferenceNode* trailer_callback, int source, int timeout_ms);
227 
228  // send HTTP response from callback
229  DLLEXPORT int sendHTTPResponseWithCallback(ExceptionSink* xsink, QoreHashNode* info, int code, const char *desc,
230  const char *http_version, const QoreHashNode* headers, const ResolvedCallReferenceNode& send_callback,
231  int source, int timeout_ms, bool* aborted = nullptr);
232 
233  // send data in HTTP chunked format
234  DLLEXPORT void sendHTTPChunkedBodyFromInputStream(InputStream* is, size_t max_chunked_size, const int timeout_ms,
235  const ResolvedCallReferenceNode* trailer_callback, ExceptionSink* xsink);
236  DLLEXPORT void sendHTTPChunkedBodyTrailer(const QoreHashNode* headers, int timeout_ms, ExceptionSink* xsink);
237 
238  // read and parse HTTP header
239  DLLEXPORT AbstractQoreNode* readHTTPHeader(ExceptionSink* xsink, QoreHashNode* info, int timeout);
240  // receive a binary message in HTTP chunked format
241  DLLEXPORT QoreHashNode* readHTTPChunkedBodyBinary(int timeout, ExceptionSink* xsink);
242  // receive a binary message in HTTP chunked format
243  DLLEXPORT QoreHashNode* readHTTPChunkedBodyToOutputStream(OutputStream* os, int timeout_ms, ExceptionSink* xsink);
244  // receive a string message in HTTP chunked format
245  DLLEXPORT QoreHashNode* readHTTPChunkedBody(int timeout, ExceptionSink* xsink);
246 
247  // receive a binary message in HTTP chunked format
248  DLLEXPORT void readHTTPChunkedBodyBinaryWithCallback(const ResolvedCallReferenceNode& recv_callback,
249  QoreObject* obj, int timeout_ms, ExceptionSink* xsink);
250  // receive a string message in HTTP chunked format
251  DLLEXPORT void readHTTPChunkedBodyWithCallback(const ResolvedCallReferenceNode& recv_callback, QoreObject* obj,
252  int timeout_ms, ExceptionSink* xsink);
253 
254  DLLEXPORT QoreStringNode* readHTTPHeaderString(ExceptionSink* xsink, int timeout_ms);
255 
257 
261  DLLEXPORT int getPollableDescriptor() const;
262 
263  DLLEXPORT int setSendTimeout(int ms);
264  DLLEXPORT int setRecvTimeout(int ms);
265  DLLEXPORT int getSendTimeout();
266  DLLEXPORT int getRecvTimeout();
267  DLLEXPORT int close();
268  DLLEXPORT int shutdown();
269  DLLEXPORT int shutdownSSL(ExceptionSink* xsink) ;
270  DLLEXPORT const char* getSSLCipherName();
271  DLLEXPORT const char* getSSLCipherVersion();
272  DLLEXPORT bool isSecure();
273  DLLEXPORT long verifyPeerCertificate();
274  DLLEXPORT int getSocket();
275  DLLEXPORT void setEncoding(const QoreEncoding* id);
276  DLLEXPORT const QoreEncoding* getEncoding() const;
277  DLLEXPORT bool isDataAvailable(ExceptionSink* xsink, int timeout = 0);
278  DLLEXPORT bool isWriteFinished(ExceptionSink* xsink, int timeout = 0);
279  DLLEXPORT bool isOpen() const;
280  // c must be already referenced before this call
281  DLLEXPORT void setCertificate(QoreSSLCertificate* c);
282  // p must be already referenced before this call
283  DLLEXPORT void setPrivateKey(QoreSSLPrivateKey* p);
284  // c and p must be already referenced before this call
285  DLLEXPORT void setCertificateAndPrivateKey(QoreSSLCertificate* c, QoreSSLPrivateKey* p);
286  DLLEXPORT int setNoDelay(int nodelay);
287  DLLEXPORT int getNoDelay();
288  DLLEXPORT void setEventQueue(ExceptionSink* xsink, Queue* q, QoreValue arg, bool with_data);
289  DLLEXPORT void setEventQueue(Queue* cbq, ExceptionSink* xsink);
290  DLLEXPORT QoreHashNode* getPeerInfo(ExceptionSink* xsink, bool host_lookup = true) const;
291  DLLEXPORT QoreHashNode* getSocketInfo(ExceptionSink* xsink, bool host_lookup = true) const;
292 
293  DLLEXPORT void upgradeClientToSSL(ExceptionSink* xsink);
294  DLLEXPORT void upgradeServerToSSL(ExceptionSink* xsink);
295 
296  DLLEXPORT void upgradeClientToSSL(int timeout_ms, ExceptionSink* xsink);
297  DLLEXPORT void upgradeServerToSSL(int timeout_ms, ExceptionSink* xsink);
298 
299  DLLEXPORT void clearWarningQueue(ExceptionSink* xsink);
300  DLLEXPORT void setWarningQueue(ExceptionSink* xsink, int64 warning_ms, int64 warning_bs, Queue* wq, QoreValue arg,
301  int64 min_ms = 1000);
302  DLLEXPORT QoreHashNode* getUsageInfo() const;
303  DLLEXPORT void clearStats();
304  DLLEXPORT bool pendingHttpChunkedBody() const;
305  DLLEXPORT void setSslVerifyMode(int mode);
306  DLLEXPORT int getSslVerifyMode() const;
307  DLLEXPORT void acceptAllCertificates(bool accept_all = true);
308  DLLEXPORT bool getAcceptAllCertificates() const;
309  DLLEXPORT bool captureRemoteCertificates(bool set);
310  DLLEXPORT QoreObject* getRemoteCertificate() const;
311  DLLEXPORT int64 getConnectionId() const;
312 
314  DLLEXPORT int setNonBlock(ExceptionSink* xsink);
315 
317  DLLEXPORT void clearNonBlock();
318 
319 private:
320  DLLLOCAL QoreSocketObject(QoreSocket* s, QoreSSLCertificate* cert = nullptr, QoreSSLPrivateKey* pk = nullptr);
321 
322 protected:
323  my_socket_priv* priv;
324 
325  DLLLOCAL virtual ~QoreSocketObject();
326 };
327 
328 #endif // _QORE_QORE_SOCKET_OBJECT_H
The base class for all value and parse types in Qore expression trees.
Definition: AbstractQoreNode.h:57
holds arbitrary binary data
Definition: BinaryNode.h:41
container for holding Qore-language exception information and also for registering a "thread_exit" ca...
Definition: ExceptionSink.h:48
Interface for private data of input streams.
Definition: InputStream.h:44
Interface for private data of output streams.
Definition: OutputStream.h:44
defines string encoding functions in Qore
Definition: QoreEncoding.h:83
This is the hash or associative list container type in Qore, dynamically allocated only,...
Definition: QoreHashNode.h:50
the implementation of Qore's object data type, reference counted, dynamically-allocated only
Definition: QoreObject.h:60
represents an X509 certificate, reference-counted, dynamically-allocated only
Definition: QoreSSLCertificate.h:42
provides access to a private key data structure for SSL connections
Definition: QoreSSLPrivateKey.h:40
provides access to sockets using Qore data structures
Definition: QoreSocket.h:127
Qore's string value type, reference counted, dynamically-allocated only.
Definition: QoreStringNode.h:50
base class for resolved call references
Definition: CallReferenceNode.h:109
a helper class for getting socket origination information
Definition: QoreSocket.h:74
intptr_t qore_offset_t
used for offsets that could be negative
Definition: common.h:76
long long int64
64bit integer type, cannot use int64_t here since it breaks the API on some 64-bit systems due to equ...
Definition: common.h:260
The main value class in Qore, designed to be passed by value.
Definition: QoreValue.h:275