From 9668df9d17f343bf8a130bd8b50a977485a926c8 Mon Sep 17 00:00:00 2001 From: Malf Furious Date: Wed, 29 Mar 2017 01:34:07 -0400 Subject: Add pad class --- app/class/pad.class.php | 87 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 87 insertions(+) create mode 100644 app/class/pad.class.php (limited to 'app/class') diff --git a/app/class/pad.class.php b/app/class/pad.class.php new file mode 100644 index 0000000..7c53f30 --- /dev/null +++ b/app/class/pad.class.php @@ -0,0 +1,87 @@ +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; + return $pad; + } +} + +?> -- cgit v1.2.3