yanggs07 / yii2-salt-api
A yii2 implement of saltstack api client
Installs: 3
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:yii2-extension
Requires
- php: >=7.4
- ext-curl: *
- lspbupt/yii2-curl: dev-master
- yiisoft/yii2: ~2.0
This package is auto-updated.
Last update: 2025-03-22 06:53:04 UTC
README
Before using this salt-api PHP SDK, enable salt-api for salt master is required.
Salt-api Installation And Configuration
see salt-api
Install salt-api for linux
# yum -y install salt-api or # apt -y install salt-api or whatever your linux system can do this
Generate self-signed cert with correct api host domain
salt-call --local tls.create_self_signed_cert CN=salt-master.server days=3650 local: Created Private Key: "/etc/pki/tls/certs/salt-master.server.key." Created Certificate: "/etc/pki/tls/certs/salt-master.server.crt."
Later we would use https://salt-master.server:8000
for remote api call and use custom CA cert file.
Copy the CA public key file /etc/pki/tls/certs/salt-master.server.crt
to your PHP project path.
Configure salt-api and salt-master
Ensure the master conf include master.d
:
[root@salt-master ~]# vim /etc/salt/master default_include: master.d/*.conf
Create new api conf:
[root@salt-master ~]# vim /etc/salt/master.d/api.conf rest_cherrypy: host: <ip_salt-api_would_listen> port: 8000 ssl_crt: /etc/pki/tls/certs/salt-master.server.crt ssl_key: /etc/pki/tls/certs/salt-master.server.key
Create salt-api user with YOUR password!
[root@salt-master ~]# useradd -M -s /sbin/nologin saltapi [root@salt-master ~]# echo 'saltapi' | passwd --stdin saltapi
Create auth conf:
[root@salt-master ~]# vim /etc/salt/master.d/auth.conf external_auth: pam: saltapi: - .* - '@wheel' - '@runner' - '@jobs'
Restart services:
[root@salt-master ~]# systemctl restart salt-master [root@salt-master ~]# systemctl start salt-api [root@salt-master ~]# systemctl enable salt-api
SDK DEMO Code
tes.php
:
<?php require '../vendor/autoload.php'; $client = new \yanggs07\saltapi\ApiClient([ 'host' => 'salt-master.server', 'port' => 8000, 'cacert' => '/path/to/your/salt-api_self-signed/ca.crt', // or use // if you do not have the ca crt file, use this instead // 'skipCertCheck' => true 'username' => 'saltapi', 'password' => 'saltapi', ]); $session = $client->pamLogin(); $ret = $client->localAsyncRun($session, "*", 'cmd.run', 'w'); $jid = $ret['jid']; for ($i = 0;$i < 30; $i++) { $ret = $client->job($session, $jid); var_dump($ret); sleep(1); } ?>
TODOs
- More api calls
- Session persistence with cache interface
- Better exception treatment
- more...