# Init `self` from a `json` object.
init from_json(api: GithubAPI, json: JsonObject) do
- self.api = api
+ init(api)
self.json = json
end
+ # Event ID from Github.
+ fun id: String do return json["id"].as(String)
+
+ # Set id.
+ fun id=(id: String) do json["id"] = id
+
# Action performed by the event.
fun action: String do return json["action"].as(String)
+ # Set action.
+ fun action=(action: String) do json["action"] = action
+
# Repo where this event occured.
fun repo: Repo do
return new Repo.from_json(api, json["repository"].as(JsonObject))
end
+
+ # Set repo.
+ fun repo=(repo: Repo) do json["repository"] = repo.json
end
# Triggered when a commit comment is created.
fun comment: CommitComment do
return new CommitComment.from_json(api, repo, json["comment"].as(JsonObject))
end
+
+ # Set comment.
+ fun comment=(comment: CommitComment) do json["comment"] = comment.json
end
# Triggered when a repository, branch, or tag is created.
# Can be one of `repository`, `branch`, or `tag`.
fun ref_type: String do return json["ref_type"].as(String)
+ # Set ref_type.
+ fun ref_type=(ref_type: String) do json["ref_type"] = ref_type
+
# Git ref (or null if only a repository was created).
fun ref: String do return json["ref"].as(String)
+ # Set ref.
+ fun ref=(ref: String) do json["ref"] = ref
+
# Name of the repo's default branch (usually master).
fun master_branch: String do return json["master_branch"].as(String)
+ # Set master_branch.
+ fun master_branch=(master_branch: String) do json["master_branch"] = master_branch
+
# Repo's current description.
fun description: String do return json["description"].as(String)
+
+ # Set description.
+ fun description=(description: String) do json["description"] = description
end
# Triggered when a branch or a tag is deleted.
# Can be one of `repository`, `branch`, or `tag`.
fun ref_type: String do return json["ref_type"].as(String)
+ # Set ref_type.
+ fun ref_type=(ref_type: String) do json["ref_type"] = ref_type
+
# Git ref (or null if only a repository was deleted).
fun ref: String do return json["ref"].as(String)
+
+ # Set ref.
+ fun ref=(ref: String) do json["ref"] = ref
end
# Triggered when a new snapshot is deployed.
# Commit SHA for which this deployment was created.
fun sha: String do return json["sha"].as(String)
+ # Set sha.
+ fun sha=(sha: String) do json["sha"] = sha
+
# Name of repository for this deployment, formatted as :owner/:repo.
fun name: String do return json["name"].as(String)
+ # Set name.
+ fun name=(name: String) do json["name"] = name
+
# Optional extra information for this deployment.
fun payload: nullable String do
- if not json.has_key("payload") then return null
- return json["payload"].as(String)
+ var res = json.get_or_null("payload")
+ if res isa String then return res else return null
end
+ # Set payload.
+ fun payload=(payload: nullable String) do json["payload"] = payload
+
# Optional environment to deploy to.
# Default: "production"
fun environment: nullable String do
- if not json.has_key("environment") then return null
- return json["environment"].as(String)
+ var res = json.get_or_null("environment")
+ if res isa String then return res else return null
end
+ # Set environment.
+ fun environment=(environment: nullable String) do json["environment"] = environment
+
# Optional human-readable description added to the deployment.
fun description: nullable String do
- if not json.has_key("description") then return null
- return json["description"].as(String)
+ var res = json.get_or_null("description")
+ if res isa String then return res else return null
end
+
+ # Set description.
+ fun description=(description: nullable String) do json["description"] = description
end
# Triggered when a deployement's status changes.
# Optional link added to the status.
fun target_url: nullable String do
- if not json.has_key("target_url") then return null
- return json["target_url"].as(String)
+ var res = json.get_or_null("target_url")
+ if res isa String then return res else return null
end
+ # Set target_url.
+ fun target_url=(target_url: nullable String) do json["target_url"] = target_url
+
# Deployment hash that this status is associated with.
fun deployment: String do return json["deployment"].as(String)
+ # Set deployment.
+ fun deployment=(deployment: String) do json["deployment"] = deployment
+
# Optional human-readable description added to the status.
fun description: nullable String do
- if not json.has_key("description") then return null
- return json["description"].as(String)
+ var res = json.get_or_null("description")
+ if res isa String then return res else return null
end
+
+ # Set description.
+ fun description=(description: nullable String) do json["description"] = description
end
# Triggered when a user forks a repository.
# Created repository.
fun forkee: Repo do return new Repo.from_json(api, json["forkee"].as(JsonObject))
+
+ # Set forkee.
+ fun forkee=(forkee: Repo) do json["forkee"] = forkee.json
end
# Triggered when an issue comment is created.
return new Issue.from_json(api, repo, json["issue"].as(JsonObject))
end
+ # Set issue.
+ fun issue=(issue: Issue) do json["issue"] = issue.json
+
# The `Comment` itself.
fun comment: IssueComment do
return new IssueComment.from_json(api, repo, json["comment"].as(JsonObject))
end
+
+ # Set comment.
+ fun comment=(comment: IssueComment) do json["comment"] = comment.json
end
# Triggered when an event occurs on an issue.
# The `Issue` itself.
fun issue: Issue do return new Issue.from_json(api, repo, json["issue"].as(JsonObject))
+ # Set issue.
+ fun issue=(issue: Issue) do json["issue"] = issue.json
+
# Optional `Label` that was added or removed from the issue.
fun lbl: nullable Label do
- if not json.has_key("label") then return null
- return new Label.from_json(api, repo, json["label"].as(JsonObject))
+ var res = json.get_or_null("label")
+ if res isa JsonObject then return new Label.from_json(api, repo, res) else return null
+ end
+
+ # Set lbl.
+ fun lbl=(lbl: nullable Label) do
+ if lbl == null then
+ json["lbl"] = null
+ else
+ json["lbl"] = lbl.json
+ end
end
# Optional `User` that was assigned or unassigned from the issue.
fun assignee: nullable User do
- if not json.has_key("assignee") then return null
- return new User.from_json(api, json["assignee"].as(JsonObject))
+ var res = json.get_or_null("assignee")
+ if res isa JsonObject then return new User.from_json(api, res) else return null
+ end
+
+ # Set assignee.
+ fun assignee=(assignee: nullable User) do
+ if assignee == null then
+ json["assignee"] = null
+ else
+ json["assignee"] = assignee.json
+ end
end
end
# `User` that was added.
fun member: User do return new User.from_json(api, json["member"].as(JsonObject))
+
+ # Set member.
+ fun member=(member: User) do json["member"] = member.json
end
# Triggered when an event occurs on a pull request.
# The pull request number.
fun number: Int do return json["number"].as(Int)
+ # Set number.
+ fun number=(number: Int) do json["number"] = number
+
# The `PullRequest` itself.
fun pull: PullRequest do
return new PullRequest.from_json(api, repo, json["pull_request"].as(JsonObject))
end
+
+ # Set pull.
+ fun pull=(pull: PullRequest) do json["pull_request"] = pull.json
end
# Triggered when a comment is created on a pull request diff.
return new ReviewComment.from_json(api, repo, json["comment"].as(JsonObject))
end
+ # Set comment.
+ fun comment=(comment: ReviewComment) do json["comment"] = comment.json
+
# `PullRequest` the `comment` belongs to.
fun pull: PullRequest do
return new PullRequest.from_json(api, repo, json["pull_request"].as(JsonObject))
end
+
+ # Set pull.
+ fun pull=(pull: PullRequest) do json["pull_request"] = pull.json
end
# Triggered when a repository branch is pushed to.
# SHA of the HEAD commit on the repository.
fun head: String do return json["head"].as(String)
+ # Set head.
+ fun head=(head: String) do json["head"] = head
+
# Full Git ref that was pushed.
#
# Example: “refs/heads/master”
fun ref: String do return json["ref"].as(String)
+ # Set ref.
+ fun ref=(ref: String) do json["ref"] = ref
+
# Number of commits in the push.
fun size: Int do return json["size"].as(Int)
+ # Set size.
+ fun size=(size: Int) do json["size"] = size
+
# Array of pushed commits.
fun commits: Array[Commit] do
var res = new Array[Commit]
end
return res
end
+
+ # Set commits.
+ fun commits=(commits: Array[Commit]) do
+ var arr = new JsonArray
+ for commit in commits do arr.add commit.json
+ json["commits"] = arr
+ end
end
# Triggered when the status of a Git commit changes.
return api.load_commit(repo, json["sha"].as(String)).as(not null)
end
+ # Set commit.
+ fun commit=(commit: Commit) do json["sha"] = commit.sha
+
# New state.
#
# Can be `pending`, `success`, `failure`, or `error`.
fun state: String do return json["state"].as(String)
+ # Set state.
+ fun state=(state: String) do json["state"] = state
+
# Optional human-readable description added to the status.
fun description: nullable String do
- if not json.has_key("description") then return null
- return json["description"].as(String)
+ var res = json.get_or_null("description")
+ if res isa String then return res else return null
end
+ # Set description.
+ fun description=(description: nullable String) do json["description"] = description
+
# Optional link added to the status.
fun target_url: nullable String do
- if not json.has_key("target_url") then return null
- return json["target_url"].as(String)
+ var res = json.get_or_null("target_url")
+ if res isa String then return res else return null
end
+ # Set target_url.
+ fun target_url=(target_url: nullable String) do json["target_url"] = target_url
+
# Array of branches containing the status' SHA.
#
# Each branch contains the given SHA,
end
return res
end
+
+ # Set branches.
+ fun branches=(branches: Array[Commit]) do
+ var arr = new JsonArray
+ for branch in branches do arr.add branch.json
+ json["branches"] = arr
+ end
end