File indexing completed on 2024-09-15 11:56:11
0001 /* -*- C++ -*- 0002 * Copyright (C) 2003,2005 Thiago Macieira <thiago@kde.org> 0003 * 0004 * 0005 * Permission is hereby granted, free of charge, to any person obtaining 0006 * a copy of this software and associated documentation files (the 0007 * "Software"), to deal in the Software without restriction, including 0008 * without limitation the rights to use, copy, modify, merge, publish, 0009 * distribute, sublicense, and/or sell copies of the Software, and to 0010 * permit persons to whom the Software is furnished to do so, subject to 0011 * the following conditions: 0012 * 0013 * The above copyright notice and this permission notice shall be included 0014 * in all copies or substantial portions of the Software. 0015 * 0016 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 0017 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 0018 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 0019 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE 0020 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 0021 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION 0022 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 0023 */ 0024 0025 /* 0026 * Even before our #ifdef, clean up the namespace 0027 */ 0028 #ifdef socket 0029 #undef socket 0030 #endif 0031 0032 #ifdef bind 0033 #undef bind 0034 #endif 0035 0036 #ifdef listen 0037 #undef listen 0038 #endif 0039 0040 #ifdef connect 0041 #undef connect 0042 #endif 0043 0044 #ifdef accept 0045 #undef accept 0046 #endif 0047 0048 #ifdef getpeername 0049 #undef getpeername 0050 #endif 0051 0052 #ifdef getsockname 0053 #undef getsockname 0054 #endif 0055 0056 #ifndef KSOCKETBASE_H 0057 #define KSOCKETBASE_H 0058 0059 #include <QIODevice> 0060 #include <QString> 0061 0062 #include <kdelibs4support_export.h> 0063 #include "k3socketaddress.h" 0064 0065 class QMutex; 0066 0067 namespace KNetwork 0068 { 0069 0070 class KResolverEntry; 0071 class KSocketDevice; 0072 0073 class KSocketBasePrivate; 0074 /** @class KSocketBase k3socketbase.h k3socketbase.h 0075 * @brief Basic socket functionality. 0076 * 0077 * This class provides the basic socket functionlity for descended classes. 0078 * Socket classes are thread-safe and provide a recursive mutex should it be 0079 * needed. 0080 * 0081 * @note This class is abstract. 0082 * 0083 * @author Thiago Macieira <thiago@kde.org> 0084 * @deprecated Use KSocketFactory or KLocalSocket instead 0085 */ 0086 class KDELIBS4SUPPORT_DEPRECATED_EXPORT KSocketBase 0087 { 0088 public: 0089 /** 0090 * Possible socket options. 0091 * 0092 * These are the options that may be set on a socket: 0093 * - Blocking: whether the socket shall operate in blocking 0094 * or non-blocking mode. This flag defaults to on. 0095 * See setBlocking(). 0096 * - AddressReusable: whether the address used by this socket will 0097 * be available for reuse by other sockets. This flag defaults to off. 0098 * See setAddressReuseable(). 0099 * - IPv6Only: whether an IPv6 socket will accept IPv4 connections 0100 * through a mapped address. This flag defaults to off. 0101 * See setIPv6Only(). 0102 * - KeepAlive: whether TCP should send keepalive probes when a connection 0103 * has gone idle for far too long. 0104 * - Broadcast: whether this socket is allowed to send broadcast packets 0105 * and will receive packets sent to broadcast. 0106 * - NoDelay: disable the Nagle algorithm for socket types that support 0107 * it. 0108 */ 0109 enum SocketOptions { 0110 Blocking = 0x01, 0111 AddressReuseable = 0x02, 0112 IPv6Only = 0x04, 0113 Keepalive = 0x08, 0114 Broadcast = 0x10, 0115 NoDelay = 0x20 0116 }; 0117 0118 /** 0119 * Possible socket error codes. 0120 * 0121 * This is a list of possible error conditions that socket classes may 0122 * be expected to find. 0123 * 0124 * - NoError: no error has been detected 0125 * - LookupFailure: if a name lookup has failed 0126 * - AddressInUse: address is already in use 0127 * - AlreadyBound: cannot bind again 0128 * - AlreadyCreated: cannot recreate the socket 0129 * - NotBound: operation required socket to be bound and it isn't 0130 * - NotCreated: operation required socket to exist and it doesn't 0131 * - WouldBlock: requested I/O operation would block 0132 * - ConnectionRefused: connection actively refused 0133 * - ConnectionTimedOut: connection timed out 0134 * - InProgress: operation (connection) is already in progress 0135 * - NetFailure: a network failure occurred (no route, host down, host unreachable or similar) 0136 * - NotSupported: requested operation is not supported 0137 * - Timeout: a timed operation timed out 0138 * - UnknownError: an unknown/unexpected error has happened 0139 * - RemotelyDisconnected: when a connection is disconnected by the other end (since 3.4) 0140 * 0141 * @sa error, errorString 0142 */ 0143 enum SocketError { 0144 NoError = 0, 0145 LookupFailure, 0146 AddressInUse, 0147 AlreadyCreated, 0148 AlreadyBound, 0149 AlreadyConnected, 0150 NotConnected, 0151 NotBound, 0152 NotCreated, 0153 WouldBlock, 0154 ConnectionRefused, 0155 ConnectionTimedOut, 0156 InProgress, 0157 NetFailure, 0158 NotSupported, 0159 Timeout, 0160 UnknownError, 0161 RemotelyDisconnected 0162 }; 0163 0164 public: 0165 /** 0166 * Default constructor. 0167 */ 0168 KSocketBase(); 0169 0170 /** 0171 * Destructor. 0172 */ 0173 virtual ~KSocketBase(); 0174 0175 /* 0176 * The following functions are shared by all descended classes and will have 0177 * to be reimplemented. 0178 */ 0179 0180 protected: 0181 /** 0182 * Set the given socket options. 0183 * 0184 * The default implementation does nothing but store the mask internally. 0185 * Descended classes must override this function to achieve functionality and 0186 * must also call this implementation. 0187 * 0188 * @param opts a mask of SocketOptions or-ed bits of options to set 0189 * or unset 0190 * @returns true on success 0191 * @note this function sets the options corresponding to the bits enabled in @p opts 0192 * but will also unset the optiosn corresponding to the bits not set. 0193 */ 0194 virtual bool setSocketOptions(int opts); 0195 0196 /** 0197 * Retrieves the socket options that have been set. 0198 * 0199 * The default implementation just retrieves the mask from an internal variable. 0200 * Descended classes may choose to override this function to read the values 0201 * from the operating system. 0202 * 0203 * @returns the mask of the options set 0204 */ 0205 virtual int socketOptions() const; 0206 0207 public: 0208 /** 0209 * Sets this socket's blocking mode. 0210 * 0211 * In blocking operation, all I/O functions are susceptible to blocking -- 0212 * i.e., will not return unless the I/O can be satisfied. In non-blocking 0213 * operation, if the I/O would block, the function will return an error 0214 * and set the corresponding error code. 0215 * 0216 * The default implementation toggles the Blocking flag with the current 0217 * socket options and calls setSocketOptions(). 0218 * 0219 * @param enable whether to set this socket to blocking mode 0220 * @returns whether setting this value was successful; it is NOT the 0221 * final blocking mode. 0222 */ 0223 virtual bool setBlocking(bool enable); 0224 0225 /** 0226 * Retrieves this socket's blocking mode. 0227 * 0228 * @returns true if this socket is/will be operated in blocking mode, 0229 * false if non-blocking. 0230 */ 0231 bool blocking() const; 0232 0233 /** 0234 * Sets this socket's address reuseable flag. 0235 * 0236 * When the address reuseable flag is active, the address used by 0237 * this socket is left reuseable for other sockets to bind. If 0238 * the flag is not active, no other sockets may reuse the same 0239 * address. 0240 * 0241 * The default implementation toggles the AddressReuseable flag with the current 0242 * socket options and calls setSocketOptions(). 0243 * 0244 * @param enable whether to set the flag on or off 0245 * @returns true if setting this flag was successful 0246 */ 0247 virtual bool setAddressReuseable(bool enable); 0248 0249 /** 0250 * Retrieves this socket's address reuseability flag. 0251 * 0252 * @returns true if this socket's address can be reused, 0253 * false if it can't. 0254 */ 0255 bool addressReuseable() const; 0256 0257 /** 0258 * Sets this socket's IPv6 Only flag. 0259 * 0260 * When this flag is on, an IPv6 socket will only accept, connect, send to or 0261 * receive from IPv6 addresses. When it is off, it will also talk to 0262 * IPv4 addresses through v4-mapped addresses. 0263 * 0264 * This option has no effect on non-IPv6 sockets. 0265 * 0266 * The default implementation toggles the IPv6Only flag with the current 0267 * socket options and calls setSocketOptions(). 0268 * 0269 * @param enable whether to set the flag on or off 0270 * @returns true if setting this flag was successful 0271 */ 0272 virtual bool setIPv6Only(bool enable); 0273 0274 /** 0275 * Retrieves this socket's IPv6 Only flag. 0276 * 0277 * @returns true if this socket will ignore IPv4-compatible and IPv4-mapped 0278 * addresses, false if it will accept them. 0279 */ 0280 bool isIPv6Only() const; 0281 0282 /** 0283 * Sets this socket Broadcast flag. 0284 * 0285 * Datagram-oriented sockets cannot normally send packets to broadcast 0286 * addresses, nor will they receive packets that were sent to a broadcast 0287 * address. To do so, you need to enable the Broadcast flag. 0288 * 0289 * This option has no effect on stream-oriented sockets. 0290 * 0291 * @returns true if setting this flag was successful. 0292 */ 0293 virtual bool setBroadcast(bool enable); 0294 0295 /** 0296 * Retrieves this socket's Broadcast flag. 0297 * 0298 * @returns true if this socket can send and receive broadcast packets, 0299 * false if it can't. 0300 */ 0301 bool broadcast() const; 0302 0303 /** 0304 * Sets this socket's NoDelay flag. 0305 * 0306 * Stream-oriented protocols, like TCP, have an internal algorithm 0307 * (called Nagle's algorithm) that collects data in a buffer so that 0308 * the transmission doesn't occur after every single write operation. 0309 * The side-effect is that the transmission of short messages is 0310 * delayed. 0311 * 0312 * Setting NoDelay to 'true' will disable this algorithm. 0313 * 0314 * @returns true if setting this flag was successful. 0315 */ 0316 virtual bool setNoDelay(bool enable); 0317 0318 /** 0319 * Retrieves this socket's NoDelay flag. 0320 * 0321 * @returns true if this socket's Nagle algorithm is disabled. 0322 */ 0323 bool noDelay() const; 0324 0325 /** 0326 * Retrieves the socket implementation used on this socket. 0327 * 0328 * This function creates the device if none has been set 0329 * using the default factory. 0330 */ 0331 KSocketDevice *socketDevice() const; 0332 0333 /** 0334 * Sets the socket implementation to be used on this socket. 0335 * 0336 * Note: it is an error to set this if the socket device has 0337 * already been set once. 0338 * 0339 * This function is provided virtual so that derived classes can catch 0340 * the setting of a device and properly set their own states and internal 0341 * variables. The parent class must be called. 0342 * 0343 * This function is called by socketDevice() above when the socket is 0344 * first created. 0345 */ 0346 virtual void setSocketDevice(KSocketDevice *device); 0347 0348 /** 0349 * Sets the internally requested capabilities for a socket device. 0350 * 0351 * Most socket classes can use any back-end implementation. However, a few 0352 * may require specific capabilities not provided in the default 0353 * implementation. By using this function, derived classes can request 0354 * that a backend with those capabilities be created when necessary. 0355 * 0356 * For the possible flags, see KSocketDevice::Capabilities. However, note 0357 * that only the Can* flags make sense in this context. 0358 * 0359 * @note Since socketDevice must always return a valid backend object, it 0360 * is is possible that the created device does not conform to all 0361 * requirements requested. Implementations sensitive to this fact 0362 * should test the object returned by socketDevice() (through 0363 * KSocketDevice::capabilities(), for instance) the availability. 0364 * 0365 * @param add mask of KSocketDevice::Capabilities to add 0366 * @param remove mask of bits to remove from the requirements 0367 * @return the current mask of requested capabilities 0368 */ 0369 int setRequestedCapabilities(int add, int remove = 0); 0370 0371 protected: 0372 /** 0373 * Returns true if the socket device has been initialised in this 0374 * object, either by calling socketDevice() or setSocketDevice() 0375 */ 0376 bool hasDevice() const; 0377 0378 /** 0379 * Sets the socket's error code. 0380 * 0381 * @param error the error code 0382 */ 0383 void setError(SocketError error); 0384 0385 /** 0386 * Resets the socket error code and the I/O Device's status. 0387 */ 0388 void resetError(); 0389 0390 public: 0391 /** 0392 * Retrieves the socket error code. 0393 * @sa errorString 0394 */ 0395 SocketError error() const; 0396 0397 /** 0398 * Returns the error string corresponding to this error condition. 0399 */ 0400 QString errorString() const; 0401 0402 /** 0403 * Returns the internal mutex for this class. 0404 * 0405 * Note on multithreaded use of sockets: 0406 * the socket classes are thread-safe by design, but you should be aware of 0407 * problems regarding socket creation, connection and destruction in 0408 * multi-threaded programs. The classes are guaranteed to work while 0409 * the socket exists, but it's not wise to call connect in multiple 0410 * threads. 0411 * 0412 * Also, this mutex must be unlocked before the object is destroyed, which 0413 * means you cannot use it to guard against other threads accessing the object 0414 * while destroying it. You must ensure there are no further references to this 0415 * object when deleting it. 0416 */ 0417 QMutex *mutex() const; 0418 0419 public: 0420 /** 0421 * Returns the string describing the given error code, i18n'ed. 0422 * 0423 * @param code the error code 0424 */ 0425 static QString errorString(SocketError code); 0426 0427 /** 0428 * Returns true if the given error code is a fatal one, false 0429 * otherwise. The parameter here is of type int so that 0430 * casting isn't necessary when using the parameter to signal 0431 * QClientSocketBase::gotError. 0432 * 0433 * @param code the code to test 0434 */ 0435 static bool isFatalError(int code); 0436 0437 private: 0438 /// @internal 0439 /// called by KSocketDevice 0440 void unsetSocketDevice(); 0441 0442 KSocketBase(const KSocketBase &); 0443 KSocketBase &operator =(const KSocketBase &); 0444 0445 KSocketBasePrivate *const d; 0446 0447 friend class KSocketDevice; 0448 }; 0449 0450 /** 0451 * @class KActiveSocketBase k3socketbase.h k3socketbase.h 0452 * @brief Abstract class for active sockets 0453 * 0454 * This class provides the standard interfaces for active sockets, i.e., 0455 * sockets that are used to connect to external addresses. 0456 * 0457 * @author Thiago Macieira <thiago@kde.org> 0458 * @deprecated Use KSocketFactory or KLocalSocket instead 0459 */ 0460 class KDELIBS4SUPPORT_DEPRECATED_EXPORT KActiveSocketBase: public QIODevice, virtual public KSocketBase 0461 { 0462 Q_OBJECT 0463 public: 0464 /** 0465 * Constructor. 0466 */ 0467 KActiveSocketBase(QObject *parent); 0468 0469 /** 0470 * Destructor. 0471 */ 0472 ~KActiveSocketBase() override; 0473 0474 /** 0475 * Unshadow errorString from QIODevice 0476 */ 0477 QString errorString() const; 0478 0479 /** 0480 * @reimp 0481 */ 0482 void setSocketDevice(KSocketDevice *device) override; 0483 0484 /** 0485 * Reimplemented from QIODevice. 0486 */ 0487 bool open(OpenMode mode) override; 0488 0489 /** 0490 * Binds this socket to the given address. 0491 * 0492 * The socket will be constructed with the address family, 0493 * socket type and protocol as those given in the 0494 * @p address object. 0495 * 0496 * @param address the address to bind to 0497 * @returns true if the binding was successful, false otherwise 0498 */ 0499 virtual bool bind(const KResolverEntry &address) = 0; 0500 0501 /** 0502 * Connect to a remote host. 0503 * 0504 * This will make this socket try to connect to the remote host. 0505 * If the socket is not yet created, it will be created using the 0506 * address family, socket type and protocol specified in the 0507 * @p address object. 0508 * 0509 * If this function returns with error InProgress, calling it 0510 * again with the same address after a time will cause it to test 0511 * if the connection has succeeded in the mean time. 0512 * 0513 * @param address the address to connect to 0514 * @param mode mode for connection, from QIODevice 0515 * 0516 * @returns true if the connection was successful or has been successfully 0517 * queued; false if an error occurred. 0518 */ 0519 virtual bool connect(const KResolverEntry &address, 0520 OpenMode mode = ReadWrite) = 0; 0521 0522 /** 0523 * Disconnects this socket from a connection, if possible. 0524 * 0525 * If this socket was connected to an endpoint, the connection 0526 * is severed, but the socket is not closed. If the socket wasn't 0527 * connected, this function does nothing. 0528 * 0529 * If the socket hadn't yet been created, this function does nothing 0530 * either. 0531 * 0532 * Not all socket types can disconnect. Most notably, only 0533 * connectionless datagram protocols such as UDP support this operation. 0534 * 0535 * @return true if the socket is now disconnected or false on error. 0536 */ 0537 virtual bool disconnect() = 0; 0538 0539 /** 0540 * Sockets are sequential 0541 */ 0542 bool isSequential() const override; 0543 0544 /** 0545 * This call is not supported on sockets. Reimplemented from QIODevice. 0546 * This will always return 0. 0547 */ 0548 qint64 size() const override; 0549 0550 /** 0551 * This call is not supported on sockets. Reimplemented from QIODevice. 0552 * This will always return 0. 0553 */ 0554 qint64 pos() const override; 0555 0556 /** 0557 * This call is not supported on sockets. Reimplemented from QIODevice. 0558 * This will always return false. 0559 */ 0560 bool seek(qint64) override; 0561 0562 /** 0563 * This call is not supported on sockets. Reimplemented from QIODevice. 0564 * This will always return true. 0565 */ 0566 bool atEnd() const override; 0567 0568 /** 0569 * Reads data from the socket. 0570 * 0571 * Reimplemented from QIODevice. See QIODevice::read for 0572 * more information. 0573 */ 0574 qint64 read(char *data, qint64 maxlen); 0575 0576 /** 0577 * Reads data from the socket. 0578 * 0579 * Reimplemented from QIODevice. See QIODevice::read for 0580 * more information. 0581 */ 0582 QByteArray read(qint64 len); 0583 0584 /** @overload 0585 * Receives data and the source address. 0586 * 0587 * This call will read data in the socket and will also 0588 * place the sender's address in @p from object. 0589 * 0590 * @param data where to write the read data to 0591 * @param maxlen the maximum number of bytes to read 0592 * @param from the address of the sender will be stored here 0593 * @returns the actual number of bytes read 0594 */ 0595 qint64 read(char *data, qint64 maxlen, KSocketAddress &from); 0596 0597 /** 0598 * Peeks the data in the socket and the source address. 0599 * 0600 * This call will allow you to peek the data to be received without actually 0601 * receiving it -- that is, it will be available for further peekings and 0602 * for the next read call. 0603 * 0604 * @param data where to write the peeked data to 0605 * @param maxlen the maximum number of bytes to peek 0606 * @returns the actual number of bytes copied into @p data 0607 */ 0608 qint64 peek(char *data, qint64 maxlen); 0609 0610 /** 0611 * @overload 0612 * Peeks the data in the socket and the source address. 0613 * 0614 * This call will allow you to peek the data to be received without actually 0615 * receiving it -- that is, it will be available for further peekings and 0616 * for the next read call. 0617 * 0618 * @param data where to write the peeked data to 0619 * @param maxlen the maximum number of bytes to peek 0620 * @param from the address of the sender will be stored here 0621 * @returns the actual number of bytes copied into @p data 0622 */ 0623 qint64 peek(char *data, qint64 maxlen, KSocketAddress &from); 0624 0625 /** 0626 * Writes the given data to the socket. 0627 * 0628 * Reimplemented from QIODevice. See QIODevice::write for 0629 * more information. 0630 */ 0631 qint64 write(const char *data, qint64 len); 0632 0633 /** 0634 * Writes the given data to the socket. 0635 * 0636 * Reimplemented from QIODevice. See QIODevice::write for 0637 * more information. 0638 */ 0639 qint64 write(const QByteArray &data); 0640 0641 /** @overload 0642 * Writes the given data to the destination address. 0643 * 0644 * Note that not all socket connections allow sending data to different 0645 * addresses than the one the socket is connected to. 0646 * 0647 * @param data the data to write 0648 * @param len the length of the data 0649 * @param to the address to send to 0650 * @returns the number of bytes actually sent 0651 */ 0652 qint64 write(const char *data, qint64 len, const KSocketAddress &to); 0653 0654 /** 0655 * Waits up to @p msecs for more data to be available on this socket. 0656 * 0657 * If msecs is -1, this call will block indefinetely until more data 0658 * is indeed available; if it's 0, this function returns immediately. 0659 * 0660 * If @p timeout is not NULL, this function will set it to indicate 0661 * if a timeout occurred. 0662 * 0663 * @returns the number of bytes available 0664 */ 0665 virtual qint64 waitForMore(int msecs, bool *timeout = nullptr) = 0; 0666 0667 /** 0668 * This call is not supported on sockets. Reimplemented from QIODevice. 0669 */ 0670 void ungetChar(char); 0671 0672 /** 0673 * Returns this socket's local address. 0674 */ 0675 virtual KSocketAddress localAddress() const = 0; 0676 0677 /** 0678 * Return this socket's peer address, if we are connected. 0679 * If the address cannot be retrieved, the returned object will contain 0680 * an invalid address. 0681 */ 0682 virtual KSocketAddress peerAddress() const = 0; 0683 0684 // FIXME KDE 4.0: 0685 // enable this function 0686 #if 0 0687 /** 0688 * Returns this socket's externally-visible address, if known. 0689 */ 0690 virtual KSocketAddress externalAddress() const = 0; 0691 #endif 0692 0693 protected: 0694 /** 0695 * Reads data from the socket. 0696 * 0697 * Reimplemented from QIODevice. See QIODevice::readData for 0698 * more information. 0699 */ 0700 qint64 readData(char *data, qint64 len) override; 0701 0702 /** @overload 0703 * Receives data and the source address. 0704 * 0705 * This call will read data in the socket and will also 0706 * place the sender's address in @p from object. 0707 * 0708 * @param data where to write the read data to 0709 * @param maxlen the maximum number of bytes to read 0710 * @param from the address of the sender will be stored here 0711 * @returns the actual number of bytes read 0712 */ 0713 virtual qint64 readData(char *data, qint64 maxlen, KSocketAddress *from) = 0; 0714 0715 /** 0716 * Peeks the data in the socket and the source address. 0717 * 0718 * This call will allow you to peek the data to be received without actually 0719 * receiving it -- that is, it will be available for further peekings and 0720 * for the next read call. 0721 * 0722 * @param data where to write the peeked data to 0723 * @param maxlen the maximum number of bytes to peek 0724 * @param from the address of the sender will be stored here 0725 * @returns the actual number of bytes copied into @p data 0726 */ 0727 virtual qint64 peekData(char *data, qint64 maxlen, KSocketAddress *from) = 0; 0728 0729 /** 0730 * Writes the given data to the socket. 0731 * 0732 * Reimplemented from QIODevice. See QIODevice::writeData for 0733 * more information. 0734 */ 0735 qint64 writeData(const char *data, qint64 len) override; 0736 0737 /** @overload 0738 * Writes the given data to the destination address. 0739 * 0740 * Note that not all socket connections allow sending data to different 0741 * addresses than the one the socket is connected to. 0742 * 0743 * @param data the data to write 0744 * @param len the length of the data 0745 * @param to the address to send to 0746 * @returns the number of bytes actually sent 0747 */ 0748 virtual qint64 writeData(const char *data, qint64 len, const KSocketAddress *to) = 0; 0749 0750 /** 0751 * Sets the socket's error code. 0752 * 0753 * @param error the error code 0754 */ 0755 void setError(SocketError error); 0756 0757 /** 0758 * Resets the socket error code and the I/O Device's status. 0759 */ 0760 void resetError(); 0761 }; 0762 0763 /** 0764 * @class KPassiveSocketBase k3socketbase.h k3socketbase.h 0765 * @brief Abstract base class for passive sockets. 0766 * 0767 * This socket provides the initial functionality for passive sockets, 0768 * i.e., sockets that accept incoming connections. 0769 * 0770 * @author Thiago Macieira <thiago@kde.org> 0771 * @deprecated Use KSocketFactory or KLocalSocket instead 0772 */ 0773 class KDELIBS4SUPPORT_DEPRECATED_EXPORT KPassiveSocketBase: virtual public KSocketBase 0774 { 0775 public: 0776 /** 0777 * Constructor 0778 */ 0779 KPassiveSocketBase(); 0780 0781 /** 0782 * Destructor 0783 */ 0784 ~KPassiveSocketBase() override; 0785 0786 /** 0787 * Binds this socket to the given address. 0788 * 0789 * The socket will be constructed with the address family, 0790 * socket type and protocol as those given in the 0791 * @p address object. 0792 * 0793 * @param address the address to bind to 0794 * @returns true if the binding was successful, false otherwise 0795 */ 0796 virtual bool bind(const KResolverEntry &address) = 0; 0797 0798 /** 0799 * Puts this socket into listening mode. 0800 * 0801 * Placing a socket in listening mode means that it will 0802 * be allowed to receive incoming connections from 0803 * remote hosts. 0804 * 0805 * Note that some socket types or protocols cannot be 0806 * put in listening mode. 0807 * 0808 * @param backlog the number of accepted connections to 0809 * hold before starting to refuse 0810 * @returns true if the socket is now in listening mode 0811 */ 0812 virtual bool listen(int backlog) = 0; 0813 0814 /** 0815 * Closes this socket. All resources used are freed. Note that closing 0816 * a passive socket does not close the connections accepted with it. 0817 */ 0818 virtual void close() = 0; 0819 0820 /** 0821 * Accepts a new incoming connection. 0822 * 0823 * If this socket was in listening mode, you can call this 0824 * function to accept an incoming connection. 0825 * 0826 * If this function cannot accept a new connection (either 0827 * because it is not listening for one or because the operation 0828 * would block), it will return NULL. 0829 * 0830 * Also note that descended classes will override this function 0831 * to return specialized socket classes. 0832 */ 0833 virtual KActiveSocketBase *accept() = 0; 0834 0835 /** 0836 * Returns this socket's local address. 0837 */ 0838 virtual KSocketAddress localAddress() const = 0; 0839 0840 /** 0841 * Returns this socket's externally-visible address if known. 0842 */ 0843 virtual KSocketAddress externalAddress() const = 0; 0844 0845 private: 0846 KPassiveSocketBase(const KPassiveSocketBase &); 0847 KPassiveSocketBase &operator = (const KPassiveSocketBase &); 0848 }; 0849 0850 } // namespace KNetwork 0851 0852 #endif