Tims-Chat/files/lib/data/command/Command.class.php

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

61 lines
1.5 KiB
PHP
Raw Normal View History

2018-08-16 22:30:59 +00:00
<?php
2022-03-04 17:10:24 +00:00
2018-08-16 22:30:59 +00:00
/*
2022-03-04 17:10:24 +00:00
* Copyright (c) 2010-2022 Tim Düsterhus.
2018-08-16 22:30:59 +00:00
*
* Use of this software is governed by the Business Source License
* included in the LICENSE file.
*
2022-03-10 17:56:18 +00:00
* Change Date: 2026-03-10
2018-08-16 22:30:59 +00:00
*
* On the date above, in accordance with the Business Source
* License, use of this software will be governed by version 2
* or later of the General Public License.
*/
namespace chat\data\command;
2022-03-04 17:10:24 +00:00
use chat\system\command\ICommand;
use wcf\data\package\PackageCache;
use wcf\data\ProcessibleDatabaseObject;
use wcf\system\WCF;
2018-08-16 22:30:59 +00:00
/**
* Represents a chat command.
*/
2022-03-04 17:10:24 +00:00
class Command extends ProcessibleDatabaseObject
{
/**
* @inheritDoc
*/
protected static $processorInterface = ICommand::class;
/**
* Returns whether this command has at least one trigger assigned.
*
* The default PlainCommand implicitely has one.
*/
2022-03-04 17:46:21 +00:00
public function hasTriggers(): bool
2022-03-04 17:10:24 +00:00
{
static $chatPackageID = null;
if ($chatPackageID === null) {
$chatPackageID = PackageCache::getInstance()->getPackageID('be.bastelstu.chat');
}
if ($this->packageID === $chatPackageID && $this->identifier === 'plain') {
return true;
}
$sql = "SELECT COUNT(*)
FROM chat1_command_trigger
WHERE commandID = ?";
$statement = WCF::getDB()->prepare($sql);
$statement->execute([
$this->commandID,
]);
return $statement->fetchSingleColumn() > 0;
}
2018-08-16 22:30:59 +00:00
}