定制 yarri/master-api-client 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

yarri/master-api-client

最新稳定版本:v1.1

Composer 安装命令:

composer require yarri/master-api-client

包简介

Client for Master API

README 文档

README

Build Status

Pomoci klienta je mozne odesilat prikazy, ktere budou okamzite na strane Master API serveru provedeny. Napriklad registrace domeny muze byt realizovana na jediny HTTP pozadavek; celkovy cas potrebny pro registraci nebude delsi nez jen nekolik malo vterin.

Klient je testovan na PHP ve verzich 5.6 az 8.4.

Klient komunikuje na HTTP protokolu pres SSL. Pro navazani socketoveho spojeni pres SSL je nutne do PHP nainstalovat rozsireni OpenSSL.

Changelog

http://www.domainmaster.cz/masterapi/client/CHANGELOG

Potrebne knihovny

Soubory jsou soucasti dodavky.

<?php
require("miniyaml.inc");            // minimalisticky YAML parser
require("masterapi_client.inc");    // tridy Master API klienta
?>

Inicializace klienta

URL testovaciho serveru: http://test-api.domainmaster.cz/masterapi/server.php URL ostreho serveru: https://www.domainmaster.cz/masterapi/server.php

Testovaci Master API server je provozovan nad ne prilis aktualni kopii ostre databaze. Instance je napojena na testovaci rozhrani CZ.NICu. Pokud budete chtit vyzkouset testovaci Master API server, kontaktujte nas e-mailem na adrese info[at]generalregistry[dot]cz.

Pomoci parametru "charset" je mozne nastavit pouzitou znakovou sadu, ve ktere budou zasilany parametry prikazu (napr. u registrace kontaktu pro .cz domeny).

<?php
$client = new MasterApi_Client(array(
  "username" => "GR:PLATCE",        // prihlasovaci jmeno platce (idacc nebo iddealer)
  "password" => "heslo",            // heslo platce
  "charset" => "UTF-8",      // mozna kodovani: WINDOWS-1250, ISO-8859-2, UTF-8
  "server_url" => "https://www.domainmaster.cz/masterapi/server.php",
));
?>

Implementace klienta

Volanim metody SendCommand() bude odeslan prikaz do Master API serveru. Vracen bude objekt, ktery popisuje 3 stavy:

  • akce dopadla uspesne - pozadavek byl beze zbytku vyrizen
  • doslo k chybe - pozadavek neni mozne zpracovat, duvodem muze byt syntakticka chyba v parametrech, pokus o registraci jiz existujici domeny a podobne.
  • doslo k docasne chybe - prikaz neni mozne z nejake docasne chyboveho stavu realizovat; v takovem pripade je nutne nejakou dobu pockat (5 minut) a odeslat stejny prikaz znovu; POZOR!!! - o realizaci prikazu se opakovane nebude pokouset nas automat

Volanim metody getMessage() u navratoveho objektu lze zjistit popis pripadne chyby.

Nektere typy prikazu vyzaduji parametry. Tyto parametry vychazeji z e-mailoveho API. Dokumentace k e-mailovemu API je zde: http://www.domainmaster.cz/doc/auto_reg_cz_enum.pdf

Jiste prikazy vraceji nejaka data (napr. "list domains"). Metodou getData() lze tato data ziskat. Vraceno je asociativni pole.

<?php
// spusteni prikazu
// prvni parametr: nazev prikazu (viz nize v tomto souboru)
// druhy volitelny parametr: potrebne parametry daneho prikazu
$result = $client->sendCommand("transfer cz domain",array(
  "transfer" =>    "domena.cz",
  "auth-info" =>   "kfSkrsmc42",
  "idacc" =>       "GR:PLATCE",
  "iddealer" =>    ""
));

// zpracovani vysledku
if($result->IsSuccess()){
  // uspech
  echo "commnad was successfuly executed\n";
  echo "--------------------------------\n";
  echo "data:\n";
  print_r($result->getData()); // vrati asociativni pole nebo null (podle charakteru odpovedi)
}else{
  // NEUSPECH!
  // pokud $this->IsTemporaryError() vrati true - jedna se pravdepodobne o docasnou chybu -> nutno pockat 5 minut a pak stejny prikaz odeslat znovu
  echo "commnad WAS NOT executed successfuly\n";
  echo "------------------------------------\n";
  echo "message: ".$result->getMessage()."\n"; // popis chyby
  echo "temporary error: ".($result->IsTemporaryError() ? "yes (request should be repeated)" : "no")."\n";
  echo "------------------------------------\n";
  // pro debug ucely je mozne pouzit nasledujici metody
  // echo "http request:\n";
  // echo $result->getHttpRequest()."\n";
  // echo "http response:\n";
  // echo $result->getHttpResponse()."\n";
}
?>

Penaltovy system

Master API zaznamenava pozadavky, ktere skoncily chybou (nikoli docasnou). Pri dosazeni urciteho poctu chyb bude klient pred pouzitim Master API blokovan:

  • po dosazeni 2 chyb je klient blokovan do konce aktualni minuty
  • po dosazeni 6 chyb je klient blokovan do konce aktualni hodiny

Je-li klient blokovan, bude mu na kazdy dalsi prikaz vracena docasna chyba se zpravou: "you are blocked from the Master API because of abusive usage"

Funkce Master Api

Viz http://www.domainmaster.cz/master-api/dokumentace/

// vim: expandtab

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

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