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.
β
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
)
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. |
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. |
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. |
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. |
File | Description |
---|---|
functions.php | Global shortcut functions for frequent array/config tasks. |
- PHP 8.2 or higher
composer require infocyph/arraykit
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]
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);
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' ]
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');
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
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();
Have a bug or feature idea? Please open an issue.
Licensed under the MIT License β use it freely for personal or commercial projects. See LICENSE for details.