nastradamus39/annotation-md

此扩展解析phpdoc注释并生成可由slate docker解析的md文档

0.0.8 2017-02-22 08:30 UTC

This package is not auto-updated.

Last update: 2024-09-23 14:27:27 UTC


README

  • Phpdoc — 文档以phpdoc注释的形式呈现,从中生成.md文件。

  • Slate docker — 生成的.md文件格式支持slate

安装

composer require nastradamus39/annotation-md

使用

$controllersPath = PATH_TO_CONTROLLERS;
$buildPath = BUILD_PATH;

$params = [
            "title"     => "Заголовок",
            "baseUrl"   => "http://api.yoursite.com"
        ];

$parser = new Parser($controllersPath, $buildPath, $params);
$parser->parse();
  • $controllersPath - 搜索控制器所在的文件夹路径。
  • $buildPath - 保存单个.md文件的文件夹路径。

注释

支持的注释

  • ApiController — 描述控制器。在文档中为一个部分。
  • ApiContent — 自定义内容块。在文档中代表一个部分。
  • ApiError — 描述错误的块。添加到文档的末尾。
  • ApiAction — 控制器的动作。在文档部分中的子部分。
  • Sample - 使用javascript、php、shell、ruby、python等语言中的示例代码
  • Request - 描述请求。
  • Param - 请求参数。

JSON选项卡用于显示服务器对请求的响应示例。

/**
 * @ApiController(
 *     title="Пользователь",
 *     description="Описаие методов для работы с пользователем"
 * )
 * @ApiContent(
 *     title="Авторизация",
 *     description="Описание процесса авторизации"
 *  )
 * @ApiError(code="400", description="Bad Request – Your request sucks.")
 * @ApiError(code="401", description="Unauthorized – Your API key is wrong.")
 */
class User
{
    /**
      * @ApiAction(
      *     title="Список пользователей",
      *     description="Возвращает список пользователей",
      *     samples={
      *          @Sample(lang="javascript", code="alert('123');"),
      *          @Sample(lang="php", code="phpinfo();")
      *     }
      *     request=@Request(
      *          method="GET",
      *          url="/users",
      *          body="",
      *          params={
      *              @Param(title="param1", type="type1", defaultValue="val", description="descr"),
      *              @Param(title="param1", type="type1", defaultValue="val", description="descr")
      *          }
      *         response=@Response(body="json encoded array")
      *     )
      * )
      */
     public function listAction() {}
}