Skip to main content

Minimalistic dynamic library which is a powerful http-server written in C and C++.

Project description

Arnelify Logo

Arnelify Server for Python C++ G++ Python Nuitka

🚀 About

Arnelify® Server for Python - is a minimalistic dynamic library which is a powerful http-server written in C and C++.

📋 Minimal Requirements

Important: It's strongly recommended to use in a container that has been built from the gcc v14.2.0 image.

  • CPU: Apple M1 / Intel Core i7 / AMD Ryzen 7
  • OS: Debian 11 / MacOS 15 / Windows 10 with WSL2.
  • RAM: 4 GB

📦 Installation

Installing via pip:

pip install arnelify-server

🎉 Usage

Install dependencies:

make install

Compile library:

make build

Compile & Run test:

make test_nuitka

Run test:

make test

📚 Code Examples

Configure the C/C++ IntelliSense plugin for VSCode (optional).

Clang_format_fallback = Google

IncludePath for VSCode (optional):

"includePath": [
  "/opt/homebrew/Cellar/jsoncpp/1.9.6/include/json",
  "${workspaceFolder}/src/cpp",
  "${workspaceFolder}/src"
],

You can find code examples here.

Option Description
SERVER_ALLOW_EMPTY_FILES If this option is enabled, the server will not reject empty files.
SERVER_BLOCK_SIZE_KB The size of the allocated memory used for processing large packets.
SERVER_CHARSET Defines the encoding that the server will recommend to all client applications.
SERVER_GZIP If this option is enabled, the server will use GZIP compression if the client application supports it. This setting increases CPU resource consumption. The server will not use compression if the data size exceeds the value of SERVER_BLOCK_SIZE_KB.
SERVER_KEEP_EXTENSIONS If this option is enabled, file extensions will be preserved.
SERVER_MAX_FIELDS Defines the maximum number of fields in the received form.
SERVER_MAX_FIELDS_SIZE_TOTAL_MB Defines the maximum total size of all fields in the form. This option does not include file sizes.
SERVER_MAX_FILES Defines the maximum number of files in the form.
SERVER_MAX_FILES_SIZE_TOTAL_MB Defines the maximum total size of all files in the form.
SERVER_MAX_FILE_SIZE_MB Defines the maximum size of a single file in the form.
SERVER_PORT Defines which port the server will listen on.
SERVER_THREAD_LIMIT Defines the maximum number of threads that will handle requests.
SERVER_QUEUE_LIMIT Defines the maximum size of the queue on the client socket.
SERVER_UPLOAD_DIR Specifies the upload directory for storage.

⚖️ MIT License

This software is licensed under the MIT License. The original author's name, logo, and the original name of the software must be included in all copies or substantial portions of the software.

🛠️ Contributing

Join us to help improve this software, fix bugs or implement new functionality. Active participation will help keep the software up-to-date, reliable, and aligned with the needs of its users.

⭐ Release Notes

Version 0.7.4 - Minimalistic dynamic library

We are excited to introduce the Arnelify Server dynamic library for Python! Please note that this version is raw and still in active development.

Change log:

  • Multi-Threading
  • Minimalistic dynamic library for Python
  • Block processing in "on-the-fly" mode
  • GZIP support
  • Significant refactoring and optimizations

Please use this version with caution, as it may contain bugs and unfinished features. We are actively working on improving and expanding the server's capabilities, and we welcome your feedback and suggestions.

🔗 Mentioned

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

arnelify-server-0.7.4.tar.gz (23.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

arnelify_server-0.7.4-cp311-cp311-manylinux2014_x86_64.whl (597.9 kB view details)

Uploaded CPython 3.11

File details

Details for the file arnelify-server-0.7.4.tar.gz.

File metadata

  • Download URL: arnelify-server-0.7.4.tar.gz
  • Upload date:
  • Size: 23.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.2

File hashes

Hashes for arnelify-server-0.7.4.tar.gz
Algorithm Hash digest
SHA256 f5fb2744c25063c400444af67212fff1001bc636a45992a1f148b715708343bb
MD5 bce2efb859485584f8966b76020a58ba
BLAKE2b-256 5360bb810f892fbe3b7d8a1ecdac82351a236f37a81cedee500ee1002484aea9

See more details on using hashes here.

File details

Details for the file arnelify_server-0.7.4-cp311-cp311-manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for arnelify_server-0.7.4-cp311-cp311-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 3334c37c42ccad8763f8b9f8e6b3c944fe57b7251bf9c8cfd868b9d6413fc0a3
MD5 71ef1784b4aceaa1f982271dd8cdf96a
BLAKE2b-256 37e830f90c7ce7ccde8d47cda94606bcd1ad0c54ff479921ebe3982ab88993ba

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page