SHA = $SHA; return $this; } /** * Sets redirect target url for the deployment * * @param string $targetUrl is the url that is to be set * @return self */ public function setTargetUrl(string $targetUrl): self { $this->targetUrl = $targetUrl; return $this; } /** * Sets resource document for the build event. * * @param Document $resource * @return self */ public function setResource(Document $resource): self { $this->resource = $resource; return $this; } /** * Returns set resource document for the build event. * * @return null|Document */ public function getResource(): ?Document { return $this->resource; } /** * Sets deployment for the build event. * * @param Document $deployment * @return self */ public function setDeployment(Document $deployment): self { $this->deployment = $deployment; return $this; } /** * Returns set deployment for the build event. * * @return null|Document */ public function getDeployment(): ?Document { return $this->deployment; } /** * Sets type for the build event. * * @param string $type Can be `BUILD_TYPE_DEPLOYMENT` or `BUILD_TYPE_RETRY`. * @return self */ public function setType(string $type): self { $this->type = $type; return $this; } /** * Returns set type for the function event. * * @return string */ public function getType(): string { return $this->type; } /** * Executes the function event and sends it to the functions worker. * * @return string|bool * @throws \InvalidArgumentException */ public function trigger(): string|bool { return Resque::enqueue($this->queue, $this->class, [ 'project' => $this->project, 'resource' => $this->resource, 'deployment' => $this->deployment, 'type' => $this->type, 'SHA' => $this->SHA, 'targetUrl' => $this->targetUrl ]); } }