diff options
Diffstat (limited to 'app/class')
| -rw-r--r-- | app/class/group.class.php | 66 | 
1 files changed, 66 insertions, 0 deletions
| diff --git a/app/class/group.class.php b/app/class/group.class.php new file mode 100644 index 0000000..1e98aff --- /dev/null +++ b/app/class/group.class.php @@ -0,0 +1,66 @@ +<?php + +/* + * SCROTT IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. + * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR + * OTHER DEALINGS IN THE SOFTWARE. + * + * For more information, please refer to UNLICENSE + */ + +require_once "class/agent.class.php"; +require_once "class/user.class.php"; + +/* + * This class models Scrott user groups, a construct which exists to + * simplify the sharing of multiple Scrott pads. + */ +class group extends agent +{ +    /* +     * Constructor +     */ +    public function __construct(?string $guid = NULL) +    { +        $this->fields['groups'] = array( +            "guid", +        ); + +        parent::__construct($guid); +        $this->expectType("group"); +    } + +    /* +     * Get an array of all groups, sorted by name +     */ +    public static function getAll_ordByName() : array +    { +        $query = "SELECT guid FROM objects WHERE objtype = 'group' ORDER BY name"; +        $res = database::query($query); + +        $groups = array(); + +        foreach ($res as $g) +            $groups[] = new group($g['guid']); + +        return $groups; +    } + +    /* +     * Initialize a new group object with the given name and owner +     */ +    public static function initNew(string $name, user $owner) : group +    { +        $group = new group(); +        $group->setOwner($owner); +        $group->name = $name; +        $group->objtype = "group"; +        return $group; +    } +} + +?> | 
