Skip to main content

KORE Binary Format - High-performance columnar compression with 5-8x compression ratio

Project description

Kore โ€” Killer Optimized Record Exchange

Crates.io PyPI License Rust 1.70+

A high-performance, columnar file format for analytics with cloud storage connectors.

Kore is a Rust-based columnar file format designed for efficient storage and analysis of structured data. It provides zero external dependencies in the base library with optional cloud connectors for AWS S3, Azure Blob Storage, and Google Cloud Storage.


๐Ÿš€ Quick Start (5 Minutes)

Step 1: Install

pip install kore-fileformat==1.1.4

Step 2: Import

from kore_fileformat import compress_csv

# Compress a CSV file (that's it!)
original, compressed, ratio = compress_csv("data.csv", "data.kore")
print(f"โœ… Compressed {ratio:.1%}")

Step 3: Use It

from kore_fileformat import get_kore_info

# Get file information
info = get_kore_info("data.kore")
print(f"Records: {info['total_records']:,}")

๐Ÿ“š Documentation

Getting Started

Document For Whom Time
docs/INSTALLATION.md Everyone 5 min
docs/USER_GUIDE.md Python users 15 min
docs/EXAMPLES.md Developers 20 min

Reference

Document Coverage
docs/API_REFERENCE.md Complete API documentation with examples
docs/TROUBLESHOOTING.md FAQ, common issues, solutions

Advanced Documentation

Guide Purpose
PYTHON_USER_GUIDE.md Cloud integration, advanced features
DOCKER_EMULATORS_GUIDE.md Docker setup, LocalStack, Azurite testing
DOCUMENTATION_INDEX.md Complete documentation index
CI_CD_SECRETS_SETUP.md GitHub Actions, publishing setup

๐Ÿ‘‰ New users: Start with docs/INSTALLATION.md โ†’ docs/USER_GUIDE.md


โœจ Features

Core Library

  • โœ… Zero External Dependencies: Lightweight base crate
  • โœ… Columnar Format: Optimized for analytical queries
  • โœ… Compression: Built-in data compression
  • โœ… Multi-Platform: Windows, macOS, Linux, web

Cloud Connectors

  • โœ… AWS S3: Full implementation in v1.0.0
  • โณ Azure Blob Storage: Full implementation coming in v1.1.0
  • โณ Google Cloud Storage: Full implementation coming in v1.1.0

Language Bindings

  • โœ… Python: PyO3 wheel for Python 3.9-3.12
  • โœ… Java: JNI bindings and Maven package
  • โœ… JavaScript: NAPI module for Node.js
  • โณ Go: Coming in v1.2.0

DevOps & CI/CD

  • โœ… GitHub Actions: 10 automated jobs for testing and publishing
  • โœ… Docker Support: Integration tests with emulators
  • โœ… Multi-Registry Publishing: crates.io, PyPI, Maven Central, npm

๐Ÿ“‹ What's Included in v1.0.0

Component Status Details
Base Library โœ… Production Columnar format, compression, serialization
S3 Connector โœ… Production Read/write to AWS S3 with LocalStack testing
Azure Connector โณ Prepared Stub implementations, full SDK in v1.1.0
GCS Connector โณ Prepared Stub implementations, full SDK in v1.1.0
Python Bindings โœ… Production Wheel installation, PyPI distribution
Java Bindings โœ… Production JNI library, Maven Central distribution
JavaScript Bindings โœ… Production NAPI addon, npm distribution
Integration Tests โœ… Complete 4 comprehensive tests with emulators
Documentation โœ… Complete 8 guides, 2000+ lines, 50+ examples

๐ŸŽฏ Use Cases

Data Analytics

Process large datasets efficiently with columnar storage:

import kore_fileformat
# Store analytics data in columnar format for fast queries

Cloud Data Lakes

Store data directly in S3, Azure, or GCS:

from kore_fileformat import S3Reader
reader = S3Reader(region='us-east-1')
data = reader.read_file('my-bucket', 'path/to/data.kore')

Multi-Language Projects

Use Kore from Python, Java, or JavaScript in the same project:

# Python: import kore_fileformat
# Java: import com.kore.cloud.S3Reader;
# JS: const kore = require('kore-fileformat');

๐Ÿ—๏ธ Architecture

Modular Design

