承接 digitalcz/digisign 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

digitalcz/digisign

最新稳定版本:v2.11.0

Composer 安装命令:

composer require digitalcz/digisign

包简介

DigiSign PHP library - provides communication with https://api.digisign.org in PHP via PSR-18 HTTP Client

README 文档

README

Latest Version on Packagist Software License CI Scrutinizer Code Quality codecov Total Downloads

DigiSign PHP library - provides communication with https://api.digisign.org in PHP using PSR-18 HTTP Client, PSR-17 HTTP Factories and PSR-16 SimpleCache.

API documentation is here https://api.digisign.org/api/docs

Install

Via Composer

$ composer require digitalcz/digisign

Configuration

Example configuration in PHP

use DigitalCz\DigiSign\Auth\ApiKeyCredentials; use DigitalCz\DigiSign\DigiSign; // Via constructor options $dgs = new DigiSign([ 'access_key' => '...', 'secret_key' => '...' ]); // Or via methods $dgs = new DigiSign(); $dgs->setCredentials(new ApiKeyCredentials('...', '...'));

Available constructor options

  • access_key - string; ApiKey access key
  • secret_key - string; ApiKey secret key
  • credentials - DigitalCz\DigiSign\Auth\Credentials instance
  • client - DigitalCz\DigiSign\DigiSignClient instance with your custom PSR17/18 objects
  • http_client - Psr\Http\Client\ClientInterface instance of your custom PSR18 client
  • cache - Psr\SimpleCache\CacheInterface for caching Credentials Tokens
  • sandbox - bool; whether to use sandbox or production API
  • api_base - string; override the base API url
  • signature_tolerance - int; The tolerance for webhook signature age validation (in seconds)

Available configuration methods

use DigitalCz\DigiSign\Auth\Token; use DigitalCz\DigiSign\Auth\TokenCredentials; use DigitalCz\DigiSign\DigiSign; use DigitalCz\DigiSign\DigiSignClient; use Symfony\Component\Cache\Adapter\FilesystemAdapter; use Symfony\Component\Cache\Psr16Cache; use Symfony\Component\HttpClient\Psr18Client; $dgs = new DigiSign(); // To set your own PSR-18 HTTP Client, if not provided Psr18ClientDiscovery is used $dgs->setClient(new DigiSignClient(new Psr18Client())); // If you already have the auth-token, i can use TokenCredentials $dgs->setCredentials(new TokenCredentials(new Token('...', 123))); // Cache will be used to store auth-token, so it can be reused in later requests $dgs->setCache(new Psr16Cache(new FilesystemAdapter())); // Use sandbox API (https://api.staging.digisign.org) $dgs->useSandbox(true); // Overwrite API base $dgs->setApiBase('https://example.com/api'); // Set maximum age of webhook request to one minute $dgs->setSignatureTolerance(60);

Example configuration in Symfony

services: DigitalCz\DigiSign\DigiSign: $options: # minimal config access_key: '%digisign.accessKey%' secret_key: '%digisign.secretKey%' # other options cache: '@psr16.cache' http_client: '@psr18.http_client' sandbox: true # use sandbox API

Usage

Create and send Envelope

$dgs = new DigitalCz\DigiSign\DigiSign(['access_key' => '...', 'secret_key' => '...']); $envelopes = $dgs->envelopes(); $envelope = $envelopes->create([ 'emailSubject' => 'Please sign', 'emailBody' => 'Hello James, please sign these documents.', 'senderName' => 'John Smith', 'senderEmail' => 'john.smith@example.com' ]); $recipient = $envelopes->recipients($envelope)->create([ 'role' => 'signer', 'name' => 'James Brown', 'email' => 'james42@example.com', 'mobile' => '+420775300500', ]); $stream = DigitalCz\DigiSign\Stream\FileStream::open('path/to/document.pdf'); $file = $dgs->files()->upload($stream); $document = $envelopes->documents($envelope)->create([ 'name' => 'Contract', 'file' => $file->self() ]); $tag = $envelopes->tags($envelope)->create([ 'type' => 'signature', 'document' => $document, 'recipient' => $recipient, 'page' => 1, 'xPosition' => 200, 'yPosition' => 340 ]); $envelopes->send($envelope->id());

See examples for more

Change log

Please see CHANGELOG for more information on what has changed recently.

Testing

$ composer csfix # fix codestyle $ composer checks # run all checks  # or separately $ composer tests # run phpunit $ composer phpstan # run phpstan $ composer cs # run codesniffer

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email devs@digital.cz instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 35.24k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 5
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 5
  • Watchers: 2
  • Forks: 9
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固