!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/netdata/externaldeps/libwebsockets/include/libwebsockets/   drwxrwxr-x
Free 13.1 GB of 57.97 GB (22.6%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     lws-timeout-timer.h (8.14 KB)      -rw-rw-r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/*
 * libwebsockets - small server side websockets and web server implementation
 *
 * Copyright (C) 2010-2018 Andy Green <andy@warmcat.com>
 *
 *  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:
 *  version 2.1 of the License.
 *
 *  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
 *
 * included from libwebsockets.h
 */

/*! \defgroup timeout Connection timeouts

    APIs related to setting connection timeouts
*/
//@{

/*
 * NOTE: These public enums are part of the abi.  If you want to add one,
 * add it at where specified so existing users are unaffected.
 */
enum pending_timeout {
    NO_PENDING_TIMEOUT                    =  0,
    PENDING_TIMEOUT_AWAITING_PROXY_RESPONSE            =  1,
    PENDING_TIMEOUT_AWAITING_CONNECT_RESPONSE        =  2,
    PENDING_TIMEOUT_ESTABLISH_WITH_SERVER            =  3,
    PENDING_TIMEOUT_AWAITING_SERVER_RESPONSE        =  4,
    PENDING_TIMEOUT_AWAITING_PING                =  5,
    PENDING_TIMEOUT_CLOSE_ACK                =  6,
    PENDING_TIMEOUT_UNUSED1                    =  7,
    PENDING_TIMEOUT_SENT_CLIENT_HANDSHAKE            =  8,
    PENDING_TIMEOUT_SSL_ACCEPT                =  9,
    PENDING_TIMEOUT_HTTP_CONTENT                = 10,
    PENDING_TIMEOUT_AWAITING_CLIENT_HS_SEND            = 11,
    PENDING_FLUSH_STORED_SEND_BEFORE_CLOSE            = 12,
    PENDING_TIMEOUT_SHUTDOWN_FLUSH                = 13,
    PENDING_TIMEOUT_CGI                    = 14,
    PENDING_TIMEOUT_HTTP_KEEPALIVE_IDLE            = 15,
    PENDING_TIMEOUT_WS_PONG_CHECK_SEND_PING            = 16,
    PENDING_TIMEOUT_WS_PONG_CHECK_GET_PONG            = 17,
    PENDING_TIMEOUT_CLIENT_ISSUE_PAYLOAD            = 18,
    PENDING_TIMEOUT_AWAITING_SOCKS_GREETING_REPLY            = 19,
    PENDING_TIMEOUT_AWAITING_SOCKS_CONNECT_REPLY        = 20,
    PENDING_TIMEOUT_AWAITING_SOCKS_AUTH_REPLY        = 21,
    PENDING_TIMEOUT_KILLED_BY_SSL_INFO            = 22,
    PENDING_TIMEOUT_KILLED_BY_PARENT            = 23,
    PENDING_TIMEOUT_CLOSE_SEND                = 24,
    PENDING_TIMEOUT_HOLDING_AH                = 25,
    PENDING_TIMEOUT_UDP_IDLE                = 26,
    PENDING_TIMEOUT_CLIENT_CONN_IDLE            = 27,
    PENDING_TIMEOUT_LAGGING                    = 28,
    PENDING_TIMEOUT_THREADPOOL                = 29,
    PENDING_TIMEOUT_THREADPOOL_TASK                = 30,
    PENDING_TIMEOUT_KILLED_BY_PROXY_CLIENT_CLOSE        = 31,
    PENDING_TIMEOUT_USER_OK                    = 32,

    /****** add new things just above ---^ ******/

    PENDING_TIMEOUT_USER_REASON_BASE            = 1000
};

#define lws_time_in_microseconds lws_now_usecs

#define LWS_TO_KILL_ASYNC -1
/**< If LWS_TO_KILL_ASYNC is given as the timeout sec in a lws_set_timeout()
 * call, then the connection is marked to be killed at the next timeout
 * check.  This is how you should force-close the wsi being serviced if
 * you are doing it outside the callback (where you should close by nonzero
 * return).
 */
#define LWS_TO_KILL_SYNC -2
/**< If LWS_TO_KILL_SYNC is given as the timeout sec in a lws_set_timeout()
 * call, then the connection is closed before returning (which may delete
 * the wsi).  This should only be used where the wsi being closed is not the
 * wsi currently being serviced.
 */
/**
 * lws_set_timeout() - marks the wsi as subject to a timeout some seconds hence
 *
 * \param wsi:    Websocket connection instance
 * \param reason:    timeout reason
 * \param secs:    how many seconds.  You may set to LWS_TO_KILL_ASYNC to
 *        force the connection to timeout at the next opportunity, or
 *        LWS_TO_KILL_SYNC to close it synchronously if you know the
 *        wsi is not the one currently being serviced.
 */
LWS_VISIBLE LWS_EXTERN void
lws_set_timeout(struct lws *wsi, enum pending_timeout reason, int secs);

/**
 * lws_set_timeout_us() - marks the wsi as subject to a timeout some us hence
 *
 * \param wsi:    Websocket connection instance
 * \param reason:    timeout reason
 * \param us:    0 removes the timeout, otherwise number of us to wait
 *
 * Higher-resolution version of lws_set_timeout().  Actual resolution depends
 * on platform and load, usually ms.
 */
void
lws_set_timeout_us(struct lws *wsi, enum pending_timeout reason, lws_usec_t us);

#define LWS_SET_TIMER_USEC_CANCEL ((lws_usec_t)-1ll)
#define LWS_USEC_PER_SEC ((lws_usec_t)1000000)

/**
 * lws_set_timer_usecs() - schedules a callback on the wsi in the future
 *
 * \param wsi:    Websocket connection instance
 * \param usecs:  LWS_SET_TIMER_USEC_CANCEL removes any existing scheduled
 *          callback, otherwise number of microseconds in the future
 *          the callback will occur at.
 *
 * NOTE: event loop support for this:
 *
 *  default poll() loop:   yes
 *  libuv event loop:      yes
 *  libev:    not implemented (patch welcome)
 *  libevent: not implemented (patch welcome)
 *
 * After the deadline expires, the wsi will get a callback of type
 * LWS_CALLBACK_TIMER and the timer is exhausted.  The deadline may be
 * continuously deferred by further calls to lws_set_timer_usecs() with a later
 * deadline, or cancelled by lws_set_timer_usecs(wsi, -1).
 *
 * If the timer should repeat, lws_set_timer_usecs() must be called again from
 * LWS_CALLBACK_TIMER.
 *
 * Accuracy depends on the platform and the load on the event loop or system...
 * all that's guaranteed is the callback will come after the requested wait
 * period.
 */
LWS_VISIBLE LWS_EXTERN void
lws_set_timer_usecs(struct lws *wsi, lws_usec_t usecs);

/*
 * lws_timed_callback_vh_protocol() - calls back a protocol on a vhost after
 *                     the specified delay in seconds
 *
 * \param vh:     the vhost to call back
 * \param protocol: the protocol to call back
 * \param reason: callback reason
 * \param secs:    how many seconds in the future to do the callback.
 *
 * Callback the specified protocol with a fake wsi pointing to the specified
 * vhost and protocol, with the specified reason, at the specified time in the
 * future.
 *
 * Returns 0 if OK or 1 on OOM.
 *
 * In the multithreaded service case, the callback will occur in the same
 * service thread context as the call to this api that requested it.  If it is
 * called from a non-service thread, tsi 0 will handle it.
 */
LWS_VISIBLE LWS_EXTERN int
lws_timed_callback_vh_protocol(struct lws_vhost *vh,
                   const struct lws_protocols *prot,
                   int reason, int secs);

/*
 * lws_timed_callback_vh_protocol_us() - calls back a protocol on a vhost after
 *                      the specified delay in us
 *
 * \param vh:     the vhost to call back
 * \param protocol: the protocol to call back
 * \param reason: callback reason
 * \param us:    how many us in the future to do the callback.
 *
 * Callback the specified protocol with a fake wsi pointing to the specified
 * vhost and protocol, with the specified reason, at the specified time in the
 * future.
 *
 * Returns 0 if OK or 1 on OOM.
 *
 * In the multithreaded service case, the callback will occur in the same
 * service thread context as the call to this api that requested it.  If it is
 * called from a non-service thread, tsi 0 will handle it.
 */
LWS_VISIBLE LWS_EXTERN int
lws_timed_callback_vh_protocol_us(struct lws_vhost *vh,
                  const struct lws_protocols *prot, int reason,
                  lws_usec_t us);


typedef void (*sul_cb_t)(lws_sorted_usec_list_t *sul);

struct lws_sorted_usec_list {
    struct lws_dll2 list;    /* simplify the code by keeping this at start */
    sul_cb_t    cb;
    lws_usec_t    us;
};


/*
 * lws_sul_schedule() - schedule a callback
 *
 * \param context: the lws_context
 * \param tsi: the thread service index (usually 0)
 * \param sul: pointer to the sul element
 * \param cb: the scheduled callback
 * \param us: the delay before the callback arrives, or
 *        LWS_SET_TIMER_USEC_CANCEL to cancel it.
 *
 * Generic callback-at-a-later time function.  The callback happens on the
 * event loop thread context.
 *
 * Although the api has us resultion, the actual resolution depends on the
 * platform and is commonly 1ms.
 *
 * This doesn't allocate and doesn't fail.
 *
 * You can call it again with another us value to change the delay.
 */
LWS_VISIBLE LWS_EXTERN void
lws_sul_schedule(struct lws_context *context, int tsi,
             lws_sorted_usec_list_t *sul, sul_cb_t cb, lws_usec_t us);

///@}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0053 ]--