fields['pads'] = array( "guid", "stage", "issueNumb", ); parent::__construct($guid); $this->expectType("pad"); } /* * Get an array of all pads, sorted by name */ public static function getAll_ordByName() : array { $query = "SELECT guid FROM objects WHERE objtype = 'pad' ORDER BY name"; $res = database::query($query); $pads = array(); foreach ($res as $p) $pads[] = new pad($p['guid']); return $pads; } /* * Get an array of all pads NOT owned by a group. These are root-level * pads. Results are sorted by name. */ public static function getAllNoGroup_ordByName() : array { $query = "SELECT o.guid FROM objects o JOIN objects b ON o.owner = b.guid WHERE o.objtype = 'pad' AND " . "b.objtype = 'user' ORDER BY o.name"; $res = database::query($query); $pads = array(); foreach ($res as $p) $pads[] = new pad($p['guid']); return $pads; } /* * Initialize a new pad object with the given name and owner */ public static function initNew(string $name, agent $owner) : pad { $pad = new pad(); $pad->setOwner($owner); $pad->name = $name; $pad->objtype = "pad"; $pad->issueNumb = 0; $pad->saveObj(); return $pad; } /* * Get an array of all stages under this pad. The array is in * proper sequential order. */ public function getStages() : array { if (!isset($this->stage) || $this->stage == "") return array(); $stage = new stage($this->stage); return $stage->getArray(); } /* * Insert a stage object at the front of this pad's pipeline */ public function insertStage(stage $stage) : void { $stage->stage = $this->stage; $this->stage = $stage->guid; $stage->saveObj(); $this->saveObj(); } /* * Get an array of all closed issues under this pad. Ordered by * datetime closed. */ public function getClosedIssues_ordByClosed() : array { $query = "SELECT o.guid FROM objects o JOIN issues i ON o.guid = i.guid " . "WHERE o.parent = '" . database::esc($this->guid) . "' ORDER BY i.closed DESC"; $res = database::query($query); $issues = array(); foreach ($res as $i) $issues[] = new issue($i['guid']); return $issues; } } ?>