Documentation ¶
Index ¶
- Constants
- type AuthCallbackResponse
- type BuildResource
- type Daemon
- type Deploy
- type DeployConfig
- type DeployCreationResponse
- type DeployDelResponse
- type DeployGetResponse
- type DeployListResponse
- type DeployPlan
- type DeployPlanStatus
- type DeploySetResponse
- type DeploymentKind
- type Event
- type EventID
- type EventStatus
- type FilterResponse
- type GetEventResponse
- type GetProfileResponse
- type HealthCheckResponse
- type Hook
- type JenkinsConfig
- type KeepPoilcyRule
- type ListRepoResponse
- type LogoutResponse
- type NodeResource
- type NotifyProfile
- type NotifySetting
- type Operation
- type Profile
- type Project
- type ProjectCreationResponse
- type ProjectDelResponse
- type ProjectGetResponse
- type ProjectListResponse
- type ProjectSetResponse
- type ProjectVersion
- type ProjectVersionCreationResponse
- type ProjectVersionGetResponse
- type ProjectVersionListResponse
- type QueueStatus
- type RegistryCompose
- type Repo
- type RepositoryStatus
- type RequestTokenResponse
- type Resource
- type ResourceCompose
- type ResourceGetResponse
- type ResourceSetResponse
- type SMTPServerConfig
- type Security
- type Service
- type ServiceCreationResponse
- type ServiceDelResponse
- type ServiceDependency
- type ServiceGetResponse
- type ServiceListResponse
- type ServiceRepository
- type ServiceSetResponse
- type SetEvent
- type SetEventResponse
- type Version
- type VersionBuildResponse
- type VersionConcelResponse
- type VersionControlSystem
- type VersionCreationResponse
- type VersionDeployStatus
- type VersionDeployment
- type VersionGetResponse
- type VersionKeepPolicy
- type VersionListResponse
- type VersionLiveInfo
- type VersionLog
- type VersionLogCreateResponse
- type VersionLogGetResponse
- type VersionOperation
- type VersionOperator
- type VersionStatus
- type VersionTag
- type VscToken
- type WebhookGithub
- type WebhookGitlab
- type WebhookResponse
- type WebhookSVN
- type WorkerInfo
- type WorkerNode
- type WorkerNodeCreateResponse
- type WorkerNodeDelResponse
- type WorkerNodeGetResponse
- type WorkerNodeType
- type WorkerNodesListResponse
- type YamlDeployFlag
Constants ¶
const ( // GITHUB is the name of github. GITHUB string = "github" // GITLAB is the name of gitlab. GITLAB string = "gitlab" )
const ( CISuccess string = "success" CIFailure string = "failure" CIPending string = "pending" )
CIStatus defines the status of a ci
const ( GithubWebhookIgnore string = "ignore" GithubWebhookPush string = "push" GithubWebhookPullRequest string = "pull_request" GithubWebhookRelease string = "release" )
Github webhook event type
const ( GithubWebhookFlagRelease string = "release" GithubWebhookFlagCommit string = "head_commit" GithubWebhookFlagPR string = "pull_request" GithubWebhookFlagAction string = "action" GithubWebhookFlagRef string = "ref" GithubWebhookFlagTags string = "tags" )
Github webhook payload flag
const ( PRActionOpened string = "opened" PRActionSynchronize string = "synchronize" )
Github pull request actions
const ( GitlabWebhookIgnore string = "ignore" GitlabWebhookPush string = "push" GitlabWebhookPullRequest string = "merge_request" GitlabWebhookRelease string = "tag_push" )
Gitlab webhook event type
const ( GitlabWebhookFlagRef string = "ref" GitlabWebhookFlagTags string = "tags" )
Gitlab webhook payload flag
const ( // APIVersion is the version of API. // TODO: Make this package versioned. Right now, this is only used for indetifying // the endpoints, i.e. /api/v0.1/; we can't really do version control with it. APIVersion string = "v0.1" )
const AutoCreateTagFlag = "_Cyclone"
AutoCreateTagFlag is the default tag postfix.
const ( // DeployOperationSuccess represents deploy operates successfully DeployOperationSuccess string = "success" )
const (
SVNWebhookCommit string = "commit"
)
SVN webhook event type
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type AuthCallbackResponse ¶
type AuthCallbackResponse struct { Result string `json:"result,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
AuthCallbackResponse is the response type for auth callback request.
type BuildResource ¶
type BuildResource struct { // The memory config Memory float64 `bson:"memory" json:"memory"` // The cpu config CPU float64 `bson:"cpu" json:"cpu"` }
BuildResource is config of resource for building image
type Daemon ¶
type Daemon struct { //VersionID is the cancelled version's ID VersionID string `bson:"versionid,omitempty" json:"versionid,omitempty"` // DaemonPoolID is the docker daemon pool ID DaemonPoolID string `bson:"daemonpool_id,omitempty" json:"daemonpool_id,omitempty"` // EnterPoint is the docker daemon's enterpoint EnterPoint string `bson:"enterpoint,omitempty" json:"enterpoint,omitempty"` }
Daemon records value that is used to store in db
type Deploy ¶
type Deploy struct { // The identifies of deploy. DeployID string `bson:"_id,omitempty" json:"_id,omitempty"` // The user who owns the deploy. UserID string `bson:"user_id,omitempty" json:"user_id,omitempty"` // Deploy plan DeployPlan DeployPlan `bson:"deploy_plan,omitempty" json:"deploy_plan,omitempty"` }
Deploy is the management unit in release system.
type DeployConfig ¶
type DeployConfig struct { // Cluster name ClusterName string `bson:"cluster_name,omitempty" json:"cluster_name,omitempty"` // Cluster id ClusterID string `bson:"cluster_id,omitempty" json:"cluster_id,omitempty"` // namespace name Namespace string `bson:"namespace,omitempty" json:"namespace,omitempty"` // deployment name Deployment string `bson:"deployment,omitempty" json:"deployment,omitempty"` // container names Containers []string `bson:"containers,omitempty" json:"containers,omitempty"` }
DeployConfig is the type for deplyment config.
type DeployCreationResponse ¶
type DeployCreationResponse struct { DeployID string `json:"deploy_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
DeployCreationResponse is the response type for deploy creation request
type DeployDelResponse ¶
type DeployDelResponse struct { Result string `json:"result,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
DeployDelResponse is the response type for deploy delete request
type DeployGetResponse ¶
type DeployGetResponse struct { Deploy Deploy `json:"deploy,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
DeployGetResponse is the response type for deploy get request.
type DeployListResponse ¶
type DeployListResponse struct { Deploys []Deploy `json:"deploys,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
DeployListResponse is the response type for deploy list request.
type DeployPlan ¶
type DeployPlan struct { // Plan name PlanName string `bson:"plan_name,omitempty" json:"plan_name,omitempty"` // Deploy config Config DeployConfig `bson:"config,omitempty" json:"config,omitempty"` }
DeployPlan is the type for deployment plan.
type DeployPlanStatus ¶
type DeployPlanStatus struct { // Plan name PlanName string `bson:"plan_name,omitempty" json:"plan_name,omitempty"` // Deploy config Config DeployConfig `bson:"config,omitempty" json:"config,omitempty"` // Deploy status Status VersionDeployStatus `bson:"status,omitempty" json:"status,omitempty"` }
DeployPlanStatus is the type for deployment plan config and status.
type DeploySetResponse ¶
type DeploySetResponse struct { Result string `json:"result,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
DeploySetResponse is the response type for deploy set request
type DeploymentKind ¶
type DeploymentKind string
DeploymentKind is the type for kind of deployment.
const ( // DeploymentKindNew is a kind of deployment, represents "deploy a new version". DeploymentKindNew DeploymentKind = "new" // DeploymentKindRollingUpgrade is a kind of deployment, represents "rolling upgrade from an old version". DeploymentKindRollingUpgrade DeploymentKind = "rollingupgrade" // DeploymentKindRollack is a kind of deployment, represents "rollback to an old version". DeploymentKindRollack DeploymentKind = "rollback" )
type Event ¶
type Event struct { // ID of the event, uniquely identifies the event. EventID EventID `bson:"event_id,omitempty" json:"event_id,omitempty"` // Operation the event is about, like cloning repository event, building // image event, etc. Operation Operation `bson:"operation,omitempty" json:"operation,omitempty"` // Almost all Cyclone event deal with user, service, version - the core // concept in Cyclone; therefore, event carries these properties. Note // sender might not set all of them. Service Service `bson:"service,omitempty" json:"service,omitempty"` Version Version `bson:"version,omitempty" json:"version,omitempty"` Project Project `bson:"project,omitempty" json:"project,omitempty"` ProjectVersion ProjectVersion `bson:"project_version,omitempty" json:"project_version,omitempty"` // Custom data passed to event operation handler. Data map[string]interface{} `bson:"data,omitempty" json:"data,omitempty"` WorkerInfo WorkerInfo `bson:"worker_info,omitempty" json:"worker_info,omitempty"` // The status of the event. External system can retrieve the event and // examine the status of the event, including PostHook. Status EventStatus `bson:"status,omitempty" json:"status,omitempty"` // In case of error, ErrorMessage holds the messge for end user. ErrorMessage string `bson:"error_msg,omitempty" json:"error_msg,omitempty"` // NewWorkerInfo Worker cloud.WorkerInfo `bson:"worker,omitempty" json:"worker,omitempty"` // Retry represents the number of retry when cloud is busy. Retry int `bson:"retry,omitempty" json:"retry,omitempty"` InTime time.Time `bson:"inTime,omitempty" json:"inTime,omitempty"` OutTime time.Time `bson:"outTime,omitempty" json:"outTime,omitempty"` QueueStatus QueueStatus `bson:"queueStatus,omitempty" json:"queueStatus,omitempty"` }
Event is an event occurred in the system. It is managed by AsycManager which will pass the event to appropriate handler.
type EventStatus ¶
type EventStatus string
EventStatus contains the status of an event.
const ( EventStatusPending EventStatus = "pending" EventStatusRunning EventStatus = "running" EventStatusSuccess EventStatus = "success" EventStatusFail EventStatus = "fail" EventStatusCancel EventStatus = "cancel" )
event status type
type FilterResponse ¶
type FilterResponse struct { // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
FilterResponse is the response type for filtered request.
type GetEventResponse ¶
type GetEventResponse struct { Event Event `json:"event,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
GetEventResponse is the response type for getevent request.
type GetProfileResponse ¶
GetProfileResponse is the response type for profile get request, sent by paging server.
type HealthCheckResponse ¶
type HealthCheckResponse struct { // Return the error message. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
HealthCheckResponse is the response type for health check request.
type Hook ¶
type Hook struct { Phase string `bson:"phase" json:"phase"` Callback string `bson:"callback" json:"callback"` Token *oauth2.Token `bson:"token,omitempty" json:"token,omitempty"` }
Hook is a callback hook
type JenkinsConfig ¶
type JenkinsConfig struct { // Jenkins server address Address string `bson:"address,omitempty" json:"address,omitempty"` // Jenkins login username Username string `bson:"username,omitempty" json:"username,omitempty"` // Jenkins login password Password string `bson:"password,omitempty" json:"password,omitempty"` }
JenkinsConfig is the type for jenkins config.
type KeepPoilcyRule ¶
type KeepPoilcyRule string
KeepPoilcyRule is the rule of policy. In the future, keep policy can be more descriptive and powerful, e.g. delete this version if newer version is live in production for a long time.
const ( KeepPoilcyForever KeepPoilcyRule = "forever" KeepPoilcyTimeBound KeepPoilcyRule = "timebound" )
The rules of policy
type ListRepoResponse ¶
type ListRepoResponse struct { Username string `json:"username,omitempty"` Repos []Repo `json:"repos,omitempty"` AvatarURL string `json:"avatar_url,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ListRepoResponse is the response type for repo list request.
type LogoutResponse ¶
type LogoutResponse struct { Result string `json:"result,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
LogoutResponse is the response type for logout request.
type NodeResource ¶
type NodeResource struct { // The memory config Memory float64 `bson:"memory,omitempty" json:"memory,omitempty"` // The cpu config CPU float64 `bson:"cpu,omitempty" json:"cpu,omitempty"` }
NodeResource is type for resources config, such as CPU and memory.
type NotifyProfile ¶
type NotifyProfile struct { // User's profile. Profiles []Profile `bson:"profiles,omitempty" json:"profiles,omitempty"` // Notify Settings. Setting NotifySetting `bson:"setting,omitempty" json:"setting,omitempty"` }
NotifyProfile is the profile of the service.
type NotifySetting ¶
type NotifySetting string
NotifySetting is the setting about whether send the email.
const ( // SendWhenFailed shows that Cyclone sends the build log email when version creation failed. SendWhenFailed NotifySetting = "sendwhenfailed" // SendWhenFinished shows that Cyclone sends the build log email when version creation finished. SendWhenFinished NotifySetting = "sendwhenfinished" )
type Project ¶
type Project struct { // Project ID uniquely identifies the project. ProjectID string `bson:"_id,omitempty" json:"_id,omitempty"` // The user who owns the cluster. UserID string `bson:"user_id,omitempty" json:"user_id,omitempty"` // Project name, e.g. OrderSystem. Name string `bson:"name,omitempty" json:"name,omitempty"` // A short, human-readable description of the project. Description string `bson:"description,omitempty" json:"description,omitempty"` // Time when the version is created. CreateTime time.Time `bson:"create_time,omitempty" json:"create_time,omitempty"` // A list of all project version IDs. Versions []string `bson:"versions,omitempty" json:"versions,omitempty"` // Dependency of the services. Services []ServiceDependency `bson:"services,omitempty" json:"services,omitempty"` // Work flow of the services. WorkFlow []string `bson:"work_flow,omitempty" json:"work_flow,omitempty"` }
Project is the management unit in release system.
type ProjectCreationResponse ¶
type ProjectCreationResponse struct { ProjectID string `json:"project_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ProjectCreationResponse is the response type for project set request.
type ProjectDelResponse ¶
type ProjectDelResponse struct { Result string `json:"result,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ProjectDelResponse is the response type for project delete request.
type ProjectGetResponse ¶
type ProjectGetResponse struct { Project Project `json:"project,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ProjectGetResponse is the response type for project get request.
type ProjectListResponse ¶
type ProjectListResponse struct { Projects []Project `json:"projects,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ProjectListResponse is the response type for project list request.
type ProjectSetResponse ¶
type ProjectSetResponse struct { ProjectID string `json:"project_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ProjectSetResponse is the response type for project setting request.
type ProjectVersion ¶
type ProjectVersion struct { // VersionID uniquely identifies the version. VersionID string `bson:"_id,omitempty" json:"_id,omitempty"` // The user who owns the cluster. UserID string `bson:"user_id,omitempty" json:"user_id,omitempty"` // ServiceID points to the version's service. ProjectID string `bson:"project_id,omitempty" json:"project_id,omitempty"` // The version name, e.g. v1.0.1. This is used as docker image tag directly. Name string `bson:"name,omitempty" json:"name,omitempty"` // A short, human-readable description of the version. Description string `bson:"description,omitempty" json:"description,omitempty"` // Policy of the publish (also known as manual, QA, UAT, etc). Policy string `bson:"policy,omitempty" json:"policy,omitempty"` // Time when the version is created. CreateTime time.Time `bson:"create_time,omitempty" json:"create_time,omitempty"` // Version status is the version's status information. Status VersionStatus `bson:"status,omitempty" json:"status,omitempty"` // Dependency of the services. Services []ServiceDependency `bson:"services,omitempty" json:"services,omitempty"` // Tasks of this version publishing. Tasks []Version `bson:"tasks,omitempty" json:"tasks,omitempty"` // Version build error message if any. ErrorMessage string `bson:"error_message,omitempty" json:"error_message,omitempty"` }
ProjectVersion associates with a project - a project can have multiple versions.
type ProjectVersionCreationResponse ¶
type ProjectVersionCreationResponse struct { ProjectVersionID string `json:"project_version_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ProjectVersionCreationResponse is the response type for project set request.
type ProjectVersionGetResponse ¶
type ProjectVersionGetResponse struct { ProjectVersion ProjectVersion `json:"projectversion,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ProjectVersionGetResponse is the response type for project version get request.
type ProjectVersionListResponse ¶
type ProjectVersionListResponse struct { ProjectVersions []ProjectVersion `json:"project_versions,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ProjectVersionListResponse is the response type for project service list request.
type QueueStatus ¶ added in v0.4.0
type QueueStatus string
const ( InQueue QueueStatus = "in" OutQueue QueueStatus = "out" Handling QueueStatus = "handling" )
type RegistryCompose ¶
type RegistryCompose struct { // Registry's address, ie. cargo.caicloud.io RegistryLocation string `json:"registrylocation,omitempty"` // RegistryUsername used for operating the images RegistryUsername string `json:"registryusername,omitempty"` // RegistryPassword used for operating the images RegistryPassword string `json:"registrypassword,omitempty"` }
RegistryCompose that compose the info about the registry
type Repo ¶
type Repo struct { Name string `json:"name,omitempty"` Owner string `json:"owner,omitempty"` URL string `json:"url,omitempty"` }
Repo is the type for a VCS repo.
type RepositoryStatus ¶
type RepositoryStatus string
RepositoryStatus is a summary of repository status.
const ( // RepositoryAccepted shows that the repositry create request is accepted, and Cyclone is preparing to clone it. RepositoryAccepted RepositoryStatus = "accepted" // RepositoryHealthy shows that the repository is healthy and ready to be used. RepositoryHealthy RepositoryStatus = "healthy" // RepositoryMissing shows that the repository is missing, meaning that Cyclone is unable to verity its existence. RepositoryMissing RepositoryStatus = "missing" // RepositoryUnknownVcs shows that the given vcs is not supported. RepositoryUnknownVcs RepositoryStatus = "unknownvcs" // RepositoryInternalError shows that the repositry creation has internal errors in Cyclone. RepositoryInternalError RepositoryStatus = "internalerror" )
type RequestTokenResponse ¶
type RequestTokenResponse struct { Enterpoint string `json:"enterpoint,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
RequestTokenResponse is the response type for service list request.
type Resource ¶
type Resource struct { // The user who owns the cluster. UserID string `bson:"user_id,omitempty" json:"user_id,omitempty"` // The total memory for user TotalResource BuildResource `bson:"total_resource,omitempty" json:"total_resource,omitempty"` // PerResource resoure for building image PerResource BuildResource `bson:"per_resource,omitempty" json:"per_resource,omitempty"` // The left memory for user LeftResource BuildResource `bson:"left_resource,omitempty" json:"left_resource,omitempty"` }
Resource is the management for user
type ResourceCompose ¶
type ResourceCompose struct { // The total memory for userid MemoryForUser int64 `json:"memoryforuser,omitempty"` // The memory for container MemoryForContainer int64 `json:"memoryforcontainer,omitempty"` // The total cpu for userid CPUForUser int64 `json:"ccpuforuser,omitempty"` // The cpu for container CPUForContainer int64 `json:"cpuforcontainer,omitempty"` }
ResourceCompose that compose the info about the resource
type ResourceGetResponse ¶
type ResourceGetResponse struct { Resource map[string]*cloud.Resource `json:"resource,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ResourceGetResponse is the response type for resource get request.
type ResourceSetResponse ¶
type ResourceSetResponse struct { Result string `json:"result,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ResourceSetResponse is the response type for resource setting request.
type SMTPServerConfig ¶
type SMTPServerConfig struct { SMTPServer string SMTPPort int SMTPUsername string SMTPPassword string }
SMTPServerConfig deifnes the config of SMTP Server.
type Security ¶
type Security struct { Name string `bson:"name,omitempty" json:"name,omitempty"` Description string `bson:"description,omitempty" json:"description,omitempty"` Severity string `bson:"severity,omitempty" json:"severity,omitempty"` }
Security is the type for security check.
type Service ¶
type Service struct { // Service ID uniquely identifies the service. ServiceID string `bson:"_id,omitempty" json:"_id,omitempty"` // The user who owns the cluster. UserID string `bson:"user_id,omitempty" json:"user_id,omitempty"` // The deploy id DeployID string `bson:"deploy_id,omitempty" json:"deploy_id,omitempty"` // Service name, e.g. OrderSystem. Name string `bson:"name,omitempty" json:"name,omitempty"` // Username, just for build and push image. Username string `bson:"username,omitempty" json:"username,omitempty"` // A short, human-readable description of the service. Description string `bson:"description,omitempty" json:"description,omitempty"` // Build script path. When this script path (or maybe change to just text string) // is specified, we build image using BuildPath. // TODO: It's better to change to PreBuildHook and PostBuildHook to let Cyclone // control building image; otherwise, user can use arbitrary image name. BuildPath string `bson:"build_path,omitempty" json:"build_path,omitempty"` // A list of success version IDs. Versions []string `bson:"versions,omitempty" json:"versions,omitempty"` // A list of failed version IDs. VersionFails []string `bson:"version_fails,omitempty" json:"version_fails,omitempty"` // Repository information of the service. // TODO: For private repository, we need OAuth. Repository ServiceRepository `bson:"repository,omitempty" json:"repository,omitempty"` Jconfig JenkinsConfig `bson:"jconfig,omitempty" json:"jconfig,omitempty"` // Email porfile. Profile NotifyProfile `bson:"profile,omitempty" json:"profile,omitempty"` // Record last build version time or service create time first LastCreateTIme time.Time `bson:"last_createtime,omitempty" json:"last_createtime,omitempty"` // Record last build version name LastVersionName string `bson:"last_versionname,omitempty" json:"last_versionname,omitempty"` // Deploy plans DeployPlans []DeployPlan `bson:"deploy_plans,omitempty" json:"deploy_plans,omitempty"` // Repository information of the service. YAMLConfigName string `bson:"yaml_config_name,omitempty" json:"yaml_config_name,omitempty"` // for code to deployment Hooks []Hook `bson:"hooks,omitempty" json:"hooks,omitempty"` PublishNow bool `bson:"publishNow,omitempty" json:"publishNow,omitempty"` Dockerfile string `bson:"dockerfile,omitempty" json:"dockerfile,omitempty"` CaicloudYaml string `bson:"caicloudYaml,omitempty" json:"caicloudYaml,omitempty"` ImageName string `bson:"image_name,omitempty" json:"image_name,omitempty"` }
Service is the management unit in release system.
type ServiceCreationResponse ¶
type ServiceCreationResponse struct { ServiceID string `json:"service_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ServiceCreationResponse is the response type for service creation request.
type ServiceDelResponse ¶
type ServiceDelResponse struct { Result string `json:"result,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ServiceDelResponse is the response type for delete service request.
type ServiceDependency ¶
type ServiceDependency struct { // Service ID uniquely identifies the service. ServiceID string `bson:"service_id,omitempty" json:"service_id,omitempty"` // Service Name uniquely name the service. ServiceName string `bson:"service_name,omitempty" json:"service_name,omitempty"` // Depend special the depency of this service in project. Depend []ServiceDependency `bson:"depend,omitempty" json:"depend,omitempty"` }
ServiceDependency is define the dependency of the services
type ServiceGetResponse ¶
type ServiceGetResponse struct { Service Service `json:"service,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ServiceGetResponse is the response type for service get request.
type ServiceListResponse ¶
type ServiceListResponse struct { Services []Service `json:"services,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ServiceListResponse is the response type for service list request.
type ServiceRepository ¶
type ServiceRepository struct { // URL of the repository, e.g. https://github.com/caicloud/Cyclone. URL string `bson:"url,omitempty" json:"url,omitempty"` // Version control tool used to host the service repository. Vcs VersionControlSystem `bson:"vcs,omitempty" json:"vcs,omitempty"` // Subtype of Version control tool SubVcs string `bson:"subvcs,omitempty" json:"subvcs,omitempty"` // RepositoryStatus is current status of the repository, e.g. repository doesn't exist, etc. Status RepositoryStatus `bson:"status,omitempty" json:"status,omitempty"` // Username is used for Version Control System to operate Username string `bson:"username,omitempty" json:"username,omitempty"` // Password is used for Version Control System to operate Password string `bson:"password,omitempty" json:"password,omitempty"` // Webhook type, such as "github" "bitbuckect" Webhook string `bson:"webhook,omitempty" json:"webhook,omitempty"` }
ServiceRepository is all information about a repository hosting service codebase.
type ServiceSetResponse ¶
type ServiceSetResponse struct { ServiceID string `json:"service_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
ServiceSetResponse is the response type for service setting request.
type SetEvent ¶
type SetEvent struct {
Event Event `json:"event,omitempty"`
}
SetEvent is the request body for setevent request.
type SetEventResponse ¶
type SetEventResponse struct { // ID of the event, uniquely identifies the event. EventID EventID `bson:"event_id,omitempty" json:"event_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
SetEventResponse is the response type for setevent request.
type Version ¶
type Version struct { // VersionID uniquely identifies the version. VersionID string `bson:"_id,omitempty" json:"_id,omitempty"` // ServiceID points to the version's service. ServiceID string `bson:"service_id,omitempty" json:"service_id,omitempty"` // Service Name uniquely name the service. ServiceName string `bson:"service_name,omitempty" json:"service_name,omitempty"` // LogID points to the version's log. LogID string `bson:"version_log_id,omitempty" json:"version_log_id,omitempty"` // The version name, e.g. v1.0.1. This is used as docker image tag directly. Name string `bson:"name,omitempty" json:"name,omitempty"` // Ref reference of git repo, support branch, tag Ref string `bson:"ref,omitempty" json:"ref,omitempty"` // A short, human-readable description of the version. Description string `bson:"description,omitempty" json:"description,omitempty"` // A list of dependencies, reference to other versions. // TODO: This is only used as a FYI. It's hard to manage composite application. DependentVersionIDs []string `bson:"dependent_version_ids,omitempty" json:"dependent_version_ids,omitempty"` // Tags is a list of version tags. A version can have multiple tags, including // system tags and custom tags. System tags is added by Cyclone and custom tags // are added by a user. A version can have multiple tags, e.g. latest version // can also be live version. See below for a list of system tags. // TODO: Make tag a map instead of version. Tags []VersionTag `bson:"tags,omitempty" json:"tags,omitempty"` // LiveInfo is only valid when the version is tagged with "live". It contains // information about where the version is deployed, when it is deployed, etc. // A version can run on multiple cluster/project), so we have a list of LiveInfo. LiveInfo []VersionLiveInfo `bson:"live_info,omitempty" json:"live_info,omitempty"` // Commit of the version (also known as revision, etc). Commit string `bson:"commit,omitempty" json:"commit,omitempty"` // Time when the version is created. CreateTime time.Time `bson:"create_time,omitempty" json:"create_time,omitempty"` // Time when the version finishes. EndTime time.Time `bson:"end_time,omitempty" json:"end_time,omitempty"` // Release version URL. This is used to find the release hosted on remote machine, // e.g. https://github.com/caicloud/cyclone/releases/v1.0. URL string `bson:"url,omitempty" json:"url,omitempty"` // Version status is the version's status information. Status VersionStatus `bson:"status,omitempty" json:"status,omitempty"` // Yaml deploy status is the current status of the version's deployment information. YamlDeployStatus VersionDeployStatus `bson:"yaml_deploy_status,omitempty" json:"yaml_deploy_status,omitempty"` // Operation is the version's operation to execute. Operation VersionOperation `bson:"operation,omitempty" json:"operation,omitempty"` // Operator is the version's operator. Operator VersionOperator `bson:"operator,omitempty" json:"operator,omitempty"` // Deploy plans and status DeployPlansStatuses []DeployPlanStatus `bson:"deploy_plans_statuses,omitempty" json:"deploy_plans_statuses,omitempty"` // Flag of deploying with the information in yaml YamlDeploy YamlDeployFlag `bson:"yaml_deploy,omitempty" json:"yaml_deploy,omitempty"` // Version build error message if any. ErrorMessage string `bson:"error_message,omitempty" json:"error_message,omitempty"` // ProjectVersionID points to the version's projectVersion. ProjectVersionID string `bson:"projectversion_id,omitempty" json:"projectversion_id,omitempty"` // Final status is the version's final status information, finished or unfinished FinalStatus string `bson:"final_status,omitempty" json:"final_status,omitempty"` // SecurtiyCheck for built image SecurityCheck bool `bson:"security_check,omitempty" json:"security_check,omitempty"` // Securtiy info for built image SecurityInfo []Security `bson:"security_info,omitempty" json:"security_info,omitempty"` // BuildResource resoure for building image BuildResource BuildResource `bson:"build_resource,omitempty" json:"build_resource,omitempty"` }
Version associates with a service - a service can have multiple versions.
type VersionBuildResponse ¶
type VersionBuildResponse struct { // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
VersionBuildResponse is the response type for version build request.
type VersionConcelResponse ¶
type VersionConcelResponse struct { Result string `json:"result,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
VersionConcelResponse is the response type for version cancel request.
type VersionControlSystem ¶
type VersionControlSystem string
VersionControlSystem is information about how service codebase is managed.
const ( // Git is the name of git. Git VersionControlSystem = "git" // Svn is the name of svn. Svn VersionControlSystem = "svn" // Mercurial is the name of mercurial. Mercurial VersionControlSystem = "mercurial" // Fake is the name of fake vcs system, a fake implementation for testing purpose. Fake VersionControlSystem = "fake" )
type VersionCreationResponse ¶
type VersionCreationResponse struct { VersionID string `json:"version_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
VersionCreationResponse is the response type for version creation request.
type VersionDeployStatus ¶
type VersionDeployStatus string
VersionDeployStatus is the type for version status.
const ( // DeployNoRun shows that the version's deployment wouldn't be run. DeployNoRun VersionDeployStatus = "norun" // DeployPending shows that the version's deployment is pending. DeployPending VersionDeployStatus = "pending" // DeploySuccess shows that the version's deployment is successful. DeploySuccess VersionDeployStatus = "success" // DeployFailed shows that the version's deployment is failed. DeployFailed VersionDeployStatus = "failed" )
type VersionDeployment ¶
type VersionDeployment struct { // The version to deploy. VersionID string // Kind of the deployment, e.g. deploy a new version, rolling upgrade from an old version. DeploymentKind DeploymentKind // Information needed to deploy the version. VersionLiveInfo VersionLiveInfo }
VersionDeployment is the type for deployment.
type VersionGetResponse ¶
type VersionGetResponse struct { Version Version `json:"version,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
VersionGetResponse is the response type for version get request.
type VersionKeepPolicy ¶
type VersionKeepPolicy struct { Policy KeepPoilcyRule DeleteTime time.Time }
VersionKeepPolicy is the type for policy of version.
type VersionListResponse ¶
type VersionListResponse struct { Versions []Version `json:"versions,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
VersionListResponse is the response type for service list request.
type VersionLiveInfo ¶
type VersionLiveInfo struct { // Which cluster and project was the version deployed. Cluster string `bson:"cluster,omitempty" json:"cluster,omitempty"` Project string `bson:"project,omitempty" json:"project,omitempty"` // When was the version deployed on the cluster/project. DeployTime time.Time `bson:"deploy_time,omitempty" json:"deploy_time,omitemtpy"` }
VersionLiveInfo contains information about how a version is deployed.
type VersionLog ¶
type VersionLog struct { // LogID uniquely identifies the version version. LogID string `bson:"_id,omitempty" json:"_id,omitempty"` // VerisonID points to the log. VerisonID string `bson:"version_id,omitempty" json:"version_id,omitempty"` // Logs defines the logs when the version is created. Logs string `bson:"logs,omitempty" json:"logs,omitempty"` }
VersionLog is the version log.
type VersionLogCreateResponse ¶
type VersionLogCreateResponse struct { // LogID uniquely identifies the version version. LogID string `bson:"_id,omitempty" json:"_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
VersionLogCreateResponse is the response type for log create request.
type VersionLogGetResponse ¶
type VersionLogGetResponse struct { Logs string `json:"logs,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
VersionLogGetResponse is the response type for version log get request.
type VersionOperation ¶
type VersionOperation string
VersionOperation defines the operations of a version
const ( // IntegrationOperation is the version operation. IntegrationOperation VersionOperation = "integration" // PublishOperation is the version operation. PublishOperation VersionOperation = "publish" // DeployOperation is only used for project deploy,when have pushed image // web can not use this value DeployOperation VersionOperation = "deploy" )
type VersionOperator ¶
type VersionOperator string
VersionOperator defines the operator of a version
const ( // WebhookOperator is webhook operator. WebhookOperator VersionOperator = "webhook" // APIOperator is api operator. APIOperator VersionOperator = "api" )
type VersionStatus ¶
type VersionStatus string
VersionStatus is the type for version status.
const ( VersionFailed VersionStatus = "failed" VersionHealthy VersionStatus = "healthy" VersionPending VersionStatus = "pending" VersionCancel VersionStatus = "cancelled" VersionRunning VersionStatus = "running" )
VersionStatus defines the status of a version, e.g. in process of building image, image built, etc.
type VersionTag ¶
type VersionTag string
VersionTag is the type of version tags.
const ( LatestVersion VersionTag = "latest" LiveVersion VersionTag = "live" NormalVersion VersionTag = "normal" )
System tags. In the future, we may support more system version tag, e.g. "stage", "test". User defined version tag can also be applied to a version, but it's not pre-defined.
type VscToken ¶
type VscToken struct { // The user who owns the cluster. UserID string `bson:"userid,omitempty" json:"user_id,omitempty"` Vsc string `bson:"vsc,omitempty" json:"vsc,omitempty"` Vsctoken oauth2.Token `bson:"vsctoken,omitempty" json:"vsctoken,omitempty"` }
VscToken is the type for token.
type WebhookGithub ¶
type WebhookGithub map[string]interface{}
WebhookGithub contains datas send from github webhook.
type WebhookGitlab ¶
type WebhookGitlab map[string]interface{}
WebhookGitlab is type for gitlab webhook request.
type WebhookResponse ¶
type WebhookResponse struct { // Return the error message. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
WebhookResponse is the response type for webhook request.
type WebhookSVN ¶
type WebhookSVN struct { // svn url, ie. svn://192.168.0.2/sample_repo URL string `json:"url,omitempty"` // event type of webhook Event string `json:"event,omitempty"` // id of commit CommitID string `json:"commit_id,omitempty"` }
WebhookSVN contains datas send from svn webhook.
type WorkerInfo ¶
type WorkerInfo struct { // worker docker host DockerHost string `json:"docker_host,omitempty"` // ID of the container, uniquely identifies the container. ContainerID string `json:"container_id,omitempty"` // DueTime due time of the event DueTime time.Time `json:"due_time,omitempty"` // The resource need to used by this event UsedResource BuildResource `json:"used_resource,omitempty"` }
WorkerInfo save the woker info
type WorkerNode ¶
type WorkerNode struct { // ID of the worker node. NodeID string `bson:"_id,omitempty" json:"_id,omitempty"` // Name of the worker node. Name string `bson:"name,omitempty" json:"name,omitempty"` // A short, human-readable description of the node. Description string `bson:"description,omitempty" json:"description,omitempty"` // IP of the worker node. IP string `bson:"ip,omitempty" json:"ip,omitempty"` // DockerHost of the worker node. DockerHost string `bson:"docker_host,omitempty" json:"docker_host,omitempty"` // Type of the worker node. Type WorkerNodeType `bson:"type,omitempty" json:"type,omitempty"` // Total resouce of the worker node TotalResource NodeResource `bson:"total_resource,omitempty" json:"total_resource,omitempty"` // Left resouce of the worker node LeftResource NodeResource `bson:"left_resource,omitempty" json:"left_resource,omitempty"` }
WorkerNode is the information of worker node.
type WorkerNodeCreateResponse ¶
type WorkerNodeCreateResponse struct { NodeID string `json:"node_id,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
WorkerNodeCreateResponse is the response type for worker node add request.
type WorkerNodeDelResponse ¶
type WorkerNodeDelResponse struct { Result string `json:"result,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
WorkerNodeDelResponse is the response type for delete worker node request.
type WorkerNodeGetResponse ¶
type WorkerNodeGetResponse struct { WorkerNode WorkerNode `json:"worker_node,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
WorkerNodeGetResponse is the response type for worker node get request.
type WorkerNodeType ¶
type WorkerNodeType string
WorkerNodeType is the type for node's type, such as "system".
const ( SystemWorkerNode WorkerNodeType = "system" UserWorkerNode WorkerNodeType = "user" )
Worker Node Type
type WorkerNodesListResponse ¶
type WorkerNodesListResponse struct { WorkerNodes []WorkerNode `json:"worker_nodes,omitempty"` // Return the error message IFF not successful. This is used to provide user-facing errors. ErrorMessage string `json:"error_msg,omitempty"` }
WorkerNodesListResponse is the response type for worker nodes list request.
type YamlDeployFlag ¶
type YamlDeployFlag string
YamlDeployFlag is the type of version deployment flag.
const ( // DeployWithYaml shows that the deployment is deployed with yaml. DeployWithYaml YamlDeployFlag = "yes" // NotDeployWithYaml shows that the deployment is deployed without yaml. NotDeployWithYaml YamlDeployFlag = "no" )