Documentation ¶
Overview ¶
Package openapi Basa OpenAPI Document
basa 开放 API (以下简称 openapi)是一组便于开发者调试、第三方工具开发和 CI/CD 的开放数据接口。 openapi 虽然格式上满足 Restful,但是并不是单一接口只针对特定资源的操作,在大部分时候单一接口会操作一组资源; 同时,虽然 openapi 下只允许通过 GET 请求访问,但是并不意味着 GET 操作代表着 Restful 中对 GET 的用法定义; openapi 的路径格式:/openapi/v1/gateway/action/:action,:action 代表特定操作,例如: get_vip_info、upgrade_deployment。
openapi 所操作的 action 必须搭配具有该 action 权限的 APIKey 使用(作为一个命名为 apikey 的 GET 请求参数), 而对应的 apikey 需要具备 action 对应的权限(例如:action 对应 get_pod_info 的时候,apikey 需要具备 OPENAPI_GET_POD_INFO 权限), 同时,受限于某些action的使用场景,可能强制要求附加的 APIKey 的使用范围,目前APIKey的适用范围包括三种,App 级别、Namespace 级别 以及 全局级别。 Terms Of Service:
Schemes: https Host: localhost BasePath: /openapi/v1/gateway/action Version: 1.6.1 Consumes: - application/json Produces: - application/json Security: - api_key: SecurityDefinitions: api_key: type: apiKey name: apikey in: query
swagger:meta
Index ¶
- Constants
- type DeploymentInfo
- type DeploymentStatus
- type DeploymentStatusParam
- type OpenAPIController
- func (c *OpenAPIController) CheckDeploymentPermission(deployment string) bool
- func (c *OpenAPIController) CheckNamespacePermission(namespace string) bool
- func (c *OpenAPIController) CheckoutRoutePermission(action string) bool
- func (c *OpenAPIController) GetDeploymentDetail()
- func (c *OpenAPIController) GetDeploymentStatus()
- func (c *OpenAPIController) GetLatestDeploymentTpl()
- func (c *OpenAPIController) GetPodInfo()
- func (c *OpenAPIController) GetPodInfoFromIP()
- func (c *OpenAPIController) GetPodList()
- func (c *OpenAPIController) GetResourceInfo()
- func (c *OpenAPIController) ListAppDeploys()
- func (c *OpenAPIController) ListNamespaceApps()
- func (c *OpenAPIController) ListNamespaceUsers()
- func (c *OpenAPIController) Prepare()
- func (c *OpenAPIController) RestartDeployment()
- func (c *OpenAPIController) ScaleDeployment()
- func (c *OpenAPIController) UpgradeDeployment()
- type PodInfoFromIPParam
- type PodInfoParam
- type PodListParam
- type RestartDeploymentParam
- type ScaleDeploymentParam
- type UpgradeDeploymentParam
Constants ¶
const ( GetPodInfoAction = "GET_POD_INFO" GetPodInfoFromIPAction = "GET_POD_INFO_FROM_IP" GetResourceInfoAction = "GET_RESOURCE_INFO" GetDeploymentStatusAction = "GET_DEPLOYMENT_STATUS" UpgradeDeploymentAction = "UPGRADE_DEPLOYMENT" ScaleDeploymentAction = "SCALE_DEPLOYMENT" RestartDeploymentAction = "RESTART_DEPLOYMENT" GetDeploymentDetailAction = "GET_DEPLOYMENT_DETAIL" GetLatestDeploymentTplAction = "GET_LATEST_DEPLOYMENT_TPL" GetPodListAction = "GET_POD_LIST" ListNamespaceUsers = "LIST_NAMESPACE_USERS" ListNamespaceApps = "LIST_NAMESPACE_APPS" ListAppDeploys = "List_APP_DEPLOYS" PermissionPrefix = "OPENAPI_" )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type DeploymentInfo ¶
type DeploymentInfo struct { Deployment *models.Deployment DeploymentTemplete *models.DeploymentTemplate DeploymentObject *appsv1.Deployment Cluster *models.Cluster Namespace *models.Namespace }
type DeploymentStatus ¶
type DeploymentStatus struct { // required: true Pods []response.Pod `json:"pods"` // required: true Deployment response.Deployment `json:"deployment"` // required: true Healthz bool `json:"healthz"` }
swagger:model deploymentstatus
type DeploymentStatusParam ¶
type DeploymentStatusParam struct { // in: query // Required: true Deployment string `json:"deployment"` // Required: true Namespace string `json:"namespace"` // 和升级部署存在差别,不允许同时填写多个 cluster // Required: true Cluster string `json:"cluster"` }
swagger:parameters DeploymentStatusParam
type OpenAPIController ¶
type OpenAPIController struct {
base.APIKeyController
}
func (*OpenAPIController) CheckDeploymentPermission ¶
func (c *OpenAPIController) CheckDeploymentPermission(deployment string) bool
func (*OpenAPIController) CheckNamespacePermission ¶
func (c *OpenAPIController) CheckNamespacePermission(namespace string) bool
func (*OpenAPIController) CheckoutRoutePermission ¶
func (c *OpenAPIController) CheckoutRoutePermission(action string) bool
func (*OpenAPIController) GetDeploymentDetail ¶
func (c *OpenAPIController) GetDeploymentDetail()
swagger:route GET /get_deployment_detail deploy DeploymentDetailParam
通过给定的namespace、app name、deployment name来查询某个具体deployment的信息
因为查询范围是对所有的服务进行的,因此需要绑定 全局 apikey 使用。
Responses: 200: respresourceinfo 400: responseState 500: responseState
@router /get_deployment_detail [get]
func (*OpenAPIController) GetDeploymentStatus ¶
func (c *OpenAPIController) GetDeploymentStatus()
swagger:route GET /get_deployment_status deploy DeploymentStatusParam
该接口用于返回特定部署的状态信息
重点关注 kubernetes 集群内状态而非描述信息,当然也可以只关注 healthz 字段。 该接口可以使用所有种类的 apikey
Responses: 200: respdeploymentstatus 400: responseState 401: responseState 500: responseState
@router /get_deployment_status [get]
func (*OpenAPIController) GetLatestDeploymentTpl ¶
func (c *OpenAPIController) GetLatestDeploymentTpl()
swagger:route GET /get_latest_deployment_tpl deploy LatestDeploymentTplParam
通过给定的namespace、app name、deployment name来查询某个具体deployment的最新部署模板信息
因为查询范围是对所有的服务进行的,因此需要绑定 全局 apikey 使用。
Responses: 200: respresourceinfo 400: responseState 500: responseState
@router /get_latest_deployment_tpl [get]
func (*OpenAPIController) GetPodInfo ¶
func (c *OpenAPIController) GetPodInfo()
swagger:route GET /get_pod_info pod PodInfoParam
用于获取线上所有 pod 中包含请求条件中 labelSelector 指定的特定 label 的 pod
返回 每个 pod 的 pod IP 和 所有 label 列表。 需要绑定全局 apikey 使用。该接口的权限控制为只能使用全局 apikey 的原因是查询条件为 labelSelector ,是对所有 app 的 条件过滤。
Responses: 200: resppodlist 401: responseState 500: responseState
@router /get_pod_info [get]
func (*OpenAPIController) GetPodInfoFromIP ¶
func (c *OpenAPIController) GetPodInfoFromIP()
swagger:route GET /get_pod_info_from_ip pod PodInfoFromIPParam
用于通过线上 kubernetes Pod IP 反查对应 Pod 信息的接口
返回 每个 pod 的 pod IP 和 所有 label 列表。 需要绑定全局 apikey 使用。该接口的权限控制为只能使用全局 apikey 的原因是查询条件为 IP ,是对所有 app 的 条件过滤。
Responses: 200: resppodlist 401: responseState 500: responseState
@router /get_pod_info_from_ip [get]
func (*OpenAPIController) GetPodList ¶
func (c *OpenAPIController) GetPodList()
swagger:route GET /get_pod_list pod PodListParam
用于根据资源类型获取所有机房Pod列表
返回 Pod 信息 需要绑定全局 apikey 使用。
Responses: 200: respPodInfoList 401: responseState 500: responseState
@router /get_pod_list [get]
func (*OpenAPIController) GetResourceInfo ¶
func (c *OpenAPIController) GetResourceInfo()
swagger:route GET /get_resource_info resource ResourceInfoParam
通过给定的资源类型和资源名称反查出资源所属的 app 和 用户信息
因为查询范围是对所有的服务进行的,因此需要绑定 全局 apikey 使用。
Responses: 200: respresourceinfo 400: responseState 500: responseState
@router /get_resource_info [get]
func (*OpenAPIController) ListAppDeploys ¶
func (c *OpenAPIController) ListAppDeploys()
swagger:route GET /get_app_deploys resource ResourceInfoParam
通过给定的app,查询deploy信息
因为查询范围是对所有的服务进行的,因此需要绑定 全局 apikey 使用。
Responses: 200: respresourceinfo 400: responseState 500: responseState
@router /get_app_deploys [get]
func (*OpenAPIController) ListNamespaceApps ¶
func (c *OpenAPIController) ListNamespaceApps()
swagger:route GET /list_namespace_apps resource ResourceInfoParam
通过给定的namespace,获取 app 信息和用户信息
因为查询范围是指定namespace,因此需要绑定 namespace apikey 使用。
Responses: 200: respresourceinfo 400: responseState 500: responseState
@router /list_namespace_apps [get]
func (*OpenAPIController) ListNamespaceUsers ¶
func (c *OpenAPIController) ListNamespaceUsers()
swagger:route GET /list_namespace_users resource ResourceInfoParam
通过给定的namespace,获取 用户信息
因为查询范围是指定namespace,因此需要绑定 namespace apikey 使用。
Responses: 200: respresourceinfo 400: responseState 500: responseState
@router /list_namespace_users [get]
func (*OpenAPIController) Prepare ¶
func (c *OpenAPIController) Prepare()
func (*OpenAPIController) RestartDeployment ¶
func (c *OpenAPIController) RestartDeployment()
swagger:route GET /restart_deployment deploy RestartDeploymentParam
用于用户调用以实现强制重启部署
该接口只能使用 app 级别的 apikey,这样做的目的主要是防止 apikey 的滥用
Responses: 200: responseSuccess 400: responseState 401: responseState 500: responseState
@router /restart_deployment [get]
func (*OpenAPIController) ScaleDeployment ¶
func (c *OpenAPIController) ScaleDeployment()
swagger:route GET /scale_deployment deploy ScaleDeploymentParam
用于 CI/CD 中的部署水平扩容/缩容
副本数量范围为0-32 该接口只能使用 app 级别的 apikey,这样做的目的主要是防止 apikey 的滥用
Responses: 200: responseSuccess 400: responseState 401: responseState 500: responseState
@router /scale_deployment [get]
func (*OpenAPIController) UpgradeDeployment ¶
func (c *OpenAPIController) UpgradeDeployment()
swagger:route GET /upgrade_deployment deploy UpgradeDeploymentParam
用于 CI/CD 中的集成升级部署
该接口只能使用 app 级别的 apikey,这样做的目的主要是防止 apikey 的滥用。 目前用户可以选择两种用法,第一种是默认的,会根据请求的 images 和 environments 对特定部署线上模板进行修改并创建新模板,然后使用新模板进行升级; 需要说明的是,environments 列表会对 deployment 内所有容器中包含指定环境变量 key 的环境变量进行更新,如不包含,则不更新。 第二种是通过指定 publish=false 来关掉直接上线,这种条件下会根据 images 和 environments 字段创建新的模板,并返回新模板id,用户可以选择去平台上手动上线或者通过本接口指定template_id参数上线。 cluster 字段可以选择单个机房也可以选择多个机房,对于创建模板并上线的用法,会根据指定的机房之前的模板进行分类(如果机房 a 和机房 b 使用同一个模板,那么调用以后仍然共用一个新模板) 而对于指定 template_id 来上线的形式,则会忽略掉所有检查,直接使用特定模板上线到所有机房。
Responses: 200: responseSuccess 400: responseState 401: responseState 500: responseState
@router /upgrade_deployment [get]
type PodInfoFromIPParam ¶
type PodInfoFromIPParam struct { // in: query // Pod IP 列表,使用逗号分隔 // Required: true IPS string `json:"ips"` // Required: true Cluster string `json:"cluster"` // contains filtered or unexported fields }
swagger:parameters PodInfoFromIPParam
type PodInfoParam ¶
type PodInfoParam struct { // in: query // Pod Label Key,只允许填写一个 // Required: true LabelSelector string `json:"labelSelector"` // Required: true Cluster string `json:"cluster"` }
swagger:parameters PodInfoParam
type PodListParam ¶
type PodListParam struct { // Basa 的 namespace 名称,必须与 Name 同时存在或者不存在 // in: query // Required: false Namespace string `json:"namespace"` // 资源名称,必须与 Namespace 同时存在或者不存在 // in: query // Required: false Name string `json:"name"` // 资源类型:daemonsets,deployments,cronjobs,statefulsets // in: query // Required: true Type api.ResourceName `json:"type"` }
swagger:parameters PodListParam
type RestartDeploymentParam ¶
type RestartDeploymentParam struct { // in: query // Required: true Deployment string `json:"deployment"` // Required: true Namespace string `json:"namespace"` // 和升级部署存在差别,不允许同时填写多个 cluster // Required: true Cluster string `json:"cluster"` }
swagger:parameters RestartDeploymentParam
type ScaleDeploymentParam ¶
type ScaleDeploymentParam struct { // in: query // Required: true Deployment string `json:"deployment"` // Required: true Namespace string `json:"namespace"` // 和升级部署存在差别,不允许同时填写多个 cluster // Required: true Cluster string `json:"cluster"` // 期望调度到的副本数量,范围:(0,32] // Required: true Replicas int `json:"replicas"` }
swagger:parameters ScaleDeploymentParam
type UpgradeDeploymentParam ¶
type UpgradeDeploymentParam struct { // in: query // Required: true Deployment string `json:"deployment"` // Required: true Namespace string `json:"namespace"` // 支持同时填写多个 Cluster,只需要在 cluster 之间使用英文半角的逗号分隔即可 // Required: true Cluster string `json:"cluster"` // Required: false TemplateId int `json:"template_id"` // 该字段为 true 的时候,会自动使用新生成的配置模板上线,否则会只创建对应的模板,并且将模板 ID 返回(用于敏感的需要手动操作的上线环境) // Required: false Publish bool `json:"publish"` // 升级的描述 // Required: false Description string `json:"description"` // 该字段为扁平化为字符串的 key-value 字典,填写格式为 容器名1=镜像名1,容器名2=镜像名2 (即:多个容器之间使用英文半角的逗号分隔) // Required: false Images string `json:"images"` // 该字段为扁平化为字符串的 key-value 字典,填写格式为 环境变量1=值1,环境变量2=值2 (即:多个环境变量之间使用英文半角的逗号分隔) // Required: false Environments string `json:"environments"` // contains filtered or unexported fields }
swagger:parameters UpgradeDeploymentParam