appwrite/src/Appwrite/Event/Build.php

134 lines
2.8 KiB
PHP
Raw Normal View History

2022-04-19 13:13:55 +00:00
<?php
namespace Appwrite\Event;
use Resque;
use Utopia\Database\Document;
class Build extends Event
{
protected string $type = '';
protected ?Document $resource = null;
protected ?Document $deployment = null;
protected string $SHA = '';
protected string $targetUrl = '';
2022-04-19 13:13:55 +00:00
public function __construct()
{
parent::__construct(Event::BUILDS_QUEUE_NAME, Event::BUILDS_CLASS_NAME);
}
/**
* Sets commit SHA for the build event.
*
* @param string $SHA is the commit hash of the incoming commit
* @return self
*/
public function setSHA(string $SHA): self
{
$this->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;
}
2022-04-19 13:13:55 +00:00
/**
* Sets resource document for the build event.
*
2022-05-10 12:31:20 +00:00
* @param Document $resource
2022-04-19 13:13:55 +00:00
* @return self
*/
public function setResource(Document $resource): self
{
$this->resource = $resource;
return $this;
}
/**
* Returns set resource document for the build event.
*
2022-05-23 14:54:50 +00:00
* @return null|Document
2022-04-19 13:13:55 +00:00
*/
public function getResource(): ?Document
{
return $this->resource;
}
/**
* Sets deployment for the build event.
*
2022-05-10 12:31:20 +00:00
* @param Document $deployment
2022-04-19 13:13:55 +00:00
* @return self
*/
public function setDeployment(Document $deployment): self
{
$this->deployment = $deployment;
return $this;
}
/**
* Returns set deployment for the build event.
*
2022-05-10 12:31:20 +00:00
* @return null|Document
2022-04-19 13:13:55 +00:00
*/
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
2022-04-19 13:13:55 +00:00
]);
}
}