Skip to content

infocyph/ArrayKit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

52 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

ArrayKit

Security & Standards Codacy Badge Packagist Downloads License: MIT Packagist Version Packagist PHP Version GitHub Code Size

ArrayKit is a modern PHP 8.2+ library for elegant, high-performance array manipulation, dot notation utilities, dynamic configuration, hookable collections, and more. From shallow single arrays to deeply nested data structures β€” ArrayKit provides a fluent, reliable toolkit for real-world PHP projects.


πŸ“¦ Features at a Glance

βœ… Single-Dimensional Helpers βœ… Multi-Dimensional Helpers βœ… Dot Notation Get/Set/Flatten βœ… Dynamic Config with Hooks βœ… Collection & Hooked Collection βœ… Traits for DTO & Hooking βœ… Pipeline for Collection Ops βœ… Global Helpers (functions.php)


πŸ“š Modules

➀ Array Helpers

Helper Description
ArraySingle Helpers for single-dimensional arrays (detect list/assoc, filter, paginate, duplicates, averages).
ArrayMulti Helpers for multi-dimensional arrays (flatten, collapse, depth, recursive sort, filter).
DotNotation Get/set/remove values using dot keys; flatten & expand nested arrays with dot keys.
BaseArrayHelper Internal shared base for consistent API across helpers.

➀ Config System

Class Description
Config Immutable dot-access configuration loader.
DynamicConfig Extends Config with on-get/on-set hooks to transform values dynamically (e.g., encrypt/decrypt, auto-format).
BaseConfigTrait Shared config logic.

➀ Collections

Class Description
Collection OOP array wrapper implementing ArrayAccess, Iterator, Countable, JsonSerializable.
HookedCollection Extends Collection with on-get/on-set hooks for real-time transformation of values.
Pipeline Functional-style pipeline for chaining operations on collections.
BaseCollectionTrait Shared collection behavior.

➀ Traits

Trait Description
HookTrait Generic hook system for on-get/on-set callbacks. Used by DynamicConfig & HookedCollection.
DTOTrait Utility trait for DTO-like behavior: populate, extract, cast arrays/objects easily.

➀ Global Helpers

File Description
functions.php Global shortcut functions for frequent array/config tasks.

βœ… Requirements

  • PHP 8.2 or higher

⚑ Installation

composer require infocyph/arraykit

πŸš€ Quick Examples

πŸ”Ή Single-Dimensional Helpers

use Infocyph\ArrayKit\Array\ArraySingle;

$list = [1, 2, 3, 2];

// Is it a list?
$isList = ArraySingle::isList($list); // true

// Duplicates
$dupes = ArraySingle::duplicates($list); // [2]

// Pagination
$page = ArraySingle::paginate($list, page:1, perPage:2); // [1, 2]

πŸ”Ή Multi-Dimensional Helpers

use Infocyph\ArrayKit\Array\ArrayMulti;

$data = [ [1, 2], [3, [4, 5]] ];

// Flatten to one level
$flat = ArrayMulti::flatten($data); // [1, 2, 3, 4, 5]

// Collapse one level
$collapsed = ArrayMulti::collapse($data); // [1, 2, 3, [4, 5]]

// Nesting depth
$depth = ArrayMulti::depth($data); // 3

// Recursive sort
$sorted = ArrayMulti::sortRecursive($data);

πŸ”Ή Dot Notation

use Infocyph\ArrayKit\Array\DotNotation;

$user = [
    'profile' => ['name' => 'Alice']
];

// Get value
$name = DotNotation::get($user, 'profile.name'); // Alice

// Set value
DotNotation::set($user, 'profile.email', 'alice@example.com');

// Flatten
$flat = DotNotation::flatten($user);
// [ 'profile.name' => 'Alice', 'profile.email' => 'alice@example.com' ]

πŸ”Ή Dynamic Config with Hooks

use Infocyph\ArrayKit\Config\DynamicConfig;

$config = new DynamicConfig();

// Load from file
$config->loadFile(__DIR__.'/config.php');

// Hook: auto-hash password when set
$config->onSet('auth.password', fn($v) => password_hash($v, PASSWORD_BCRYPT));

// Hook: decrypt when getting 'secure.key'
$config->onGet('secure.key', fn($v) => decrypt($v));

// Use it
$config->set('auth.password', 'secret123');
$hashed = $config->get('auth.password');

πŸ”Ή Hooked Collection

use Infocyph\ArrayKit\Collection\HookedCollection;

$collection = new HookedCollection(['name' => 'alice']);

// Hook on-get: uppercase
$collection->onGet('name', fn($v) => strtoupper($v));

// Hook on-set: prefix
$collection->onSet('role', fn($v) => "Role: $v");

echo $collection['name']; // ALICE

$collection['role'] = 'admin';
echo $collection['role']; // Role: admin

πŸ”Ή DTO Trait Example

use Infocyph\ArrayKit\traits\DTOTrait;

class UserDTO {
    use DTOTrait;

    public string $name;
    public string $email;
}

$user = new UserDTO();
$user->fromArray(['name' => 'Alice', 'email' => 'alice@example.com']);
$array = $user->toArray();

🀝 Support

Have a bug or feature idea? Please open an issue.


πŸ“„ License

Licensed under the MIT License β€” use it freely for personal or commercial projects. See LICENSE for details.

About

Manage Arrays!

Resources

License

Stars

Watchers

Forks

Languages