summaryrefslogtreecommitdiffstats
path: root/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api
diff options
context:
space:
mode:
Diffstat (limited to 'fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api')
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/CMakeLists.txt195
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/README.md212
-rwxr-xr-xfluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/sample_test_run.py141
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/CMakeLists.txt91
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/addr_resolve.c69
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/inc/.gitkeep0
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/multicast_client.c135
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/multicast_server.c120
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/send_recv.c219
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/socket_opts.c299
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/socket_utils.h48
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/tcp_client.c106
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/tcp_server.c152
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/timeout_client.c111
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/timeout_server.c69
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/udp_client.c84
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/udp_server.c122
17 files changed, 2173 insertions, 0 deletions
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/CMakeLists.txt b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/CMakeLists.txt
new file mode 100644
index 000000000..e68a63eb0
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/CMakeLists.txt
@@ -0,0 +1,195 @@
+# Copyright (C) 2019 Intel Corporation. All rights reserved.
+# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+
+cmake_minimum_required(VERSION 3.14)
+
+include(CheckPIESupported)
+
+project(socket_api_sample)
+
+#######################################
+## Detect toolchain
+#######################################
+message(CHECK_START "Detecting WASI-SDK at /opt/wasi-sdk")
+if(NOT (DEFINED WASI_SDK_DIR OR DEFINED CACHE{WASI_SDK_DIR}))
+ find_path(WASI_SDK_PARENT
+ wasi-sdk
+ PATHS /opt
+ NO_DEFAULT_PATH
+ NO_CMAKE_FIND_ROOT_PATH
+ )
+ if(WASI_SDK_PARENT)
+ set(WASI_SDK_DIR ${WASI_SDK_PARENT}/wasi-sdk)
+ endif()
+endif()
+if(WASI_SDK_DIR)
+ message(CHECK_PASS "found")
+else()
+ message(CHECK_FAIL "not found")
+endif()
+
+if(NOT EXISTS ${WASI_SDK_DIR})
+ message(FATAL_ERROR "Please install WASI-SDK under /opt/wasi-sdk")
+endif()
+
+message(CHECK_START "Detecting WASI_TOOLCHAIN_FILE at ${WASI_SDK_DIR}")
+find_file(WASI_TOOLCHAIN_FILE
+ wasi-sdk.cmake
+ PATHS "${WASI_SDK_DIR}/share/cmake"
+ NO_DEFAULT_PATH
+ NO_CMAKE_FIND_ROOT_PATH
+)
+if(WASI_TOOLCHAIN_FILE)
+ message(CHECK_PASS "found")
+else()
+ message(CHECK_FAIL "not found")
+endif()
+
+if(WASI_TOOLCHAIN_FILE-NOTFOUND)
+ message(FATAL_ERROR "Can not find wasi-sdk.cmake under ${WASI_SDK_DIR}")
+endif()
+
+message(CHECK_START "Detecting WASI_SYS_ROOT at ${WASI_SDK_DIR}")
+find_path(WASI_SYS_ROOT
+ wasi-sysroot
+ PATHS "${WASI_SDK_DIR}/share"
+ NO_DEFAULT_PATH
+ NO_CMAKE_FIND_ROOT_PATH
+)
+if(WASI_SYS_ROOT)
+ message(CHECK_PASS "found")
+ set(WASI_SYS_ROOT ${WASI_SYS_ROOT}/wasi-sysroot)
+else()
+ message(CHECK_FAIL "not found")
+endif()
+
+if(WASI_SYS_ROOT-NOTFOUND)
+ message(FATAL_ERROR "Can not find wasi-sysroot/ under ${WASI_SDK_DIR}")
+endif()
+
+message(STATUS "WASI_SDK_DIR is ${WASI_SDK_DIR}")
+message(STATUS "WASI_TOOLCHAIN_FILE is ${WASI_TOOLCHAIN_FILE}")
+message(STATUS "WASI_SYS_ROOT is ${WASI_SYS_ROOT}")
+
+###############################################################
+## Build socket applications of wasm version and native version
+###############################################################
+include(ExternalProject)
+
+ExternalProject_Add(wasm-app
+ SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src
+ UPDATE_COMMAND ""
+ PATCH_COMMAND ""
+ CONFIGURE_COMMAND ${CMAKE_COMMAND} -E copy
+ ${CMAKE_CURRENT_SOURCE_DIR}/../../wamr-sdk/app/libc-builtin-sysroot/include/pthread.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/inc
+ && ${CMAKE_COMMAND}
+ -DWASI_SDK_PREFIX=${WASI_SDK_DIR}
+ -DCMAKE_TOOLCHAIN_FILE=${WASI_TOOLCHAIN_FILE}
+ -DCMAKE_SYSROOT=${WASI_SYS_ROOT}
+ ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src
+ BUILD_COMMAND ${CMAKE_COMMAND} --build .
+ INSTALL_COMMAND ${CMAKE_COMMAND} -E copy
+ addr_resolve.wasm ${CMAKE_BINARY_DIR}
+ tcp_client.wasm ${CMAKE_BINARY_DIR}
+ tcp_server.wasm ${CMAKE_BINARY_DIR}
+ send_recv.wasm ${CMAKE_BINARY_DIR}
+ socket_opts.wasm ${CMAKE_BINARY_DIR}
+ udp_client.wasm ${CMAKE_BINARY_DIR}
+ udp_server.wasm ${CMAKE_BINARY_DIR}
+ multicast_client.wasm ${CMAKE_BINARY_DIR}
+ multicast_server.wasm ${CMAKE_BINARY_DIR}
+ timeout_client.wasm ${CMAKE_BINARY_DIR}
+ timeout_server.wasm ${CMAKE_BINARY_DIR}
+)
+
+add_executable(tcp_server ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/tcp_server.c)
+target_link_libraries(tcp_server pthread)
+
+add_executable(tcp_client ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/tcp_client.c)
+
+add_executable(send_recv ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/send_recv.c)
+target_link_libraries(send_recv pthread)
+
+add_executable(addr_resolve ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/addr_resolve.c)
+
+add_executable(socket_opts ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/socket_opts.c)
+
+add_executable(udp_client ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/udp_client.c)
+
+add_executable(udp_server ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/udp_server.c)
+
+add_executable(multicast_client ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/multicast_client.c)
+
+add_executable(multicast_server ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/multicast_server.c)
+
+add_executable(timeout_client ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/timeout_client.c)
+
+add_executable(timeout_server ${CMAKE_CURRENT_SOURCE_DIR}/wasm-src/timeout_server.c)
+
+############################################
+## Build iwasm with wasi and pthread support
+############################################
+string (TOLOWER ${CMAKE_HOST_SYSTEM_NAME} WAMR_BUILD_PLATFORM)
+if (APPLE)
+ add_definitions(-DBH_PLATFORM_DARWIN)
+endif ()
+
+# Reset linker flags
+set(CMAKE_SHARED_LIBRARY_LINK_C_FLAGS "")
+set(CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS "")
+
+# Set WAMR features
+
+# Set WAMR_BUILD_TARGET, currently values supported:
+# "X86_64", "AMD_64", "X86_32", "AARCH64[sub]", "ARM[sub]", "THUMB[sub]",
+# "MIPS", "XTENSA", "RISCV64[sub]", "RISCV32[sub]"
+if (NOT DEFINED WAMR_BUILD_TARGET)
+ if (CMAKE_SYSTEM_PROCESSOR MATCHES "^(arm64|aarch64)")
+ set (WAMR_BUILD_TARGET "AARCH64")
+ elseif (CMAKE_SYSTEM_PROCESSOR STREQUAL "riscv64")
+ set (WAMR_BUILD_TARGET "RISCV64")
+ elseif (CMAKE_SIZEOF_VOID_P EQUAL 8)
+ # Build as X86_64 by default in 64-bit platform
+ set (WAMR_BUILD_TARGET "X86_64")
+ elseif (CMAKE_SIZEOF_VOID_P EQUAL 4)
+ # Build as X86_32 by default in 32-bit platform
+ set (WAMR_BUILD_TARGET "X86_32")
+ else ()
+ message(SEND_ERROR "Unsupported build target platform!")
+ endif ()
+endif ()
+
+if (NOT CMAKE_BUILD_TYPE)
+ set (CMAKE_BUILD_TYPE Release)
+endif ()
+
+set(WAMR_BUILD_INTERP 1)
+set(WAMR_BUILD_FAST_INTERP 1)
+set(WAMR_BUILD_AOT 1)
+set(WAMR_BUILD_JIT 0)
+set(WAMR_BUILD_LIBC_BUILTIN 1)
+set(WAMR_BUILD_LIBC_WASI 1)
+set(WAMR_BUILD_LIB_PTHREAD 1)
+
+# compiling and linking flags
+if (NOT (CMAKE_C_COMPILER MATCHES ".*clang.*" OR CMAKE_C_COMPILER_ID MATCHES ".*Clang"))
+ set (CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--gc-sections")
+endif ()
+set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -Wextra -Wformat -Wformat-security")
+
+# build vmlib static lib
+set(WAMR_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR}/../..)
+include (${WAMR_ROOT_DIR}/build-scripts/runtime_lib.cmake)
+add_library(vmlib ${WAMR_RUNTIME_LIB_SOURCE})
+
+# build iwasm
+include (${SHARED_DIR}/utils/uncommon/shared_uncommon.cmake)
+set (RUNTIME_SOURCE_ALL
+ ${CMAKE_CURRENT_LIST_DIR}/../../product-mini/platforms/linux/main.c
+ ${UNCOMMON_SHARED_SOURCE}
+)
+add_executable (iwasm ${RUNTIME_SOURCE_ALL})
+check_pie_supported()
+set_target_properties (iwasm PROPERTIES POSITION_INDEPENDENT_CODE ON)
+target_link_libraries(iwasm vmlib -lpthread -lm -ldl)
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/README.md b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/README.md
new file mode 100644
index 000000000..a3bc5ac15
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/README.md
@@ -0,0 +1,212 @@
+# "socket-api" sample introduction
+
+This sample demonstrates how to use WAMR socket-api to develop wasm network applications.
+Two wasm applications are provided: tcp-server and tcp-client, and this sample demonstrates
+how they communicate with each other.
+
+## Preparation
+
+Please install WASI SDK, download the [wasi-sdk release](https://github.com/CraneStation/wasi-sdk/releases) and extract the archive to default path `/opt/wasi-sdk`.
+And install wabt, download the [wabt release](https://github.com/WebAssembly/wabt/releases) and extract the archive to default path `/opt/wabt`
+
+## Build the sample
+
+```bash
+mkdir build
+cd build
+cmake ..
+make
+```
+
+`iwasm` and the following Wasm modules (along with their corresponding native version) will be generated:
+ * `addr_resolve.wasm`, `addr_resolve`
+ * `send_recv.wasm`, `send_recv`
+ * `socket_opts.wasm`, `socket_opts`
+ * `tcp_client.wasm`, `tcp_client`
+ * `tcp_server.wasm`, `tcp_server`
+ * `udp_client.wasm`, `udp_client`
+ * `udp_server.wasm`, `udp_server`
+
+> Note that iwasm is built with libc-wasi and lib-pthread enabled.
+
+## Run workload
+
+### TCP client/server
+
+Start the tcp server, which opens port 1234 and waits for clients to connect.
+
+```bash
+cd build
+./iwasm --addr-pool=0.0.0.0/15 tcp_server.wasm
+```
+
+Start the tcp client, which connects the server and receives message.
+
+```bash
+cd build
+./iwasm --addr-pool=127.0.0.1/15 tcp_client.wasm
+```
+
+The output of client is like:
+
+```bash
+[Client] Create socket
+[Client] Connect socket
+[Client] Client receive
+[Client] 115 bytes received:
+Buffer recieved:
+Say Hi from the Server
+Say Hi from the Server
+Say Hi from the Server
+Say Hi from the Server
+Say Hi from the Server
+
+[Client] BYE
+```
+
+`send_recv.wasm` contains a thread as a server and a thread as a client. They
+send and receive data via 127.0.0.1:1234.
+
+```bash
+$ ./iwasm --addr-pool=127.0.0.1/0 ./send_recv.wasm
+```
+
+The output is:
+
+```bash
+Server is online ...
+Client is running...
+Start receiving.
+Start sending.
+Send 106 bytes successfully!
+Receive 106 bytes successlly!
+Data:
+ The stars shine down
+ It brings us light
+ Light comes down
+ To make us paths
+ It watches us
+ And mourns for us
+```
+
+### Socket options
+
+`socket_opts.wasm` shows an example of getting and setting various supported socket options
+```bash
+$ ./iwasm socket_opts.wasm
+```
+The output is:
+```bash
+[Client] Create TCP socket
+[Client] Create UDP socket
+[Client] Create UDP IPv6 socket
+setsockopt SO_RCVTIMEO result is expected
+getsockopt SO_RCVTIMEO result is expected
+...
+[Client] Close sockets
+```
+
+The `timeout_client.wasm` and `timeout_server.wasm` examples demonstrate socket send and receive timeouts using the socket options. Start the server, then start the client.
+
+```bash
+$ ./iwasm --addr-pool=0.0.0.0/15 timeout_server.wasm
+```
+
+The output is:
+
+```bash
+Wait for client to connect
+Client connected, sleeping for 10s
+Shuting down
+```
+
+```bash
+$ ./iwasm --addr-pool=127.0.0.1/15 timeout_client.wasm
+```
+
+The output is:
+
+```bash
+Waiting on recv, which should timeout
+Waiting on send, which should timeout
+Success. Closing socket
+```
+
+The `multicast_client` and `multicast_server` examples demonstrate receiving multicast packets in WASM. Start the client and then the server with a multicast IP address and port.
+
+```bash
+$ ./iwasm --addr-pool=0.0.0.0/0,::/0 multicast_client.wasm <Multicast IP> <Port>
+$ ./iwasm --addr-pool=0.0.0.0/0,::/0 multicast_client.wasm 224.0.0.1
+$ ./iwasm --addr-pool=0.0.0.0/0,::/0 multicast_client.wasm FF02:113D:6FDD:2C17:A643:FFE2:1BD1:3CD2
+```
+
+The output should be
+
+```bash
+Joined multicast group. Waiting for datagram...
+Reading datagram message...OK.
+The message from multicast server is: "Test message"
+```
+
+```bash
+$ ./multicast_server <Multicast IP> <Port>
+$ ./multicast_server 224.0.0.1
+$ ./multicast_server FF02:113D:6FDD:2C17:A643:FFE2:1BD1:3CD2
+```
+
+The output should be
+
+```bash
+Datagram sent
+```
+
+### Domain name server resolution
+
+`addr_resolve.wasm` demonstrates the usage of resolving a domain name
+```
+$ ./iwasm --allow-resolve=*.com addr_resolve.wasm github.com
+```
+
+The command displays the host name and its corresponding IP address:
+```
+Host: github.com
+IPv4 address: 140.82.121.4 (TCP)
+```
+
+### UDP client/server
+
+Start the UDP server, which opens port 1234 and waits for clients to send a message.
+
+```bash
+cd build
+./iwasm --addr-pool=0.0.0.0/15 udp_server.wasm
+```
+
+Start the tcp client, which sends a message to the server and waits for the response.
+
+```bash
+cd build
+./iwasm --addr-pool=127.0.0.1/15 udp_client.wasm
+```
+
+The output of client is like:
+
+```bash
+[Client] Create socket
+[Client] Client send
+[Client] Client receive
+[Client] Buffer recieved: Hello from server
+[Client] BYE
+```
+
+The output of the server is like:
+```
+[Server] Create socket
+[Server] Bind socket
+[Server] Wait for clients to connect ..
+[Server] received 17 bytes from 127.0.0.1:60927: Hello from client
+```
+
+## Documentation
+
+Refer to [socket api document](../../doc/socket_api.md) for more details.
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/sample_test_run.py b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/sample_test_run.py
new file mode 100755
index 000000000..ec0060281
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/sample_test_run.py
@@ -0,0 +1,141 @@
+#!/usr/bin/env python3
+#
+# Copyright (C) 2023 Intel Corporation. All rights reserved.
+# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+#
+
+import argparse
+import shlex
+import subprocess
+import sys
+import time
+import traceback
+import glob
+
+WAMRC_CMD = "../../wamr-compiler/build/wamrc"
+
+def compile_wasm_files_to_aot(wasm_apps_dir):
+ wasm_files = glob.glob(wasm_apps_dir + "/*.wasm")
+ print("Compile wasm app into aot files")
+ for wasm_file in wasm_files:
+ aot_file = wasm_file[0 : len(wasm_file) - 5] + ".aot";
+ cmd = [ WAMRC_CMD, "-o", aot_file, wasm_file ]
+ subprocess.check_call(cmd)
+
+def start_server(cmd, cwd):
+ app_server = subprocess.Popen(shlex.split(cmd), cwd=cwd)
+ return app_server
+
+def run_cmd(cmd, cwd):
+ qry_prc = subprocess.run(
+ shlex.split(cmd), cwd=cwd, check=False, capture_output=True
+ )
+ if (qry_prc.returncode != 0):
+ print("Run {} failed, return {}".format(cmd), qry_prc.returncode)
+ return
+ print("return code: {}, output:\n{}".format(qry_prc.returncode,
+ qry_prc.stdout.decode()))
+
+def main():
+ """
+ GO!GO!!GO!!!
+ """
+ parser = argparse.ArgumentParser(description="run the sample and examine outputs")
+ parser.add_argument("working_directory", type=str)
+ parser.add_argument("--aot", action='store_true', help="Test with AOT")
+ args = parser.parse_args()
+
+ test_aot = False
+ suffix = ".wasm"
+ if not args.aot:
+ print("Test with interpreter mode")
+ else:
+ print("Test with AOT mode")
+ test_aot = True
+ suffix = ".aot"
+ wasm_apps_dir = args.working_directory
+ compile_wasm_files_to_aot(wasm_apps_dir)
+
+ ret = 1
+ app_server = None
+ try:
+ print("\n================================")
+ print("Test TCP server and client")
+ cmd = "./iwasm --addr-pool=0.0.0.0/15 tcp_server" + suffix
+ app_server = start_server(cmd, args.working_directory)
+ # wait for a second
+ time.sleep(1)
+ cmd = "./iwasm --addr-pool=127.0.0.1/15 tcp_client" + suffix
+ for i in range(5):
+ run_cmd(cmd, args.working_directory)
+
+ print("\n================================")
+ print("Test UDP server and client")
+ cmd = "./iwasm --addr-pool=0.0.0.0/15 udp_server" + suffix
+ app_server = start_server(cmd, args.working_directory)
+ # wait for a second
+ time.sleep(1)
+ cmd = "./iwasm --addr-pool=127.0.0.1/15 udp_client" + suffix
+ for i in range(5):
+ run_cmd(cmd, args.working_directory)
+
+ print("\n=====================================================")
+ print("Sleep 80 seconds to wait TCP server port actually close")
+ time.sleep(80)
+
+ print("\n================================")
+ print("Test send and receive")
+ cmd = "./iwasm --addr-pool=127.0.0.1/0 ./send_recv" + suffix
+ run_cmd(cmd, args.working_directory)
+
+ print("\n================================")
+ print("Test socket options")
+ cmd = "./iwasm socket_opts" + suffix
+ run_cmd(cmd, args.working_directory)
+
+ print("\n================================")
+ print("Test timeout server and client")
+ cmd = "./iwasm --addr-pool=0.0.0.0/15 timeout_server" + suffix
+ app_server = start_server(cmd, args.working_directory)
+ # wait for a second
+ time.sleep(1)
+ cmd = "./iwasm --addr-pool=127.0.0.1/15 timeout_client" + suffix
+ run_cmd(cmd, args.working_directory)
+
+ print("\n==========================================")
+ print("Test multicast_client and multicast_server")
+ cmd = "./iwasm --addr-pool=0.0.0.0/0,::/0 multicast_client.wasm 224.0.0.1"
+ app_server = start_server(cmd, args.working_directory)
+ # wait for a second
+ time.sleep(1)
+ cmd = "./multicast_server 224.0.0.1"
+ run_cmd(cmd, args.working_directory)
+
+ cmd = "./iwasm --addr-pool=0.0.0.0/0,::/0 multicast_client.wasm FF02:113D:6FDD:2C17:A643:FFE2:1BD1:3CD2"
+ app_server = start_server(cmd, args.working_directory)
+ # wait for a second
+ time.sleep(1)
+ cmd = "./multicast_server FF02:113D:6FDD:2C17:A643:FFE2:1BD1:3CD2"
+ run_cmd(cmd, args.working_directory)
+
+ print("\n================================")
+ print("Test address resolving")
+ cmd = "./iwasm --allow-resolve=*.com addr_resolve.wasm github.com"
+ cmd = "./multicast_server FF02:113D:6FDD:2C17:A643:FFE2:1BD1:3CD2"
+ run_cmd(cmd, args.working_directory)
+
+ # wait for a second
+ time.sleep(1)
+
+ print("--> All pass")
+ ret = 0
+ except AssertionError:
+ traceback.print_exc()
+ finally:
+ app_server.kill()
+
+ return ret
+
+
+if __name__ == "__main__":
+ sys.exit(main())
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/CMakeLists.txt b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/CMakeLists.txt
new file mode 100644
index 000000000..8f11e0a6b
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/CMakeLists.txt
@@ -0,0 +1,91 @@
+# Copyright (C) 2019 Intel Corporation. All rights reserved.
+# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+
+cmake_minimum_required(VERSION 2.8...3.18)
+project(socket_api_sample_wasm_app)
+
+message(CHECK_START "Detecting WABT")
+if(NOT (DEFINED WABT_DIR OR DEFINED CACHE{WABT_DIR}))
+ find_path(WABT_DIR
+ wabt
+ PATHS /opt
+ NO_DEFAULT_PATH
+ NO_CMAKE_FIND_ROOT_PATH
+ )
+ if(DEFINED WABT_DIR)
+ set(WABT_DIR ${WABT_DIR}/wabt)
+ endif()
+endif()
+if(WABT_DIR)
+ message(CHECK_PASS "found")
+else()
+ message(CHECK_FAIL "not found")
+endif()
+
+message(CHECK_START "Detecting WASM_OBJDUMP at ${WABT_DIR}")
+find_program(WASM_OBJDUMP
+ wasm-objdump
+ PATHS "${WABT_DIR}/bin"
+ NO_DEFAULT_PATH
+ NO_CMAKE_FIND_ROOT_PATH
+)
+if(WASM_OBJDUMP)
+ message(CHECK_PASS "found")
+else()
+ message(CHECK_FAIL "not found")
+endif()
+
+set(SRC ${CMAKE_CURRENT_SOURCE_DIR})
+
+include(${CMAKE_CURRENT_SOURCE_DIR}/../../../core/iwasm/libraries/lib-socket/lib_socket_wasi.cmake)
+
+function(COMPILE_WITH_CLANG SOURCE_FILE)
+ get_filename_component(FILE_NAME ${SOURCE_FILE} NAME_WLE)
+
+ set(WASM_MODULE ${FILE_NAME}.wasm)
+
+ set(MAIN_TARGET_NAME MODULE_${FILE_NAME})
+
+ add_executable(${MAIN_TARGET_NAME} ${SOURCE_FILE})
+ set_target_properties(${MAIN_TARGET_NAME} PROPERTIES OUTPUT_NAME ${WASM_MODULE})
+ target_include_directories(${MAIN_TARGET_NAME} PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/inc)
+ target_compile_options(${MAIN_TARGET_NAME} INTERFACE -pthread)
+ target_link_libraries(${MAIN_TARGET_NAME} socket_wasi_ext)
+ target_link_options(${MAIN_TARGET_NAME} PRIVATE
+ LINKER:--export=__heap_base
+ LINKER:--export=__data_end
+ LINKER:--export=malloc
+ LINKER:--export=free
+ LINKER:--shared-memory,--max-memory=10485760
+ LINKER:--no-check-features
+ LINKER:--allow-undefined
+ )
+
+ if(EXISTS ${WASM_OBJDUMP})
+ message(STATUS "Dumping ${WASM_MODULE}...")
+ set(WASM_DUMP ${WASM_MODULE}.dump)
+ set(DUMP_TARGET_NAME DUMP_${FILE_NAME})
+
+ add_custom_command(OUTPUT ${WASM_DUMP}
+ COMMAND ${WASM_OBJDUMP} -dx ${WASM_MODULE} > ${WASM_DUMP}
+ COMMENT "Dumping ${WASM_MODULE}..."
+ DEPENDS ${MAIN_TARGET_NAME}
+ )
+
+ add_custom_target(${DUMP_TARGET_NAME} ALL
+ DEPENDS ${WASM_DUMP}
+ )
+ endif()
+endfunction()
+
+compile_with_clang(tcp_server.c)
+compile_with_clang(tcp_client.c)
+compile_with_clang(send_recv.c)
+compile_with_clang(addr_resolve.c)
+compile_with_clang(socket_opts.c)
+compile_with_clang(udp_client.c)
+compile_with_clang(udp_server.c)
+compile_with_clang(multicast_client.c)
+compile_with_clang(multicast_server.c)
+compile_with_clang(timeout_client.c)
+compile_with_clang(timeout_server.c)
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/addr_resolve.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/addr_resolve.c
new file mode 100644
index 000000000..87734dea3
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/addr_resolve.c
@@ -0,0 +1,69 @@
+/*
+ * Copyright (C) 2022 Amazon.com, Inc. or its affiliates. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+
+#include <arpa/inet.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#else
+#include <netdb.h>
+#endif
+
+int
+lookup_host(const char *host)
+{
+ struct addrinfo hints, *res, *result;
+ int errcode;
+ char addrstr[100];
+ void *ptr;
+
+ memset(&hints, 0, sizeof(hints));
+ hints.ai_family = AF_INET;
+ hints.ai_socktype = SOCK_STREAM;
+
+ errcode = getaddrinfo(host, NULL, &hints, &result);
+ if (errcode != 0) {
+ perror("getaddrinfo");
+ return -1;
+ }
+
+ res = result;
+
+ printf("Host: %s\n", host);
+ while (res) {
+ switch (res->ai_family) {
+ case AF_INET:
+ ptr = &((struct sockaddr_in *)res->ai_addr)->sin_addr;
+ break;
+ case AF_INET6:
+ ptr = &((struct sockaddr_in6 *)res->ai_addr)->sin6_addr;
+ break;
+ default:
+ printf("Unsupported address family: %d\n", res->ai_family);
+ continue;
+ }
+ inet_ntop(res->ai_family, ptr, addrstr, 100);
+ printf("IPv%d address: %s (%s)\n", res->ai_family == AF_INET6 ? 6 : 4,
+ addrstr, res->ai_socktype == SOCK_STREAM ? "TCP" : "UDP");
+ res = res->ai_next;
+ }
+
+ freeaddrinfo(result);
+
+ return EXIT_SUCCESS;
+}
+
+int
+main(int argc, char *argv[])
+{
+ if (argc < 2) {
+ printf("Usage: %s DOMAIN\n", argv[0]);
+ return EXIT_FAILURE;
+ }
+
+ return lookup_host(argv[1]);
+}
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/inc/.gitkeep b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/inc/.gitkeep
new file mode 100644
index 000000000..e69de29bb
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/inc/.gitkeep
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/multicast_client.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/multicast_client.c
new file mode 100644
index 000000000..43201dcbd
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/multicast_client.c
@@ -0,0 +1,135 @@
+/*
+ * Copyright (C) 2022 Amazon.com Inc. or its affiliates. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+
+#include <arpa/inet.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+static void
+init_sockaddr_inet(struct sockaddr_in *addr)
+{
+ addr->sin_family = AF_INET;
+ addr->sin_port = htons(1234);
+}
+
+static void
+init_sockaddr_inet6(struct sockaddr_in6 *addr)
+{
+ addr->sin6_family = AF_INET6;
+ addr->sin6_port = htons(1234);
+}
+
+static int
+get_ip_addr_type(char *addr, char *buf)
+{
+ if (inet_pton(AF_INET6, addr, buf)) {
+ return AF_INET6;
+ }
+ if (inet_pton(AF_INET, addr, buf)) {
+ return AF_INET;
+ }
+ return -1;
+}
+
+static int
+is_valid_addr_type(int addr_type)
+{
+ return !(addr_type == -1
+ || (addr_type != AF_INET && addr_type != AF_INET6));
+}
+
+int
+main(int argc, char *argv[])
+{
+ struct ipv6_mreq ipv6_group;
+ struct ip_mreq ipv4_group;
+ int sd;
+ int datalen;
+ char databuf[1024] = { 0 };
+ char multicast_addr_buffer[16];
+ struct sockaddr_storage local_address = { 0 };
+ int addr_type = -1;
+ int read_result;
+ int bool_opt = 1;
+
+ if (argc < 2) {
+ printf("Usage is <Multicast IP>\n");
+ return EXIT_FAILURE;
+ }
+
+ addr_type = get_ip_addr_type(argv[1], multicast_addr_buffer);
+
+ if (!is_valid_addr_type(addr_type)) {
+ printf("Not a valid ipv4 or ipv6 address\n");
+ return EXIT_FAILURE;
+ }
+
+ if ((sd = socket(addr_type, SOCK_DGRAM, 0)) == -1) {
+ perror("Failed opening socket");
+ return EXIT_FAILURE;
+ }
+
+ if (setsockopt(sd, SOL_SOCKET, SO_REUSEADDR, &bool_opt, sizeof(bool_opt))
+ == -1) {
+ perror("Failed setting SO_REUSEADDR");
+ goto fail;
+ }
+
+ if (addr_type == AF_INET) {
+ init_sockaddr_inet((struct sockaddr_in *)&local_address);
+ memcpy(&(ipv4_group.imr_multiaddr), multicast_addr_buffer, 4);
+ ipv4_group.imr_interface.s_addr = htonl(INADDR_ANY);
+
+ if (setsockopt(sd, IPPROTO_IP, IP_ADD_MEMBERSHIP, &ipv4_group,
+ sizeof(ipv4_group))
+ == -1) {
+ perror("Failed joining IPv4 multicast group");
+ goto fail;
+ }
+ }
+ else {
+ init_sockaddr_inet6((struct sockaddr_in6 *)&local_address);
+ memcpy(&(ipv6_group.ipv6mr_multiaddr), multicast_addr_buffer, 16);
+ ipv6_group.ipv6mr_interface = 0;
+
+ if (setsockopt(sd, IPPROTO_IPV6, IPV6_JOIN_GROUP, &ipv6_group,
+ sizeof(ipv6_group))
+ == -1) {
+ perror("Failed joining IPv6 multicast group");
+ goto fail;
+ }
+ }
+
+ if (bind(sd, (struct sockaddr *)&local_address, sizeof(local_address))
+ == -1) {
+ perror("Failed binding socket");
+ goto fail;
+ }
+
+ printf("Joined multicast group. Waiting for datagram...\n");
+
+ datalen = sizeof(databuf) - 1;
+ read_result = read(sd, databuf, datalen);
+
+ if (read_result < 0) {
+ perror("Failed binding socket");
+ goto fail;
+ }
+
+ printf("Reading datagram message...OK.\n");
+ printf("The message from multicast server is: \"%s\"\n", databuf);
+ close(sd);
+ return EXIT_SUCCESS;
+
+fail:
+ close(sd);
+ return EXIT_FAILURE;
+}
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/multicast_server.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/multicast_server.c
new file mode 100644
index 000000000..cd33557b2
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/multicast_server.c
@@ -0,0 +1,120 @@
+/*
+ * Copyright (C) 2022 Amazon.com Inc. or its affiliates. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+
+#include <arpa/inet.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+static int
+get_ip_addr_type(char *addr, char *buf)
+{
+ if (inet_pton(AF_INET6, addr, buf)) {
+ return AF_INET6;
+ }
+ if (inet_pton(AF_INET, addr, buf)) {
+ return AF_INET;
+ }
+ return -1;
+}
+
+static int
+is_valid_addr_type(int addr_type)
+{
+ return !(addr_type == -1
+ || (addr_type != AF_INET && addr_type != AF_INET6));
+}
+
+static void
+init_sockaddr_inet(struct sockaddr_in *addr, char *addr_buffer)
+{
+ addr->sin_family = AF_INET;
+ addr->sin_port = htons(1234);
+ memcpy(&(addr->sin_addr), addr_buffer, 4);
+}
+
+static void
+init_sockaddr_inet6(struct sockaddr_in6 *addr, char *addr_buffer)
+{
+ addr->sin6_family = AF_INET6;
+ addr->sin6_port = htons(1234);
+ memcpy(&(addr->sin6_addr), addr_buffer, 16);
+}
+
+int
+main(int argc, char *argv[])
+{
+ struct sockaddr_storage addr = { 0 };
+ int sd;
+ char *databuf = "Test message";
+ int datalen = strlen(databuf) + 1;
+ char multicast_addr_buffer[16];
+ int addr_type = -1;
+ int multicast_interface;
+ int bool_opt = 1;
+
+ if (argc < 2) {
+ printf("Usage is <Multicast IP>\n");
+ return EXIT_FAILURE;
+ }
+
+ addr_type = get_ip_addr_type(argv[1], multicast_addr_buffer);
+
+ if (!is_valid_addr_type(addr_type)) {
+ printf("Not a valid ipv4 or ipv6 address\n");
+ return EXIT_FAILURE;
+ }
+
+ if ((sd = socket(addr_type, SOCK_DGRAM, 0)) == -1) {
+ return EXIT_FAILURE;
+ }
+
+ if (setsockopt(sd, SOL_SOCKET, SO_REUSEADDR, &bool_opt, sizeof(bool_opt))
+ == -1) {
+ perror("Failed setting SO_REUSEADDR");
+ goto fail;
+ }
+
+ if (addr_type == AF_INET) {
+ multicast_interface = htonl(INADDR_ANY);
+ if (setsockopt(sd, IPPROTO_IP, IP_MULTICAST_IF,
+ (char *)&multicast_interface,
+ sizeof(multicast_interface))) {
+ perror("Failed setting local interface");
+ goto fail;
+ }
+ init_sockaddr_inet((struct sockaddr_in *)&addr, multicast_addr_buffer);
+ }
+ else {
+ multicast_interface = 0;
+ if (setsockopt(sd, IPPROTO_IPV6, IPV6_MULTICAST_IF,
+ (char *)&multicast_interface,
+ sizeof(multicast_interface))) {
+ perror("Failed setting local interface");
+ goto fail;
+ }
+ init_sockaddr_inet6((struct sockaddr_in6 *)&addr,
+ multicast_addr_buffer);
+ }
+
+ if (sendto(sd, databuf, datalen, 0, (struct sockaddr *)&addr, sizeof(addr))
+ == -1) {
+ perror("Failed sending datagram");
+ goto fail;
+ }
+
+ printf("Datagram sent\n");
+ close(sd);
+ return EXIT_SUCCESS;
+
+fail:
+ close(sd);
+ return EXIT_FAILURE;
+} \ No newline at end of file
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/send_recv.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/send_recv.c
new file mode 100644
index 000000000..0071b2a7b
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/send_recv.c
@@ -0,0 +1,219 @@
+/*
+ * Copyright (C) 2019 Intel Corporation. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+#include <arpa/inet.h>
+#include <assert.h>
+#include <netinet/in.h>
+#include <pthread.h>
+#include <stdbool.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <stdint.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+static pthread_mutex_t lock = { 0 };
+static pthread_cond_t cond = { 0 };
+static bool server_create_failed = false;
+static bool server_is_ready = false;
+
+void *
+run_as_server(void *arg)
+{
+ int sock = -1, on = 1;
+ struct sockaddr_in addr = { 0 };
+ int addrlen = 0;
+ int new_sock = -1;
+ char *buf[] = {
+ "The stars shine down", "It brings us light", "Light comes down",
+ "To make us paths", "It watches us", "And mourns for us",
+ };
+ struct iovec iov[] = {
+ { .iov_base = buf[0], .iov_len = strlen(buf[0]) + 1 },
+ { .iov_base = buf[1], .iov_len = strlen(buf[1]) + 1 },
+ { .iov_base = buf[2], .iov_len = strlen(buf[2]) + 1 },
+ { .iov_base = buf[3], .iov_len = strlen(buf[3]) + 1 },
+ { .iov_base = buf[4], .iov_len = strlen(buf[4]) + 1 },
+ { .iov_base = buf[5], .iov_len = strlen(buf[5]) + 1 },
+ };
+ struct msghdr msg = { .msg_iov = iov, .msg_iovlen = 6 };
+ ssize_t send_len = 0;
+
+ pthread_mutex_lock(&lock);
+ sock = socket(AF_INET, SOCK_STREAM, 0);
+ if (sock < 0) {
+ server_create_failed = true;
+ pthread_cond_signal(&cond);
+ pthread_mutex_unlock(&lock);
+ perror("Create a socket failed");
+ return NULL;
+ }
+
+#ifndef __wasi__
+ if (setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, (char *)&on, sizeof(on))) {
+ server_create_failed = true;
+ pthread_cond_signal(&cond);
+ pthread_mutex_unlock(&lock);
+ perror("Setsockopt failed");
+ goto fail1;
+ }
+#endif
+
+ /* 0.0.0.0:1234 */
+ addr.sin_family = AF_INET;
+ addr.sin_port = htons(1234);
+ addr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
+
+ addrlen = sizeof(addr);
+ if (bind(sock, (struct sockaddr *)&addr, addrlen) < 0) {
+ server_create_failed = true;
+ pthread_cond_signal(&cond);
+ pthread_mutex_unlock(&lock);
+ perror("Bind failed");
+ goto fail1;
+ }
+
+ if (listen(sock, 0) < 0) {
+ server_create_failed = true;
+ pthread_cond_signal(&cond);
+ pthread_mutex_unlock(&lock);
+ perror("Listen failed");
+ goto fail1;
+ }
+
+ server_is_ready = true;
+ pthread_cond_signal(&cond);
+ pthread_mutex_unlock(&lock);
+
+ printf("Server is online ... \n");
+
+ new_sock = accept(sock, (struct sockaddr *)&addr, (socklen_t *)&addrlen);
+ if (new_sock < 0) {
+ perror("Accept failed");
+ goto fail1;
+ }
+
+ printf("Start sending. \n");
+ send_len = sendmsg(new_sock, &msg, 0);
+ if (send_len < 0) {
+ perror("Sendmsg failed");
+ goto fail2;
+ }
+ printf("Send %ld bytes successfully!\n", send_len);
+
+fail2:
+ close(new_sock);
+fail1:
+ shutdown(sock, SHUT_RD);
+ close(sock);
+ return NULL;
+}
+
+void *
+run_as_client(void *arg)
+{
+ int sock = -1;
+ struct sockaddr_in addr = { 0 };
+ /* buf of server is 106 bytes */
+ char buf[110] = { 0 };
+ struct iovec iov = { .iov_base = buf, .iov_len = sizeof(buf) };
+ struct msghdr msg = { .msg_iov = &iov, .msg_iovlen = 1 };
+ ssize_t recv_len = 0;
+
+ pthread_mutex_lock(&lock);
+ while (!server_create_failed && !server_is_ready) {
+ pthread_cond_wait(&cond, &lock);
+ }
+ pthread_mutex_unlock(&lock);
+
+ if (server_create_failed) {
+ return NULL;
+ }
+
+ printf("Client is running...\n");
+ sock = socket(AF_INET, SOCK_STREAM, 0);
+ if (sock < 0) {
+ perror("Create a socket failed");
+ return NULL;
+ }
+
+ /* 127.0.0.1:1234 */
+ addr.sin_family = AF_INET;
+ addr.sin_port = htons(1234);
+ addr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
+
+ if (connect(sock, (struct sockaddr *)&addr, sizeof(addr)) < 0) {
+ perror("Connect failed");
+ goto fail;
+ }
+
+ printf("Start receiving. \n");
+ recv_len = recvmsg(sock, &msg, 0);
+ if (recv_len < 0) {
+ perror("Recvmsg failed");
+ goto fail;
+ }
+
+ printf("Receive %ld bytes successlly!\n", recv_len);
+ assert(recv_len == 106);
+
+ printf("Data:\n");
+ char *s = msg.msg_iov->iov_base;
+ while (strlen(s) > 0) {
+ printf(" %s\n", s);
+ s += strlen(s) + 1;
+ }
+
+fail:
+ shutdown(sock, SHUT_RD);
+ close(sock);
+ return NULL;
+}
+
+int
+main(int argc, char *argv[])
+{
+ pthread_t cs[2] = { 0 };
+ uint8_t i = 0;
+ int ret = EXIT_SUCCESS;
+
+ if (pthread_mutex_init(&lock, NULL)) {
+ perror("Initialize mutex failed");
+ ret = EXIT_FAILURE;
+ goto RETURN;
+ }
+
+ if (pthread_cond_init(&cond, NULL)) {
+ perror("Initialize condition failed");
+ ret = EXIT_FAILURE;
+ goto DESTROY_MUTEX;
+ }
+
+ if (pthread_create(&cs[0], NULL, run_as_server, NULL)) {
+ perror("Create a server thread failed");
+ ret = EXIT_FAILURE;
+ goto DESTROY_COND;
+ }
+
+ if (pthread_create(&cs[1], NULL, run_as_client, NULL)) {
+ perror("Create a client thread failed");
+ ret = EXIT_FAILURE;
+ goto DESTROY_COND;
+ }
+
+ for (i = 0; i < 2; i++) {
+ pthread_join(cs[i], NULL);
+ }
+
+DESTROY_COND:
+ pthread_cond_destroy(&cond);
+DESTROY_MUTEX:
+ pthread_mutex_destroy(&lock);
+RETURN:
+ return ret;
+}
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/socket_opts.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/socket_opts.c
new file mode 100644
index 000000000..890cc0cc5
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/socket_opts.c
@@ -0,0 +1,299 @@
+/*
+ * Copyright (C) 2022 Amazon.com Inc. or its affiliates. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+
+#include <arpa/inet.h>
+#include <errno.h>
+#include <netinet/tcp.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <sys/time.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+#define MULTICAST_ADDR 16777440
+#define OPTION_ASSERT(A, B, OPTION) \
+ if (A == B) { \
+ printf("%s is expected\n", OPTION); \
+ } \
+ else { \
+ printf("%s is unexpected\n", OPTION); \
+ perror("assertion failed"); \
+ return EXIT_FAILURE; \
+ }
+
+static struct timeval
+to_timeval(time_t tv_sec, suseconds_t tv_usec)
+{
+ struct timeval tv = { tv_sec, tv_usec };
+ return tv;
+}
+
+static int
+set_and_get_bool_opt(int socket_fd, int level, int optname, int val)
+{
+ int bool_opt = val;
+ int ret = -1;
+ socklen_t opt_len = sizeof(bool_opt);
+
+ ret = setsockopt(socket_fd, level, optname, &bool_opt, sizeof(bool_opt));
+ if (ret != 0)
+ return !val;
+
+ bool_opt = !bool_opt;
+ ret = getsockopt(socket_fd, level, optname, &bool_opt, &opt_len);
+ if (ret != 0)
+ return !val;
+
+ return bool_opt;
+}
+
+int
+main(int argc, char *argv[])
+{
+ int tcp_socket_fd = 0;
+ int udp_socket_fd = 0;
+ int udp_ipv6_socket_fd = 0;
+ struct timeval tv;
+ socklen_t opt_len;
+ int buf_len;
+ int result;
+ struct linger linger_opt;
+ uint32_t time_s;
+ int ttl;
+
+ printf("[Client] Create TCP socket\n");
+ tcp_socket_fd = socket(AF_INET, SOCK_STREAM, 0);
+ if (tcp_socket_fd == -1) {
+ perror("Create socket failed");
+ return EXIT_FAILURE;
+ }
+
+ printf("[Client] Create UDP socket\n");
+ udp_socket_fd = socket(AF_INET, SOCK_DGRAM, 0);
+ if (udp_socket_fd == -1) {
+ perror("Create socket failed");
+ return EXIT_FAILURE;
+ }
+
+ printf("[Client] Create UDP IPv6 socket\n");
+ udp_ipv6_socket_fd = socket(AF_INET6, SOCK_DGRAM, 0);
+ if (udp_ipv6_socket_fd == -1) {
+ perror("Create socket failed");
+ return EXIT_FAILURE;
+ }
+
+ // SO_RCVTIMEO
+ tv = to_timeval(123, 1000);
+ result =
+ setsockopt(tcp_socket_fd, SOL_SOCKET, SO_RCVTIMEO, &tv, sizeof(tv));
+ OPTION_ASSERT(result, 0, "setsockopt SO_RCVTIMEO result")
+
+ tv = to_timeval(0, 0);
+ opt_len = sizeof(tv);
+ result = getsockopt(tcp_socket_fd, SOL_SOCKET, SO_RCVTIMEO, &tv, &opt_len);
+ OPTION_ASSERT(result, 0, "getsockopt SO_RCVTIMEO result")
+ OPTION_ASSERT(tv.tv_sec, 123, "SO_RCVTIMEO tv_sec");
+ // OPTION_ASSERT(tv.tv_usec, 1000, "SO_RCVTIMEO tv_usec");
+
+ // SO_SNDTIMEO
+ tv = to_timeval(456, 2000);
+ result =
+ setsockopt(tcp_socket_fd, SOL_SOCKET, SO_SNDTIMEO, &tv, sizeof(tv));
+ OPTION_ASSERT(result, 0, "setsockopt SO_SNDTIMEO result")
+
+ tv = to_timeval(0, 0);
+ opt_len = sizeof(tv);
+ result = getsockopt(tcp_socket_fd, SOL_SOCKET, SO_SNDTIMEO, &tv, &opt_len);
+ OPTION_ASSERT(result, 0, "getsockopt SO_SNDTIMEO result")
+ OPTION_ASSERT(tv.tv_sec, 456, "SO_SNDTIMEO tv_sec");
+ // OPTION_ASSERT(tv.tv_usec, 2000, "SO_SNDTIMEO tv_usec");
+
+ // SO_SNDBUF
+ buf_len = 8192;
+ result = setsockopt(tcp_socket_fd, SOL_SOCKET, SO_SNDBUF, &buf_len,
+ sizeof(buf_len));
+ OPTION_ASSERT(result, 0, "setsockopt SO_SNDBUF result")
+
+ buf_len = 0;
+ opt_len = sizeof(buf_len);
+ result =
+ getsockopt(tcp_socket_fd, SOL_SOCKET, SO_SNDBUF, &buf_len, &opt_len);
+ OPTION_ASSERT(result, 0, "getsockopt SO_SNDBUF result")
+ OPTION_ASSERT((buf_len == 16384 || buf_len == 8192), 1,
+ "SO_SNDBUF buf_len");
+
+ // SO_RCVBUF
+ buf_len = 4096;
+ result = setsockopt(tcp_socket_fd, SOL_SOCKET, SO_RCVBUF, &buf_len,
+ sizeof(buf_len));
+ OPTION_ASSERT(result, 0, "setsockopt SO_RCVBUF result")
+
+ buf_len = 0;
+ opt_len = sizeof(buf_len);
+ result =
+ getsockopt(tcp_socket_fd, SOL_SOCKET, SO_RCVBUF, &buf_len, &opt_len);
+ OPTION_ASSERT(result, 0, "getsockopt SO_RCVBUF result")
+ OPTION_ASSERT((buf_len == 8192 || buf_len == 4096), 1, "SO_SNDBUF buf_len");
+
+ // SO_KEEPALIVE
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, SOL_SOCKET, SO_KEEPALIVE, 1), 1,
+ "SO_KEEPALIVE enabled");
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, SOL_SOCKET, SO_KEEPALIVE, 0), 0,
+ "SO_KEEPALIVE disabled");
+
+ // SO_REUSEADDR
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, SOL_SOCKET, SO_REUSEADDR, 1), 1,
+ "SO_REUSEADDR enabled");
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, SOL_SOCKET, SO_REUSEADDR, 0), 0,
+ "SO_REUSEADDR disabled");
+
+ // SO_REUSEPORT
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, SOL_SOCKET, SO_REUSEPORT, 1), 1,
+ "SO_REUSEPORT enabled");
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, SOL_SOCKET, SO_REUSEPORT, 0), 0,
+ "SO_REUSEPORT disabled");
+
+ // SO_LINGER
+ linger_opt.l_onoff = 1;
+ linger_opt.l_linger = 10;
+ result = setsockopt(tcp_socket_fd, SOL_SOCKET, SO_LINGER, &linger_opt,
+ sizeof(linger_opt));
+ OPTION_ASSERT(result, 0, "setsockopt SO_LINGER result")
+
+ linger_opt.l_onoff = 0;
+ linger_opt.l_linger = 0;
+ opt_len = sizeof(linger_opt);
+ result =
+ getsockopt(tcp_socket_fd, SOL_SOCKET, SO_LINGER, &linger_opt, &opt_len);
+ OPTION_ASSERT(result, 0, "getsockopt SO_LINGER result")
+ OPTION_ASSERT(linger_opt.l_onoff, 1, "SO_LINGER l_onoff");
+ OPTION_ASSERT(linger_opt.l_linger, 10, "SO_LINGER l_linger");
+
+ // SO_BROADCAST
+ OPTION_ASSERT(
+ set_and_get_bool_opt(udp_socket_fd, SOL_SOCKET, SO_BROADCAST, 1), 1,
+ "SO_BROADCAST enabled");
+ OPTION_ASSERT(
+ set_and_get_bool_opt(udp_socket_fd, SOL_SOCKET, SO_BROADCAST, 0), 0,
+ "SO_BROADCAST disabled");
+
+ // TCP_KEEPIDLE
+#ifdef TCP_KEEPIDLE
+ time_s = 16;
+ result = setsockopt(tcp_socket_fd, IPPROTO_TCP, TCP_KEEPIDLE, &time_s,
+ sizeof(time_s));
+ OPTION_ASSERT(result, 0, "setsockopt TCP_KEEPIDLE result")
+
+ time_s = 0;
+ opt_len = sizeof(time_s);
+ result =
+ getsockopt(tcp_socket_fd, IPPROTO_TCP, TCP_KEEPIDLE, &time_s, &opt_len);
+ OPTION_ASSERT(result, 0, "getsockopt TCP_KEEPIDLE result")
+ OPTION_ASSERT(time_s, 16, "TCP_KEEPIDLE");
+#endif
+
+ // TCP_KEEPINTVL
+ time_s = 8;
+ result = setsockopt(tcp_socket_fd, IPPROTO_TCP, TCP_KEEPINTVL, &time_s,
+ sizeof(time_s));
+ OPTION_ASSERT(result, 0, "setsockopt TCP_KEEPINTVL result")
+
+ time_s = 0;
+ opt_len = sizeof(time_s);
+ result = getsockopt(tcp_socket_fd, IPPROTO_TCP, TCP_KEEPINTVL, &time_s,
+ &opt_len);
+ OPTION_ASSERT(result, 0, "getsockopt TCP_KEEPINTVL result")
+ OPTION_ASSERT(time_s, 8, "TCP_KEEPINTVL");
+
+ // TCP_FASTOPEN_CONNECT
+#ifdef TCP_FASTOPEN_CONNECT
+ OPTION_ASSERT(set_and_get_bool_opt(tcp_socket_fd, IPPROTO_TCP,
+ TCP_FASTOPEN_CONNECT, 1),
+ 1, "TCP_FASTOPEN_CONNECT enabled");
+ OPTION_ASSERT(set_and_get_bool_opt(tcp_socket_fd, IPPROTO_TCP,
+ TCP_FASTOPEN_CONNECT, 0),
+ 0, "TCP_FASTOPEN_CONNECT disabled");
+#endif
+
+ // TCP_NODELAY
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, IPPROTO_TCP, TCP_NODELAY, 1), 1,
+ "TCP_NODELAY enabled");
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, IPPROTO_TCP, TCP_NODELAY, 0), 0,
+ "TCP_NODELAY disabled");
+
+ // TCP_QUICKACK
+#ifdef TCP_QUICKACK
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, IPPROTO_TCP, TCP_QUICKACK, 1), 1,
+ "TCP_QUICKACK enabled");
+ OPTION_ASSERT(
+ set_and_get_bool_opt(tcp_socket_fd, IPPROTO_TCP, TCP_QUICKACK, 0), 0,
+ "TCP_QUICKACK disabled");
+#endif
+
+ // IP_TTL
+ ttl = 8;
+ result = setsockopt(tcp_socket_fd, IPPROTO_IP, IP_TTL, &ttl, sizeof(ttl));
+ OPTION_ASSERT(result, 0, "IP_TIL");
+ ttl = 0;
+ opt_len = sizeof(ttl);
+ result = getsockopt(tcp_socket_fd, IPPROTO_IP, IP_TTL, &ttl, &opt_len);
+ OPTION_ASSERT(ttl, 8, "IP_TTL");
+ OPTION_ASSERT(result, 0, "IP_TIL");
+
+ // IPV6_V6ONLY
+ OPTION_ASSERT(
+ set_and_get_bool_opt(udp_ipv6_socket_fd, IPPROTO_IPV6, IPV6_V6ONLY, 1),
+ 1, "IPV6_V6ONLY enabled");
+ OPTION_ASSERT(
+ set_and_get_bool_opt(udp_ipv6_socket_fd, IPPROTO_IPV6, IPV6_V6ONLY, 0),
+ 0, "IPV6_V6ONLY disabled");
+
+ // IP_MULTICAST_LOOP
+ OPTION_ASSERT(
+ set_and_get_bool_opt(udp_socket_fd, IPPROTO_IP, IP_MULTICAST_LOOP, 1),
+ 1, "IP_MULTICAST_LOOP enabled");
+ OPTION_ASSERT(
+ set_and_get_bool_opt(udp_socket_fd, IPPROTO_IP, IP_MULTICAST_LOOP, 0),
+ 0, "IP_MULTICAST_LOOP disabled");
+
+ // IP_MULTICAST_TTL
+ ttl = 8;
+ result = setsockopt(udp_socket_fd, IPPROTO_IP, IP_MULTICAST_TTL, &ttl,
+ sizeof(ttl));
+ OPTION_ASSERT(result, 0, "IP_MULTICAST_TTL");
+ ttl = 0;
+ opt_len = sizeof(ttl);
+ result =
+ getsockopt(udp_socket_fd, IPPROTO_IP, IP_MULTICAST_TTL, &ttl, &opt_len);
+ OPTION_ASSERT(ttl, 8, "IP_MULTICAST_TTL");
+ OPTION_ASSERT(result, 0, "IP_MULTICAST_TTL");
+
+ // IPV6_MULTICAST_LOOP
+ OPTION_ASSERT(set_and_get_bool_opt(udp_ipv6_socket_fd, IPPROTO_IPV6,
+ IPV6_MULTICAST_LOOP, 1),
+ 1, "IPV6_MULTICAST_LOOP enabled");
+ OPTION_ASSERT(set_and_get_bool_opt(udp_ipv6_socket_fd, IPPROTO_IPV6,
+ IPV6_MULTICAST_LOOP, 0),
+ 0, "IPV6_MULTICAST_LOOP disabled");
+
+ printf("[Client] Close sockets\n");
+ close(tcp_socket_fd);
+ close(udp_socket_fd);
+ close(udp_ipv6_socket_fd);
+ return EXIT_SUCCESS;
+}
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/socket_utils.h b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/socket_utils.h
new file mode 100644
index 000000000..b69135b79
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/socket_utils.h
@@ -0,0 +1,48 @@
+/*
+ * Copyright (C) 2022 Amazon.com Inc. or its affiliates. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+
+#ifndef TCP_UTILS_H
+#define TCP_UTILS_H
+
+#include <sys/socket.h>
+#include <arpa/inet.h>
+#include <stdio.h>
+
+int
+sockaddr_to_string(struct sockaddr *addr, char *str, size_t len)
+{
+ uint16_t port;
+ char ip_string[64];
+ void *addr_buf;
+ int ret;
+
+ switch (addr->sa_family) {
+ case AF_INET:
+ {
+ struct sockaddr_in *addr_in = (struct sockaddr_in *)addr;
+ port = addr_in->sin_port;
+ addr_buf = &addr_in->sin_addr;
+ break;
+ }
+ case AF_INET6:
+ {
+ struct sockaddr_in6 *addr_in6 = (struct sockaddr_in6 *)addr;
+ port = addr_in6->sin6_port;
+ addr_buf = &addr_in6->sin6_addr;
+ break;
+ }
+ default:
+ return -1;
+ }
+
+ inet_ntop(addr->sa_family, addr_buf, ip_string,
+ sizeof(ip_string) / sizeof(ip_string[0]));
+
+ ret = snprintf(str, len, "%s:%d", ip_string, ntohs(port));
+
+ return ret > 0 && (size_t)ret < len ? 0 : -1;
+}
+
+#endif /* TCP_UTILS_H */ \ No newline at end of file
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/tcp_client.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/tcp_client.c
new file mode 100644
index 000000000..aad449483
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/tcp_client.c
@@ -0,0 +1,106 @@
+/*
+ * Copyright (C) 2019 Intel Corporation. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+#include "socket_utils.h"
+
+#include <arpa/inet.h>
+#include <netinet/in.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+static void
+init_sockaddr_inet(struct sockaddr_in *addr)
+{
+ /* 127.0.0.1:1234 */
+ addr->sin_family = AF_INET;
+ addr->sin_port = htons(1234);
+ addr->sin_addr.s_addr = htonl(INADDR_LOOPBACK);
+}
+
+static void
+init_sockaddr_inet6(struct sockaddr_in6 *addr)
+{
+ /* [::1]:1234 */
+ addr->sin6_family = AF_INET6;
+ addr->sin6_port = htons(1234);
+ addr->sin6_addr = in6addr_loopback;
+}
+
+int
+main(int argc, char *argv[])
+{
+ int socket_fd, ret, total_size = 0, af;
+ char buffer[1024] = { 0 };
+ char ip_string[64] = { 0 };
+ socklen_t len;
+ struct sockaddr_storage server_address = { 0 };
+ struct sockaddr_storage local_address = { 0 };
+
+ if (argc > 1 && strcmp(argv[1], "inet6") == 0) {
+ af = AF_INET6;
+ len = sizeof(struct sockaddr_in6);
+ init_sockaddr_inet6((struct sockaddr_in6 *)&server_address);
+ }
+ else {
+ af = AF_INET;
+ len = sizeof(struct sockaddr_in);
+ init_sockaddr_inet((struct sockaddr_in *)&server_address);
+ }
+
+ printf("[Client] Create socket\n");
+ socket_fd = socket(af, SOCK_STREAM, 0);
+ if (socket_fd == -1) {
+ perror("Create socket failed");
+ return EXIT_FAILURE;
+ }
+
+ printf("[Client] Connect socket\n");
+ if (connect(socket_fd, (struct sockaddr *)&server_address, len) == -1) {
+ perror("Connect failed");
+ close(socket_fd);
+ return EXIT_FAILURE;
+ }
+
+ len = sizeof(local_address);
+ ret = getsockname(socket_fd, (struct sockaddr *)&local_address, &len);
+ if (ret == -1) {
+ perror("Failed to retrieve socket address");
+ close(socket_fd);
+ return EXIT_FAILURE;
+ }
+
+ if (sockaddr_to_string((struct sockaddr *)&local_address, ip_string,
+ sizeof(ip_string) / sizeof(ip_string[0]))
+ != 0) {
+ printf("[Client] failed to parse local address\n");
+ close(socket_fd);
+ return EXIT_FAILURE;
+ }
+
+ printf("[Client] Local address is: %s\n", ip_string);
+
+ printf("[Client] Client receive\n");
+ while (1) {
+ ret = recv(socket_fd, buffer + total_size, sizeof(buffer) - total_size,
+ 0);
+ if (ret <= 0)
+ break;
+ total_size += ret;
+ }
+
+ printf("[Client] %d bytes received:\n", total_size);
+ if (total_size > 0) {
+ printf("Buffer recieved:\n%s\n", buffer);
+ }
+
+ close(socket_fd);
+ printf("[Client] BYE \n");
+ return EXIT_SUCCESS;
+}
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/tcp_server.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/tcp_server.c
new file mode 100644
index 000000000..2798dc252
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/tcp_server.c
@@ -0,0 +1,152 @@
+/*
+ * Copyright (C) 2019 Intel Corporation. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+#include "socket_utils.h"
+
+#include <arpa/inet.h>
+#include <netinet/in.h>
+#include <pthread.h>
+#include <stdbool.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <stdint.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+#define WORKER_NUM 5
+
+void *
+run(void *arg)
+{
+ const char *message = "Say Hi from the Server\n";
+ int new_socket = *(int *)arg;
+ int i;
+
+ printf("[Server] Communicate with the new connection #%u @ %p ..\n",
+ new_socket, (void *)(uintptr_t)pthread_self());
+
+ for (i = 0; i < 5; i++) {
+ if (send(new_socket, message, strlen(message), 0) < 0) {
+ perror("Send failed");
+ break;
+ }
+ }
+
+ printf("[Server] Shuting down the new connection #%u ..\n", new_socket);
+ shutdown(new_socket, SHUT_RDWR);
+
+ return NULL;
+}
+
+static void
+init_sockaddr_inet(struct sockaddr_in *addr)
+{
+ /* 0.0.0.0:1234 */
+ addr->sin_family = AF_INET;
+ addr->sin_port = htons(1234);
+ addr->sin_addr.s_addr = htonl(INADDR_ANY);
+}
+
+static void
+init_sockaddr_inet6(struct sockaddr_in6 *addr)
+{
+ /* [::]:1234 */
+ addr->sin6_family = AF_INET6;
+ addr->sin6_port = htons(1234);
+ addr->sin6_addr = in6addr_any;
+}
+
+int
+main(int argc, char *argv[])
+{
+ int socket_fd = -1, addrlen = 0, af;
+ struct sockaddr_storage addr = { 0 };
+ unsigned connections = 0;
+ pthread_t workers[WORKER_NUM] = { 0 };
+ int client_sock_fds[WORKER_NUM] = { 0 };
+ char ip_string[64];
+
+ if (argc > 1 && strcmp(argv[1], "inet6") == 0) {
+ af = AF_INET6;
+ addrlen = sizeof(struct sockaddr_in6);
+ init_sockaddr_inet6((struct sockaddr_in6 *)&addr);
+ }
+ else {
+ af = AF_INET;
+ addrlen = sizeof(struct sockaddr_in6);
+ init_sockaddr_inet((struct sockaddr_in *)&addr);
+ }
+
+ printf("[Server] Create socket\n");
+ socket_fd = socket(af, SOCK_STREAM, 0);
+ if (socket_fd < 0) {
+ perror("Create socket failed");
+ goto fail;
+ }
+
+ printf("[Server] Bind socket\n");
+ if (bind(socket_fd, (struct sockaddr *)&addr, addrlen) < 0) {
+ perror("Bind failed");
+ goto fail;
+ }
+
+ printf("[Server] Listening on socket\n");
+ if (listen(socket_fd, 3) < 0) {
+ perror("Listen failed");
+ goto fail;
+ }
+
+ printf("[Server] Wait for clients to connect ..\n");
+ while (connections < WORKER_NUM) {
+ addrlen = sizeof(struct sockaddr);
+ client_sock_fds[connections] =
+ accept(socket_fd, (struct sockaddr *)&addr, (socklen_t *)&addrlen);
+ if (client_sock_fds[connections] < 0) {
+ perror("Accept failed");
+ break;
+ }
+
+ if (sockaddr_to_string((struct sockaddr *)&addr, ip_string,
+ sizeof(ip_string) / sizeof(ip_string[0]))
+ != 0) {
+ printf("[Server] failed to parse client address\n");
+ goto fail;
+ }
+
+ printf("[Server] Client connected (%s)\n", ip_string);
+ if (pthread_create(&workers[connections], NULL, run,
+ &client_sock_fds[connections])) {
+ perror("Create a worker thread failed");
+ shutdown(client_sock_fds[connections], SHUT_RDWR);
+ break;
+ }
+
+ connections++;
+ }
+
+ if (connections == WORKER_NUM) {
+ printf("[Server] Achieve maximum amount of connections\n");
+ }
+
+ for (int i = 0; i < WORKER_NUM; i++) {
+ pthread_join(workers[i], NULL);
+ }
+
+ printf("[Server] Shuting down ..\n");
+ shutdown(socket_fd, SHUT_RDWR);
+ sleep(3);
+ printf("[Server] BYE \n");
+ return EXIT_SUCCESS;
+
+fail:
+ printf("[Server] Shuting down ..\n");
+ if (socket_fd >= 0)
+ close(socket_fd);
+ sleep(3);
+ return EXIT_FAILURE;
+}
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/timeout_client.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/timeout_client.c
new file mode 100644
index 000000000..652021b5d
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/timeout_client.c
@@ -0,0 +1,111 @@
+/*
+ * Copyright (C) 2022 Amazon.com Inc. or its affiliates. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+
+#include <arpa/inet.h>
+#include <errno.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <sys/socket.h>
+#include <sys/time.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+int
+main(int argc, char *argv[])
+{
+ int socket_fd;
+ struct sockaddr_in addr;
+ struct timeval tv = { 0, 1 };
+ const int snd_buf_len = 8;
+ const int data_buf_len = 1000000;
+ char *buffer = (char *)malloc(sizeof(char) * data_buf_len);
+ int result;
+ socklen_t opt_len = sizeof(snd_buf_len);
+ struct timeval snd_start_time, snd_end_time;
+ int bool_opt = 1;
+
+ if (buffer == NULL) {
+ perror("Allocation failed, please re-run with larger heap size");
+ return EXIT_FAILURE;
+ }
+
+ /* 127.0.0.1:1234 */
+ addr.sin_family = AF_INET;
+ addr.sin_port = htons(1234);
+ addr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
+
+ if ((socket_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
+ perror("Create socket failed");
+ goto fail1;
+ }
+
+ if (setsockopt(socket_fd, SOL_SOCKET, SO_REUSEADDR, &bool_opt,
+ sizeof(bool_opt))
+ == -1) {
+ perror("Failed setting SO_REUSEADDR");
+ goto fail2;
+ }
+
+ if (setsockopt(socket_fd, SOL_SOCKET, SO_RCVTIMEO, &tv, sizeof(tv)) == -1) {
+ perror("Failed setting SO_RCVTIMEO");
+ goto fail2;
+ }
+
+ if (setsockopt(socket_fd, SOL_SOCKET, SO_SNDTIMEO, &tv, sizeof(tv)) == -1) {
+ perror("Failed setting SO_SNDTIMEO");
+ goto fail2;
+ }
+
+ if (setsockopt(socket_fd, SOL_SOCKET, SO_SNDBUF, &data_buf_len,
+ sizeof(data_buf_len))
+ == -1) {
+ perror("Failed setting SO_SNDBUF");
+ goto fail2;
+ }
+
+ if (connect(socket_fd, (struct sockaddr *)&addr, sizeof(addr)) == -1) {
+ perror("Connect failed");
+ goto fail2;
+ }
+
+ if (getsockopt(socket_fd, SOL_SOCKET, SO_SNDBUF, (void *)&data_buf_len,
+ &opt_len)
+ == -1) {
+ perror("Failed getting SO_SNDBUF");
+ goto fail2;
+ }
+
+ printf("Waiting on recv, which should timeout\n");
+ result = recv(socket_fd, buffer, 1, 0);
+
+ if (result != -1 || errno != EAGAIN) {
+ perror("Recv did not timeout as expected");
+ goto fail2;
+ }
+
+ printf("Waiting on send, which should timeout\n");
+ gettimeofday(&snd_start_time, NULL);
+ result = send(socket_fd, buffer, data_buf_len, 0);
+ gettimeofday(&snd_end_time, NULL);
+
+ if (result >= data_buf_len
+ || snd_start_time.tv_sec != snd_end_time.tv_sec) {
+ perror("Send did not timeout as expected");
+ goto fail2;
+ }
+
+ printf("Success. Closing socket \n");
+ close(socket_fd);
+ free(buffer);
+ return EXIT_SUCCESS;
+
+fail2:
+ close(socket_fd);
+fail1:
+ free(buffer);
+ return EXIT_FAILURE;
+}
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/timeout_server.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/timeout_server.c
new file mode 100644
index 000000000..c71cf4553
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/timeout_server.c
@@ -0,0 +1,69 @@
+/*
+ * Copyright (C) 2022 Amazon.com Inc. or its affiliates. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+
+#include <arpa/inet.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <sys/time.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+int
+main(int argc, char *argv[])
+{
+ int socket_fd;
+ int client_socket_fd;
+ struct sockaddr_in addr = { 0 };
+ int addrlen = sizeof(addr);
+ int bool_opt = 1;
+
+ addr.sin_family = AF_INET;
+ addr.sin_port = htons(1234);
+ addr.sin_addr.s_addr = htonl(INADDR_ANY);
+ if ((socket_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
+ perror("Create socket failed");
+ return EXIT_FAILURE;
+ }
+
+ if (setsockopt(socket_fd, SOL_SOCKET, SO_REUSEADDR, &bool_opt,
+ sizeof(bool_opt))
+ == -1) {
+ perror("Failed setting SO_REUSEADDR");
+ goto fail;
+ }
+
+ if (bind(socket_fd, (struct sockaddr *)&addr, addrlen) == -1) {
+ perror("Bind socket failed");
+ goto fail;
+ }
+
+ if (listen(socket_fd, 1) == -1) {
+ perror("Listen failed");
+ goto fail;
+ }
+
+ if ((client_socket_fd =
+ accept(socket_fd, (struct sockaddr *)&addr, (socklen_t *)&addrlen))
+ == -1) {
+ perror("Accept failed");
+ goto fail;
+ }
+
+ printf("Client connected, sleeping for 10s\n");
+ sleep(10);
+
+ printf("Shuting down\n");
+ shutdown(client_socket_fd, SHUT_RDWR);
+ close(client_socket_fd);
+ shutdown(socket_fd, SHUT_RDWR);
+ close(socket_fd);
+ return EXIT_SUCCESS;
+
+fail:
+ close(socket_fd);
+ return EXIT_FAILURE;
+}
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/udp_client.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/udp_client.c
new file mode 100644
index 000000000..810a455f8
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/udp_client.c
@@ -0,0 +1,84 @@
+/*
+ * Copyright (C) 2022 Amazon.com Inc. or its affiliates. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+
+#include <arpa/inet.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+static void
+init_sockaddr_inet(struct sockaddr_in *addr)
+{
+ /* 127.0.0.1:1234 */
+ addr->sin_family = AF_INET;
+ addr->sin_port = htons(1234);
+ addr->sin_addr.s_addr = htonl(INADDR_LOOPBACK);
+}
+
+static void
+init_sockaddr_inet6(struct sockaddr_in6 *addr)
+{
+ /* [::1]:1234 */
+ addr->sin6_family = AF_INET6;
+ addr->sin6_port = htons(1234);
+ addr->sin6_addr = in6addr_loopback;
+}
+
+int
+main(int argc, char *argv[])
+{
+ int socket_fd, ret, af;
+ char buffer[1024] = { 0 };
+ socklen_t serverlen;
+ struct sockaddr_storage server_address = { 0 };
+ const char *message = "Hello from client";
+
+ if (argc > 1 && strcmp(argv[1], "inet6") == 0) {
+ af = AF_INET6;
+ init_sockaddr_inet6((struct sockaddr_in6 *)&server_address);
+ serverlen = sizeof(struct sockaddr_in6);
+ }
+ else {
+ af = AF_INET;
+ init_sockaddr_inet((struct sockaddr_in *)&server_address);
+ serverlen = sizeof(struct sockaddr_in);
+ }
+
+ printf("[Client] Create socket\n");
+ socket_fd = socket(af, SOCK_DGRAM, 0);
+ if (socket_fd == -1) {
+ perror("Create socket failed");
+ return EXIT_FAILURE;
+ }
+
+ printf("[Client] Client send\n");
+ ret = sendto(socket_fd, message, strlen(message), 0,
+ (struct sockaddr *)&server_address, serverlen);
+ if (ret < 0) {
+ close(socket_fd);
+ perror("Send failed");
+ return EXIT_FAILURE;
+ }
+
+ printf("[Client] Client receive\n");
+ serverlen = sizeof(server_address);
+ /* make sure there is space for the string terminator */
+ ret = recvfrom(socket_fd, buffer, sizeof(buffer) - 1, 0,
+ (struct sockaddr *)&server_address, &serverlen);
+
+ if (ret > 0) {
+ buffer[ret] = '\0';
+ printf("[Client] Buffer recieved: %s\n", buffer);
+ }
+
+ close(socket_fd);
+ printf("[Client] BYE \n");
+ return EXIT_SUCCESS;
+}
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/udp_server.c b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/udp_server.c
new file mode 100644
index 000000000..588964145
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/socket-api/wasm-src/udp_server.c
@@ -0,0 +1,122 @@
+/*
+ * Copyright (C) 2022 Amazon.com Inc. or its affiliates. All rights reserved.
+ * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+ */
+
+#include "socket_utils.h"
+
+#include <arpa/inet.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <unistd.h>
+#ifdef __wasi__
+#include <wasi_socket_ext.h>
+#endif
+
+#define MAX_CONNECTIONS_COUNT 5
+
+static void
+init_sockaddr_inet(struct sockaddr_in *addr)
+{
+ /* 0.0.0.0:1234 */
+ addr->sin_family = AF_INET;
+ addr->sin_port = htons(1234);
+ addr->sin_addr.s_addr = htonl(INADDR_ANY);
+}
+
+static void
+init_sockaddr_inet6(struct sockaddr_in6 *addr)
+{
+ /* [::]:1234 */
+ addr->sin6_family = AF_INET6;
+ addr->sin6_port = htons(1234);
+ addr->sin6_addr = in6addr_any;
+}
+
+int
+main(int argc, char *argv[])
+{
+ int socket_fd = -1, af;
+ socklen_t addrlen = 0;
+ struct sockaddr_storage addr = { 0 };
+ char *reply_message = "Hello from server";
+ unsigned connections = 0;
+ char ip_string[64] = { 0 };
+ char buffer[1024] = { 0 };
+
+ if (argc > 1 && strcmp(argv[1], "inet6") == 0) {
+ af = AF_INET6;
+ addrlen = sizeof(struct sockaddr_in6);
+ init_sockaddr_inet6((struct sockaddr_in6 *)&addr);
+ }
+ else {
+ af = AF_INET;
+ addrlen = sizeof(struct sockaddr_in);
+ init_sockaddr_inet((struct sockaddr_in *)&addr);
+ }
+
+ printf("[Server] Create socket\n");
+ socket_fd = socket(af, SOCK_DGRAM, 0);
+ if (socket_fd < 0) {
+ perror("Create socket failed");
+ goto fail;
+ }
+
+ printf("[Server] Bind socket\n");
+ if (bind(socket_fd, (struct sockaddr *)&addr, addrlen) < 0) {
+ perror("Bind failed");
+ goto fail;
+ }
+
+ printf("[Server] Wait for clients to connect ..\n");
+ while (connections < MAX_CONNECTIONS_COUNT) {
+ addrlen = sizeof(addr);
+ /* make sure there is space for the string terminator */
+ int ret = recvfrom(socket_fd, buffer, sizeof(buffer) - 1, 0,
+ (struct sockaddr *)&addr, &addrlen);
+ if (ret < 0) {
+ perror("Read failed");
+ goto fail;
+ }
+ buffer[ret] = '\0';
+
+ if (sockaddr_to_string((struct sockaddr *)&addr, ip_string,
+ sizeof(ip_string) / sizeof(ip_string[0]))
+ != 0) {
+ printf("[Server] failed to parse client address\n");
+ goto fail;
+ }
+
+ printf("[Server] received %d bytes from %s: %s\n", ret, ip_string,
+ buffer);
+
+ if (sendto(socket_fd, reply_message, strlen(reply_message), 0,
+ (struct sockaddr *)&addr, addrlen)
+ < 0) {
+ perror("Send failed");
+ break;
+ }
+
+ connections++;
+ }
+
+ if (connections == MAX_CONNECTIONS_COUNT) {
+ printf("[Server] Achieve maximum amount of connections\n");
+ }
+
+ printf("[Server] Shuting down ..\n");
+ shutdown(socket_fd, SHUT_RDWR);
+ close(socket_fd);
+ sleep(3);
+ printf("[Server] BYE \n");
+ return EXIT_SUCCESS;
+
+fail:
+ printf("[Server] Shuting down ..\n");
+ if (socket_fd >= 0)
+ close(socket_fd);
+ sleep(3);
+ return EXIT_FAILURE;
+}