Current Path: > > opt > cloudlinux > alt-php84 > root > usr > include > > php > ext > swoole > include
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
swoole.h | File | 25430 bytes | March 12 2025 14:32:04. | |
swoole_api.h | File | 3511 bytes | March 12 2025 14:32:04. | |
swoole_asm_context.h | File | 2336 bytes | March 12 2025 14:32:04. | |
swoole_async.h | File | 3698 bytes | March 12 2025 14:32:04. | |
swoole_atomic.h | File | 3806 bytes | March 12 2025 14:32:04. | |
swoole_base64.h | File | 1325 bytes | March 12 2025 14:32:04. | |
swoole_buffer.h | File | 2287 bytes | March 12 2025 14:32:04. | |
swoole_c_api.h | File | 2126 bytes | March 12 2025 14:32:04. | |
swoole_channel.h | File | 2393 bytes | March 12 2025 14:32:04. | |
swoole_client.h | File | 8854 bytes | March 12 2025 14:32:04. | |
swoole_config.h | File | 9090 bytes | March 12 2025 14:32:04. | |
swoole_coroutine.h | File | 10214 bytes | March 12 2025 14:32:04. | |
swoole_coroutine_c_api.h | File | 5965 bytes | March 12 2025 14:32:04. | |
swoole_coroutine_channel.h | File | 4284 bytes | March 12 2025 14:32:04. | |
swoole_coroutine_context.h | File | 2813 bytes | March 12 2025 14:32:04. | |
swoole_coroutine_socket.h | File | 19232 bytes | March 12 2025 14:32:05. | |
swoole_coroutine_system.h | File | 3960 bytes | March 12 2025 14:32:05. | |
swoole_dtls.h | File | 2463 bytes | March 12 2025 14:32:05. | |
swoole_error.h | File | 6255 bytes | March 12 2025 14:32:05. | |
swoole_file.h | File | 4536 bytes | March 12 2025 14:32:05. | |
swoole_file_hook.h | File | 3929 bytes | March 12 2025 14:32:05. | |
swoole_hash.h | File | 9923 bytes | March 12 2025 14:32:05. | |
swoole_heap.h | File | 1828 bytes | March 12 2025 14:32:05. | |
swoole_http.h | File | 7157 bytes | March 12 2025 14:32:05. | |
swoole_http2.h | File | 8584 bytes | March 12 2025 14:32:05. | |
swoole_iouring.h | File | 3172 bytes | March 12 2025 14:32:05. | |
swoole_lock.h | File | 3471 bytes | March 12 2025 14:32:05. | |
swoole_log.h | File | 15705 bytes | March 12 2025 14:32:05. | |
swoole_lru_cache.h | File | 3245 bytes | March 12 2025 14:32:05. | |
swoole_memory.h | File | 2813 bytes | March 12 2025 14:32:05. | |
swoole_message_bus.h | File | 6169 bytes | March 12 2025 14:32:06. | |
swoole_mime_type.h | File | 1476 bytes | March 12 2025 14:32:06. | |
swoole_mqtt.h | File | 2228 bytes | March 12 2025 14:32:06. | |
swoole_msg_queue.h | File | 1970 bytes | March 12 2025 14:32:06. | |
swoole_pipe.h | File | 2700 bytes | March 12 2025 14:32:06. | |
swoole_process_pool.h | File | 10176 bytes | March 12 2025 14:32:06. | |
swoole_protocol.h | File | 5291 bytes | March 12 2025 14:32:06. | |
swoole_proxy.h | File | 2942 bytes | March 12 2025 14:32:06. | |
swoole_reactor.h | File | 11519 bytes | March 12 2025 14:32:06. | |
swoole_redis.h | File | 2142 bytes | March 12 2025 14:32:06. | |
swoole_server.h | File | 44999 bytes | March 12 2025 14:32:06. | |
swoole_signal.h | File | 1762 bytes | March 12 2025 14:32:06. | |
swoole_socket.h | File | 19496 bytes | March 12 2025 14:32:06. | |
swoole_socket_hook.h | File | 2284 bytes | March 12 2025 14:32:07. | |
swoole_ssl.h | File | 5062 bytes | March 12 2025 14:32:07. | |
swoole_static_handler.h | File | 4815 bytes | March 12 2025 14:32:07. | |
swoole_string.h | File | 9082 bytes | March 12 2025 14:32:07. | |
swoole_table.h | File | 7522 bytes | March 12 2025 14:32:07. | |
swoole_thread.h | File | 2280 bytes | March 12 2025 14:32:07. | |
swoole_timer.h | File | 4226 bytes | March 12 2025 14:32:07. | |
swoole_util.h | File | 6765 bytes | March 12 2025 14:32:07. | |
swoole_version.h | File | 2264 bytes | March 12 2025 14:32:08. | |
swoole_websocket.h | File | 4638 bytes | March 12 2025 14:32:08. | |
swoole_wheel_timer.h | File | 2538 bytes | March 12 2025 14:32:08. |
/* +----------------------------------------------------------------------+ | Swoole | +----------------------------------------------------------------------+ | This source file is subject to version 2.0 of the Apache license, | | that is bundled with this package in the file LICENSE, and is | | available through the world-wide-web at the following url: | | http://www.apache.org/licenses/LICENSE-2.0.html | | If you did not receive a copy of the Apache2.0 license and are unable| | to obtain it through the world-wide-web, please send a note to | | license@swoole.com so we can mail you a copy immediately. | +----------------------------------------------------------------------+ | Author: Tianfeng Han <rango@swoole.com> | +----------------------------------------------------------------------+ */ #pragma once #include "swoole_api.h" #include "swoole_string.h" #include "swoole_socket.h" #include <unordered_map> namespace swoole { struct PipeBuffer { DataHead info; char data[0]; bool is_begin() { return info.flags & SW_EVENT_DATA_BEGIN; } bool is_chunked() { return info.flags & SW_EVENT_DATA_CHUNK; } bool is_end() { return info.flags & SW_EVENT_DATA_END; } }; struct PacketPtr { size_t length; char *data; }; struct DgramPacket { SocketType socket_type; network::Address socket_addr; uint32_t length; char data[0]; }; struct PacketTask { size_t length; char tmpfile[SW_TASK_TMP_PATH_SIZE]; }; class MessageBus { private: const Allocator *allocator_; std::unordered_map<uint64_t, std::shared_ptr<String>> packet_pool_; std::vector<network::Socket *> pipe_sockets_; std::function<uint64_t(void)> id_generator_; size_t buffer_size_; PipeBuffer *buffer_ = nullptr; bool always_chunked_transfer_ = false; String *get_packet_buffer(); ReturnCode prepare_packet(uint16_t &recv_chunk_count, String *packet_buffer); public: MessageBus() { allocator_ = sw_std_allocator(); buffer_size_ = SW_BUFFER_SIZE_STD; } ~MessageBus(); bool empty() { return packet_pool_.empty(); } size_t count() { return packet_pool_.size(); } void clear() { packet_pool_.clear(); } void set_allocator(const Allocator *allocator) { allocator_ = allocator; } void set_id_generator(const std::function<uint64_t(void)> &id_generator) { id_generator_ = id_generator; } void set_buffer_size(size_t buffer_size) { buffer_size_ = buffer_size; } void set_always_chunked_transfer() { always_chunked_transfer_ = true; } size_t get_buffer_size() { return buffer_size_; } size_t get_memory_size(); bool alloc_buffer() { void *_ptr = allocator_->malloc(sizeof(*buffer_) + buffer_size_); if (_ptr) { buffer_ = (PipeBuffer *) _ptr; sw_memset_zero(&buffer_->info, sizeof(buffer_->info)); return true; } else { return false; } } /** * If use the zend_string_allocator, must manually call this function to release the memory, * otherwise coredump will occur when php shutdown, because zend_string has been released */ void free_buffer() { allocator_->free(buffer_); buffer_ = nullptr; } void pass(SendData *task) { memcpy(&buffer_->info, &task->info, sizeof(buffer_->info)); if (task->info.len > 0) { buffer_->info.flags = SW_EVENT_DATA_PTR; PacketPtr pkt{task->info.len, (char *) task->data}; buffer_->info.len = sizeof(pkt); memcpy(buffer_->data, &pkt, sizeof(pkt)); } } /** * Send data to socket. If the data sent is larger than Server::ipc_max_size, then it is sent in chunks. * Otherwise send it directly. * When sending data in multi-thread environment, must use get_pipe_socket() to separate socket memory. * @return: send success returns true, send failure returns false. */ bool write(network::Socket *sock, SendData *packet); /** * Receive data from socket, if only one chunk is received, packet will be saved in packet_pool. * Then continue to listen to readable events, waiting for more chunks. * @return: >0: receive a complete packet, 0: continue to wait for data, -1: an error occurred */ ssize_t read(network::Socket *sock); /** * Receive data from pipeline, and store data to buffer * @return: >0: receive a complete packet, 0: continue to wait for data, -1: an error occurred */ ssize_t read_with_buffer(network::Socket *sock); /** * The last chunk of data has been received, return address and length, start processing this packet. */ PacketPtr get_packet() const; PipeBuffer *get_buffer() { return buffer_; } /** * Pop the data memory address to the outer layer, no longer managed by MessageBus */ char *move_packet() { uint64_t msg_id = buffer_->info.msg_id; auto iter = packet_pool_.find(msg_id); if (iter != packet_pool_.end()) { auto str = iter->second.get(); char *val = str->str; str->str = nullptr; return val; } else { return nullptr; } } /** * The processing of this data packet has been completed, and the relevant memory has been released */ void pop() { if (buffer_->is_end()) { packet_pool_.erase(buffer_->info.msg_id); } } /** * It is possible to operate the same pipe in multiple threads. * Each thread must have a unique buffer and the socket memory must be separated. */ network::Socket *get_pipe_socket(network::Socket *sock) { return pipe_sockets_[sock->get_fd()]; } void init_pipe_socket(network::Socket *sock); }; } // namespace swoole
SILENT KILLER Tool