psx / openrpc
模型类,以类型安全的方式生成 OpenRPC 规范
    v0.1.1
    2024-05-10 17:36 UTC
Requires
- php: >=8.1
- psx/openapi: ^0.1
- psx/record: ^3.0
Requires (Dev)
- phpunit/phpunit: ^9.0
- psx/schema: ^6.0
- symfony/yaml: ^5.0|^6.0|^7.0
- vimeo/psalm: ^5.0
README
关于
此库包含模型类,以类型安全的方式生成 OpenRPC 规范。模型根据 TypeSchema 规范(见 typeschema.json)自动生成。以下示例显示了如何生成 OpenRPC 规范
$license = new License(); $license->setName('MIT'); $info = new Info(); $info->setVersion('1.0.0'); $info->setTitle('Petstore'); $info->setLicense($license); $server = new Server(); $server->setUrl('https://:8080'); $params = []; $content = new ContentDescriptor(); $content->setName('limit'); $content->setDescription('How many items to return at one time (max 100)'); $content->setRequired(false); $content->setSchema((object) ['type' => 'integer', 'minimum' => 1]); $params[] = $content; $result = new ContentDescriptor(); $result->setName('pets'); $result->setDescription('A paged array of pets'); $result->setSchema((object) ['$ref' => '#/components/schemas/Pets']); $errors = []; $error = new Error(); $error->setCode(100); $error->setMessage('pets busy'); $errors[] = $error; $methods = []; $method = new Method(); $method->setName('list_pets'); $method->setSummary('List all pets'); $method->setParams($params); $method->setResult($result); $method->setErrors($errors); $methods[] = $method; $schemas = new Schemas(); $schemas->put('Pet', [ 'required' => ['id', 'name'], 'properties' => [ 'id' => ['type' => 'integer', 'format' => 'int64'], 'name' => ['type' => 'string'], 'tag' => ['type' => 'string'], ] ]); $schemas->put('Pets', [ 'type' => 'array', 'items' => ['$ref' => '#/components/schemas/Pet'], ]); $components = new Components(); $components->setSchemas($schemas); $openRPC = new OpenRPC(); $openRPC->setInfo($info); $openRPC->setServers([$server]); $openRPC->setMethods($methods); $openRPC->setComponents($components); echo json_encode($openRPC, JSON_PRETTY_PRINT);
这将产生以下 JSON
{
  "openrpc": "1.3.0",
  "info": {
    "title": "Petstore",
    "license": {
      "name": "MIT"
    },
    "version": "1.0.0"
  },
  "servers": [
    {
      "url": "http:\/\/localhost:8080"
    }
  ],
  "methods": [
    {
      "name": "list_pets",
      "summary": "List all pets",
      "params": [
        {
          "name": "limit",
          "description": "How many items to return at one time (max 100)",
          "required": false,
          "schema": {
            "type": "integer",
            "minimum": 1
          }
        }
      ],
      "result": {
        "name": "pets",
        "description": "A paged array of pets",
        "schema": {
          "$ref": "#\/components\/schemas\/Pets"
        }
      },
      "errors": [
        {
          "code": 100,
          "message": "pets busy"
        }
      ]
    }
  ],
  "components": {
    "schemas": {
      "Pet": {
        "required": [
          "id",
          "name"
        ],
        "properties": {
          "id": {
            "type": "integer",
            "format": "int64"
          },
          "name": {
            "type": "string"
          },
          "tag": {
            "type": "string"
          }
        }
      },
      "Pets": {
        "type": "array",
        "items": {
          "$ref": "#\/components\/schemas\/Pet"
        }
      }
    }
  }
}
贡献
如果您想提出更改,请只修改 typeschema.json 规范,然后运行 php gen.php 脚本来重新生成所有模型类。