$26 GRAYBYTE WORDPRESS FILE MANAGER $65

SERVER : premium201.web-hosting.com #1 SMP Wed Mar 26 12:08:09 UTC 2025
SERVER IP : 104.21.43.35 | ADMIN IP 216.73.216.157
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : mail

/opt/alt/php83/usr/include/php/ext/swoole/include/

HOME
Current File : /opt/alt/php83/usr/include/php/ext/swoole/include//swoole_message_bus.h
/*
  +----------------------------------------------------------------------+
  | 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       |
  | [email protected] so we can mail you a copy immediately.            |
  +----------------------------------------------------------------------+
  | Author: Tianfeng Han  <[email protected]>                             |
  +----------------------------------------------------------------------+
*/

#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


Current_dir [ NOT WRITEABLE ] Document_root [ NOT WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
1 Jan 1970 12.00 AM
root / root
0
swoole.h
24.834 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_api.h
3.429 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_asm_context.h
2.281 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_async.h
3.611 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_atomic.h
3.717 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_base64.h
1.294 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_buffer.h
2.233 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_c_api.h
2.076 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_channel.h
2.337 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_client.h
8.646 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_config.h
8.877 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_coroutine.h
9.975 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_coroutine_c_api.h
5.825 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_coroutine_channel.h
4.184 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_coroutine_context.h
2.747 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_coroutine_socket.h
18.781 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_coroutine_system.h
3.867 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_dtls.h
2.405 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_error.h
6.108 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_file.h
4.43 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_file_hook.h
3.837 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_hash.h
9.69 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_heap.h
1.785 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_http.h
6.989 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_http2.h
8.383 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_iouring.h
3.098 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_lock.h
3.39 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_log.h
15.337 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_lru_cache.h
3.169 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_memory.h
2.747 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_message_bus.h
6.024 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_mime_type.h
1.441 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_mqtt.h
2.176 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_msg_queue.h
1.924 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_pipe.h
2.637 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_process_pool.h
9.938 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_protocol.h
5.167 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_proxy.h
2.873 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_reactor.h
11.249 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_redis.h
2.092 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_server.h
43.944 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_signal.h
1.721 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_socket.h
19.039 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_socket_hook.h
2.23 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_ssl.h
4.943 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_static_handler.h
4.702 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_string.h
8.869 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_table.h
7.346 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_thread.h
2.227 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_timer.h
4.127 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_util.h
6.606 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_version.h
2.211 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_websocket.h
4.529 KB
12 Mar 2025 2.14 PM
root / linksafe
0644
swoole_wheel_timer.h
2.479 KB
12 Mar 2025 2.14 PM
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025 CONTACT ME
Static GIF