kore_fileformat/
โ”œโ”€โ”€ core/           # Base library (zero dependencies)
โ”œโ”€โ”€ cloud/          # Cloud connectors (optional)
โ”‚   โ”œโ”€โ”€ s3/        # AWS S3 (working)
โ”‚   โ”œโ”€โ”€ azure/     # Azure Blob (v1.1+)
โ”‚   โ””โ”€โ”€ gcs/       # Google Cloud (v1.1+)
โ””โ”€โ”€ bindings/       # Language bindings
    โ”œโ”€โ”€ python/    # PyO3 wheel
    โ”œโ”€โ”€ java/      # JNI library
    โ””โ”€โ”€ napi/      # Node.js addon

Feature Gates

# Base: zero external dependencies
kore_fileformat = "1.0.0"

# With S3
kore_fileformat = { version = "1.0.0", features = ["s3"] }

# With all cloud (v1.1.0+)
kore_fileformat = { version = "1.0.0", features = ["s3", "azure", "gcs"] }

# With Python bindings
# Use: pip install kore-fileformat

๐Ÿ“Š Performance

Kore is designed for analytics workloads:

  • Compression: 5-10x reduction on typical datasets
  • Query Speed: Columnar format enables fast aggregations
  • Storage: 10-50 MB files with millions of rows
  • Cloud: Direct S3/Azure/GCS integration (no intermediate files)

๐Ÿ› ๏ธ Installation

Requirements

  • Rust: 1.70+ (for building from source)
  • Python: 3.9-3.12 (for Python wheel)
  • Java: 17+ (for Java bindings)
  • Node.js: 14+ (for JavaScript bindings)
  • Docker: 20.10+ (for testing with emulators)

From PyPI (Recommended for Python)

pip install kore-fileformat

From crates.io (Rust)

cargo add kore_fileformat --features s3

Build from Source

git clone https://github.com/arunkatherashala/Kore.git
cd Kore
cargo build --release --features s3

๐Ÿงช Testing

Run Unit Tests

cargo test

Run Integration Tests (requires Docker)

# Start emulators (LocalStack, Azurite, GCS)
docker-compose up -d

# Run tests
cargo test --features s3,azure,gcs --test integration_tests -- --nocapture

# Stop emulators
docker-compose down

See DOCKER_EMULATORS_GUIDE.md for detailed setup.


๐Ÿš€ Cloud Integration

AWS S3 (v1.0.0 - Working)

from kore_fileformat import S3Reader

reader = S3Reader(region='us-east-1')
data = reader.read_file('bucket', 'object.kore')
reader.write_file('bucket', 'object.kore', data)

Azure Blob Storage (v1.1.0 - Coming Soon)

from kore_fileformat import AzureBlobReader

reader = AzureBlobReader('account', 'key')
data = reader.read_file('container', 'blob.kore')

Google Cloud Storage (v1.1.0 - Coming Soon)

from kore_fileformat import GcsReader

reader = GcsReader('project-id')
data = reader.read_file('bucket', 'object.kore')

๐Ÿค Contributing

We welcome contributions! Here's how:

  1. Report Issues: GitHub Issues
  2. Discuss Ideas: GitHub Discussions
  3. Submit PRs: Fork, branch, code, and create a pull request

See V1_1_ROADMAP.md for planned features and how to help.


๐Ÿ“… Roadmap

v1.0.0 (Current) โœ…

  • S3 connector with full API
  • Python, Java, JavaScript bindings
  • Integration tests with emulators
  • Complete documentation

v1.1.0 (Q2 2026)

  • Azure Blob Storage full implementation
  • Google Cloud Storage full implementation
  • Performance optimizations
  • Streaming support

v2.0.0 (Q4 2026)

  • Go language bindings
  • Multi-region support
  • Caching layer
  • Advanced compression

See V1_1_ROADMAP.md for detailed phases and milestones.


๐Ÿ“ฆ Distribution Channels

Latest Versions

Platform Package Version Link
PyPI kore-fileformat 1.0.0 PyPI
Crates.io kore_fileformat 1.0.0 Crates.io
Maven com.arun.kore:kore-cloud-java 1.0.0 Coming v1.1
npm kore-fileformat 1.0.0 Coming v1.1

๐Ÿ”’ Security

Features

  • Zero external dependencies in base library
  • Optional SDKs are version-pinned and updated regularly
  • Integration tests verify cloud connectivity
  • GitHub Actions security scanning

Reporting Security Issues

Please email: arunkatherashala@gmail.com


๐Ÿ“ž Support & Community

Getting Help

Stay Updated

  • GitHub: Star the repository
  • Releases: Watch for v1.1.0 announcement
  • Email: Subscribe to release notifications

