Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/xavier-lam/ys7

海康威视设备萤石开放平台(萤石云)PHP SDK,用于接入海康设备直播,通信等功能
https://github.com/xavier-lam/ys7

ezuikit ezviz hikvision php-sdk ysopen

Last synced: 27 days ago
JSON representation

海康威视设备萤石开放平台(萤石云)PHP SDK,用于接入海康设备直播,通信等功能

Awesome Lists containing this project

README

        

# 萤石开放平台PHP SDK

[![Packagist Version](https://img.shields.io/packagist/v/neteast/ys7)](https://packagist.org/packages/neteast/ys7)
[![Donate with Bitcoin](https://en.cryptobadges.io/badge/micro/1BdJG31zinrMFWxRt2utGBU2jdpv8xSgju)](https://en.cryptobadges.io/donate/1BdJG31zinrMFWxRt2utGBU2jdpv8xSgju)

海康威视设备萤石开放平台(萤石云)PHP SDK,用于接入海康设备直播,通信等功能

官方文档:
> https://open.ys7.com/doc/zh/book/index/user.html

## Installation
composer require neteast/ys7

## Quickstart

use Neteast\YS7\YS7Auth;
use Neteast\YS7\YS7Client;

$auth = new YS7Auth($appKey, $appSecret);
$client = new YS7Client($auth);

// 新增设备
$client->device->add($deviceSerial, $validateCode);

// 获取设备列表
$devices = $client->device->list();

// 获取设备信息
$info = $client->device->info($deviceSerial);

// 获取摄像头列表
$cameras = $client->device->camera->list();

// 根据设备获取摄像头列表
$cameras = $client->device->cameras($deviceSerial);

// 关闭加密功能
$client->device->configuration->setEncrypt($deviceSerial, $validateCode, false);

// 开启下线通知
$client->device->configuration->setNotify($deviceSerial, true);

### 云台
// 控制云台转动
$client->ptz->start($deviceSerial, \Neteast\YS7\Enum\PTZ::DIRECTION_UP);
sleep(1);
$client->ptz->stop();

### 地址获取
// 开通直播功能
$client->live->open($deviceSerial, $channelNo);

// 获取直播地址
$data = $client->live->address($deviceSerial, $expiresIn, $channelNo);

// 获取录像列表
$records = $client->device->records($deviceSerial);

// 获取ezopen直播地址
$addr = $client->ezopen->live($deviceSerial, $channelNo);
// 获取ezopen录像地址
$addr = $client->ezopen->rec($deviceSerial, $channelNo, 1598940000);

### 通知
// 通知
$consumer = $client->consumer();
$consumer->addHandler(function(\Neteast\YS7\Message\DataObject\Message $message, \Neteast\YS7\Message\Consumer $consumer, YS7Client $client) {
// 你的处理业务逻辑
});

// 开始消费消息
while(true) {
$consumer->consume();
sleep(30);
}

### 子账号
// 创建子账号
$accountId = $client->ram->account->create($accountName, $password);

// 获取子账号信息
$data = $client->ram->account->get($accountId);

// 设置子账号权限策略
use Neteast\YS7\Policy\Permission;
use Neteast\YS7\Policy\Resource;
use Neteast\YS7\Policy\Statement;

$devices = [Resource::create($deviceSerial, $channelNo)];
$permissions = [Permission::UPDATE];
$statements = [Statement::create($permissions, $devices)];
$client->ram->policy->set($statements);

// 获取子账号auth
$auth = $client->ram->token->get($accountId);

// 使用子账号
$client = new YS7Client($auth);
$client->device->list();

## TODOS
* 消息处理相关信号

## Contribute
对于需要使用并未封装的api,可依照本类库封装风格进行封装,通过pull request合作开发

## Changelog
### 0.2.0
* 拆分httpclient

### 0.1.0
* 基本功能封装