teknoo / kubernetes-client
A simple yet elegant client for accessing and controlling a Kubernetes cluster.
Fund package maintenance!
Patreon
TeknooSoftware
Installs: 5 583
Dependents: 2
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: ^8.2
- ext-json: *
- illuminate/collections: ^10.48||^11
- illuminate/contracts: ^10.48||^11
- php-http/client-common: ^2.7.2
- php-http/discovery: ^1.20
- psr/http-message: ^1.0.1||^2
- symfony/yaml: ^6.4||^7.0
Requires (Dev)
- behat/behat: ^v3.14
- nyholm/psr7: ^1.8.1
- php-http/curl-client: ^2.3.1
- php-http/guzzle7-adapter: ^1
- php-http/socket-client: ^2.1.1
- phpstan/phpstan: ^1.12.6
- phpunit/phpunit: ^11.4
- roave/security-advisories: dev-latest
- squizlabs/php_codesniffer: ^3.10.3
- symfony/console: ^6.4||^7
- symfony/http-client: ^6.4||^7.0
- symfony/options-resolver: ^6.4||^7
- symfony/property-access: ^6.4||^7.0
- dev-master
- 1.7.1
- 1.7.0
- 1.6.0
- 1.5.4
- 1.5.3
- 1.5.2
- 1.5.1
- 1.5.0
- 1.4.4
- 1.4.3
- 1.4.2
- 1.4.1
- 1.4.0
- 1.3.4
- 1.3.3
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.1
- 1.1.0
- 1.0.2
- 1.0.1
- 1.0.0
- 0.31.0
- 0.30.3
- 0.30.2
- 0.30.1
- 0.30.0
- 0.26.0
- 0.25.0
- 0.24.0
- 0.23.0
- 0.22.0
- 0.21.0
- 0.20.0
- 0.19.0
- 0.18.3
- 0.18.2
- 0.18.1
- 0.18.0
- 0.17.0
- 0.16.0
- 0.15.0
- 0.14.3
- 0.14.2
- 0.14.1
- 0.14.0
- 0.13.0
- 0.12.1
- 0.12.0
- 0.11.0
- 0.10.0
- 0.9.1
- 0.9.0
- 0.8.1
- 0.8.0
- 0.7.0
- 0.6.0
- 0.5.1
- 0.5.0
- 0.4.2
- 0.4.1
- 0.4.0
- 0.3.0
- 0.2.5
- 0.2.4
- 0.2.3
- 0.2.2
- 0.2.1
- 0.2.0
- 0.1.4
- 0.1.3
- 0.1.2
- 0.1.1
- 0.1.0
- 0.0.10
- 0.0.9
- 0.0.8
- 0.0.7
- 0.0.6
- 0.0.5
- 0.0.4
- 0.0.3
- 0.0.2
- 0.0.1
This package is auto-updated.
Last update: 2024-11-28 20:32:47 UTC
README
A PHP client for managing a Kubernetes cluster. Control your Kubernetes resources by manipulating manifests, as PHP array, through the Kubernetes HTTP API. The client supports all Kubernetes API V1.28 resources, but it's possible to define new resource usable with the client. This is a fork and a rework from Maclof Kuebrnetes library.
Supported API Features
v1
- Config Maps
- Delete Options
- EndPoints
- Endpoints
- Events
- Namespaces
- Nodes
- Persistent Volume
- Persistent Volume Claims
- Pods
- Quota
- Replica Sets
- Replication Controllers
- Secrets
- Service Account
- Services
autoscaling/v2
- Horizontal Pad Autoscaler
batch/v1
- CronJobs
- Jobs
batch/v1beta1
- Cron Jobs
apps/v1
- Daemon Set
- Deployments
- ReplicaSet
extensions/v1beta1
- Daemon Sets
networking.k8s.io/v1
- Ingresses
- Network Policies
certmanager.k8s.io/v1
- Certificates
- Issuers
rbac.authorization.k8s.io/v1
- ClusterRole
- ClusterRoleBinding
- Role
- RoleBinding
hnc.x-k8s.io/v1
- Subnamespace Anchor
Basic Usage
use Teknoo\Kubernetes\Client;
$client = new Client([
'master' => 'http://master.mycluster.com',
]);
// Find pods by label selector
$pods = $client->pods()
->setLabelSelector(
[
'name' => 'test',
'version' => 'a',
]
)->find();
// Both setLabelSelector and setFieldSelector can take an optional
// second parameter which lets you define inequality based selectors (ie using the != operator)
$pods = $client->pods()
->setLabelSelector(
['name' => 'test'],
['env' => 'staging']
)->find();
// Find pods by field selector
$pods = $client->pods()->setFieldSelector(['metadata.name' => 'test'])->find();
// Find first pod with label selector (same for field selector)
$pod = $client->pods()->setLabelSelector(['name' => 'test'])->first();
Authentication Examples
Insecure HTTP
use Teknoo\Kubernetes\Client; $client = new Client([ 'master' => 'http://master.mycluster.com', ]);
Connecting from a kubeconfig file
use Teknoo\Kubernetes\Client; // Parsing from the file data directly $client = Client::loadFromKubeConfig('kubeconfig yaml data'); // Parsing from the file path $client = Client::loadFromKubeConfigFile('~/.kube/config.yml');
Extending a library
Custom repositories
use Teknoo\Kubernetes\Client; $repositories = new RepositoryRegistry(); $repositories['things'] = MyApp\Kubernetes\Repository\ThingRepository::class; $client = new Client( [ 'master' => 'https://master.mycluster.com', ], $repositories ); $client->things(); //ThingRepository
Usage Examples
Create/Update a Replication Controller
The below example uses an array to specify the replication controller's attributes. You can specify the attributes either as an array, JSON encoded string or a YAML encoded string. The second parameter to the model constructor is the data type and defaults to array.
use Teknoo\Kubernetes\Model\ReplicationController; $replicationController = new ReplicationController([ 'metadata' => [ 'name' => 'nginx-test', 'labels' => [ 'name' => 'nginx-test', ], ], 'spec' => [ 'replicas' => 1, 'template' => [ 'metadata' => [ 'labels' => [ 'name' => 'nginx-test', ], ], 'spec' => [ 'containers' => [ [ 'name' => 'nginx', 'image' => 'nginx', 'ports' => [ [ 'containerPort' => 80, 'protocol' => 'TCP', ], ], ], ], ], ], ], ]); if ($client->replicationControllers()->exists($replicationController->getMetadata('name'))) { $client->replicationControllers()->update($replicationController); } else { $client->replicationControllers()->create($replicationController); } $client->replicationControllers()->apply($replicationController); // or
Delete a Replication Controller
$replicationController = $client->replicationControllers()->setLabelSelector(['name' => 'nginx-test'])->first(); $client->replicationControllers()->delete($replicationController);
You can also specify options when performing a deletion, eg. to perform cascading delete
use Teknoo\Kubernetes\Model\DeleteOptions; $client->replicationControllers()->delete( $replicationController, new DeleteOptions(['propagationPolicy' => 'Background']) );
Support this project
This project is free and will remain free. It is fully supported by the activities of the EIRL. If you like it and help me maintain it and evolve it, don't hesitate to support me on Patreon or Github.
Thanks :) Richard.
Credits
EIRL Richard Déloge - https://deloge.io - Lead developer. SASU Teknoo Software - https://teknoo.software
About Teknoo Software
Teknoo Software is a PHP software editor, founded by Richard Déloge, as part of EIRL Richard Déloge. Teknoo Software's goals : Provide to our partners and to the community a set of high quality services or software, sharing knowledge and skills.
License
Kubernetes Client is licensed under the MIT License - see the licenses folder for details.
Installation & Requirements
To install this library with composer, run this command :
composer require teknoo/kubernetes-client
This library requires :
* PHP 8.1+
* A PHP autoloader (Composer is recommended)
* Symfony/Yaml.
* Illuminate/Collections
Contribute :)
You are welcome to contribute to this project. Fork it on Github