๐Ÿ“„ License

Kore is licensed under the Apache License 2.0.

Copyright 2024-2026 Sai Arun Kumar Ktherashala

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

๐Ÿ‘ค Author

Sai Arun Kumar Ktherashala


๐ŸŽฏ What's Next?

For Users

  1. Read: PYTHON_USER_GUIDE.md or DOCKER_EMULATORS_GUIDE.md
  2. Install: pip install kore-fileformat
  3. Explore: Check DOCUMENTATION_INDEX.md for your role

For Contributors

  1. Review: V1_1_ROADMAP.md for v1.1.0 features
  2. Clone: git clone https://github.com/arunkatherashala/Kore.git
  3. Setup: Follow DOCKER_EMULATORS_GUIDE.md
  4. Code: Create feature branch and submit PR

For DevOps

  1. Setup: CI_CD_SECRETS_SETUP.md for automated publishing
  2. Monitor: GitHub Actions workflows on each push
  3. Release: Tag v1.0.1 or v1.1.0 to trigger publishing

โœ… Project Status

Phase Status Delivered
Phase 1: Core Library โœ… Complete Base Kore format, compression, serialization
Phase 2: Cloud SDKs โœ… Partial S3 working, Azure/GCS coming v1.1
Phase 3: Language Bindings โœ… Complete Python, Java, JavaScript production-ready
Phase 4: Integration Tests โœ… Complete 4 comprehensive tests with emulators
Phase 5: CI/CD & Publishing โœ… Complete 10 automated jobs, multi-registry support
Documentation โœ… Complete 8 guides, 2000+ lines, 50+ examples

๐ŸŽ‰ Thank You!

Thank you for choosing Kore! We're excited to see what you build.

Questions? Open an issue or discussion on GitHub.
Want to help? Check V1_1_ROADMAP.md for features to implement.
Found a bug? Report it on GitHub Issues.


Latest Release: v1.0.0
Last Updated: May 14, 2026
Status: Production Ready โœ…

๐Ÿš€ Let's build amazing data infrastructure together!

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

kore_fileformat-1.1.5-cp312-cp312-win_amd64.whl (141.4 kB view details)

Uploaded CPython 3.12Windows x86-64

kore_fileformat-1.1.5-cp312-cp312-manylinux_2_34_x86_64.whl (276.2 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.34+ x86-64

kore_fileformat-1.1.5-cp312-cp312-macosx_11_0_arm64.whl (237.0 kB view details)

Uploaded CPython 3.12macOS 11.0+ ARM64

File details

Details for the file kore_fileformat-1.1.5-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for kore_fileformat-1.1.5-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 3263c86b5ba73f3c4ab662be00b92f5f0be5cfe391846cff0aebfb149260ca9f
MD5 66ad7f8d3c5c8a83f16df3f99974abd9
BLAKE2b-256 d89882c13cb05896b797f14d722c34877d68b77973a2e8034fd5b52cd7fcb6ca

See more details on using hashes here.

Provenance

The following attestation bundles were made for kore_fileformat-1.1.5-cp312-cp312-win_amd64.whl:

Publisher: publish-pypi.yml on arunkatherashala/Kore

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kore_fileformat-1.1.5-cp312-cp312-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for kore_fileformat-1.1.5-cp312-cp312-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 5df585ffa35e786f83514a0d9747de1dfc918bd49cc9c371d010660daf714b81
MD5 d3d060ea516c2e9a6cc1d8b2622823bb
BLAKE2b-256 0da98e00bf7411baa9cad7d43a6568aa0252f57358fe085015a93959eacf227d

See more details on using hashes here.

Provenance

The following attestation bundles were made for kore_fileformat-1.1.5-cp312-cp312-manylinux_2_34_x86_64.whl:

Publisher: publish-pypi.yml on arunkatherashala/Kore

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kore_fileformat-1.1.5-cp312-cp312-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for kore_fileformat-1.1.5-cp312-cp312-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 04dab30a7448003711bfcfdee61da0cc7f8cca03c64446c3e74dacca24cb27c3
MD5 f3e1e8360445dca671efe9acf237a8bf
BLAKE2b-256 258c14599777b4ef9858f430bc9e3c76773549d5e79d1ce3a24fe906ed00f6f3

See more details on using hashes here.

Provenance

The following attestation bundles were made for kore_fileformat-1.1.5-cp312-cp312-macosx_11_0_arm64.whl:

Publisher: publish-pypi.yml on arunkatherashala/Kore

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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