* [ADDED] More error codes * [MODIFIED] Class updates to use Base Class all the time * [MODIFIED] Cronjobs have been slightly adjusted * [ADDED] More base class features
264 lines
12 KiB
PHP
264 lines
12 KiB
PHP
<?php
|
|
|
|
// Make sure we are called from index.php
|
|
if (!defined('SECURITY')) die('Hacking attempt');
|
|
|
|
class Worker extends Base {
|
|
protected $table = 'pool_worker';
|
|
|
|
/**
|
|
* Update worker list for a user
|
|
* @param account_id int User ID
|
|
* @param data array All workers and their settings
|
|
* @return bool
|
|
**/
|
|
public function updateWorkers($account_id, $data) {
|
|
$this->debug->append("STA " . __METHOD__, 4);
|
|
if (!is_array($data)) {
|
|
$this->setErrorMessage('No workers to update');
|
|
return false;
|
|
}
|
|
$username = $this->user->getUserName($account_id);
|
|
$iFailed = 0;
|
|
foreach ($data as $key => $value) {
|
|
if ('' === $value['username'] || '' === $value['password']) {
|
|
$iFailed++;
|
|
} else {
|
|
// Prefix the WebUser to Worker name
|
|
$value['username'] = "$username." . $value['username'];
|
|
$stmt = $this->mysqli->prepare("UPDATE $this->table SET password2 = ?, username = ?, monitor = ? WHERE account_id = ? AND id = ?");
|
|
if ( ! ( $this->checkStmt($stmt) && $stmt->bind_param('ssiii', $value['password'], $value['username'], $value['monitor'], $account_id, $key) && $stmt->execute()) )
|
|
$iFailed++;
|
|
}
|
|
}
|
|
if ($iFailed == 0)
|
|
return true;
|
|
return $this->sqlError('E0053', $iFailed);
|
|
}
|
|
|
|
/**
|
|
* Fetch all IDLE workers that have monitoring enabled
|
|
* @param none
|
|
* @return data array Workers in IDLE state and monitoring enabled
|
|
**/
|
|
public function getAllIdleWorkers($interval=600) {
|
|
$this->debug->append("STA " . __METHOD__, 4);
|
|
$stmt = $this->mysqli->prepare("
|
|
SELECT w.account_id AS account_id, w.id AS id, w.username AS username
|
|
FROM " . $this->share->getTableName() . " AS s
|
|
RIGHT JOIN " . $this->getTableName() . " AS w
|
|
ON w.username = s.username
|
|
AND s.time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
AND our_result = 'Y'
|
|
WHERE w.monitor = 1
|
|
AND s.id IS NULL
|
|
");
|
|
if ($this->checkStmt($stmt) && $stmt->bind_param('i', $interval) && $stmt->execute() && $result = $stmt->get_result())
|
|
return $result->fetch_all(MYSQLI_ASSOC);
|
|
return $this->sqlError('E0054');
|
|
}
|
|
|
|
/**
|
|
* Fetch a specific worker and its status
|
|
* @param id int Worker ID
|
|
* @return mixed array Worker details
|
|
**/
|
|
public function getWorker($id, $interval=600) {
|
|
$this->debug->append("STA " . __METHOD__, 4);
|
|
$stmt = $this->mysqli->prepare("
|
|
SELECT id, username, password, monitor,
|
|
( SELECT COUNT(id) FROM " . $this->share->getTableName() . " WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL 10 MINUTE)) AS count_all,
|
|
( SELECT COUNT(id) FROM " . $this->share->getArchiveTableName() . " WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL 10 MINUTE)) AS count_all_archive,
|
|
(
|
|
SELECT
|
|
IFNULL(IF(our_result='Y', ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) * POW(2, " . $this->config['target_bits'] . ") / ? / 1000), 0), 0) AS hashrate
|
|
FROM " . $this->share->getTableName() . "
|
|
WHERE
|
|
username = w.username
|
|
AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) + (
|
|
SELECT
|
|
IFNULL(IF(our_result='Y', ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) * POW(2, " . $this->config['target_bits'] . ") / ? / 1000), 0), 0) AS hashrate
|
|
FROM " . $this->share->getArchiveTableName() . "
|
|
WHERE
|
|
username = w.username
|
|
AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) AS hashrate,
|
|
(
|
|
SELECT IFNULL(ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) / count_all, 2), 0)
|
|
FROM " . $this->share->getTableName() . "
|
|
WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) + (
|
|
SELECT IFNULL(ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) / count_all_archive, 2), 0)
|
|
FROM " . $this->share->getArchiveTableName() . "
|
|
WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) AS difficulty
|
|
FROM $this->table AS w
|
|
WHERE id = ?
|
|
");
|
|
if ($this->checkStmt($stmt) && $stmt->bind_param('iiiiiii', $interval, $interval, $interval, $interval, $interval, $interval, $id) && $stmt->execute() && $result = $stmt->get_result())
|
|
return $result->fetch_assoc();
|
|
return $this->sqlError('E0055');
|
|
}
|
|
|
|
/**
|
|
* Fetch all workers for an account
|
|
* @param account_id int User ID
|
|
* @return mixed array Workers and their settings or false
|
|
**/
|
|
public function getWorkers($account_id, $interval=600) {
|
|
$this->debug->append("STA " . __METHOD__, 4);
|
|
$stmt = $this->mysqli->prepare("
|
|
SELECT id, username, password, monitor,
|
|
( SELECT COUNT(id) FROM " . $this->share->getTableName() . " WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)) AS count_all,
|
|
( SELECT COUNT(id) FROM " . $this->share->getArchiveTableName() . " WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)) AS count_all_archive,
|
|
(
|
|
SELECT
|
|
IFNULL(IF(our_result='Y', ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) * POW(2, " . $this->config['target_bits'] . ") / ? / 1000), 0), 0) AS hashrate
|
|
FROM " . $this->share->getTableName() . "
|
|
WHERE
|
|
username = w.username
|
|
AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) + (
|
|
SELECT
|
|
IFNULL(IF(our_result='Y', ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) * POW(2, " . $this->config['target_bits'] . ") / ? / 1000), 0), 0) AS hashrate
|
|
FROM " . $this->share->getArchiveTableName() . "
|
|
WHERE
|
|
username = w.username
|
|
AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) AS hashrate,
|
|
(
|
|
SELECT IFNULL(ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) / count_all, 2), 0)
|
|
FROM " . $this->share->getTableName() . "
|
|
WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) + (
|
|
SELECT IFNULL(ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) / count_all_archive, 2), 0)
|
|
FROM " . $this->share->getArchiveTableName() . "
|
|
WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) AS difficulty
|
|
FROM $this->table AS w
|
|
WHERE account_id = ?");
|
|
if ($this->checkStmt($stmt) && $stmt->bind_param('iiiiiiiii', $interval, $interval, $interval, $interval, $interval, $interval, $interval, $interval, $account_id) && $stmt->execute() && $result = $stmt->get_result())
|
|
return $result->fetch_all(MYSQLI_ASSOC);
|
|
return $this->sqlError('E0056');
|
|
}
|
|
|
|
/**
|
|
* Fetch all workers for admin panel
|
|
* @param limit int
|
|
* @return mixed array Workers and their settings or false
|
|
**/
|
|
public function getAllWorkers($iLimit=0, $interval=600) {
|
|
$this->debug->append("STA " . __METHOD__, 4);
|
|
$stmt = $this->mysqli->prepare("
|
|
SELECT id, username, password, monitor,
|
|
IFNULL(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty), 0) AS difficulty,
|
|
(
|
|
SELECT
|
|
IFNULL(IF(our_result='Y', ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) * 65536 / ? / 1000), 0), 0) AS hashrate
|
|
FROM " . $this->share->getTableName() . "
|
|
WHERE
|
|
username = w.username
|
|
AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) + (
|
|
SELECT
|
|
IFNULL(IF(our_result='Y', ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)) * 65536 / ? / 1000), 0), 0) AS hashrate
|
|
FROM " . $this->share->getArchiveTableName() . "
|
|
WHERE
|
|
username = w.username
|
|
AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) AS hashrate,
|
|
((
|
|
SELECT IFNULL(ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)), 2), 0)
|
|
FROM " . $this->share->getTableName() . "
|
|
WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) + (
|
|
SELECT IFNULL(ROUND(SUM(IF(difficulty=0, pow(2, (" . $this->config['difficulty'] . " - 16)), difficulty)), 2), 0)
|
|
FROM " . $this->share->getArchiveTableName() . "
|
|
WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
)) / ((
|
|
SELECT COUNT(id)
|
|
FROM " . $this->share->getTableName() . "
|
|
WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
) + (
|
|
SELECT COUNT(id)
|
|
FROM " . $this->share->getArchiveTableName() . "
|
|
WHERE username = w.username AND time > DATE_SUB(now(), INTERVAL ? SECOND)
|
|
)) AS avg_difficulty
|
|
FROM $this->table AS w
|
|
ORDER BY hashrate DESC LIMIT ?");
|
|
if ($this->checkStmt($stmt) && $stmt->bind_param('iiiiiiiii', $interval, $interval, $interval, $interval, $interval, $interval, $interval, $interval, $iLimit) && $stmt->execute() && $result = $stmt->get_result())
|
|
return $result->fetch_all(MYSQLI_ASSOC);
|
|
return $this->sqlError('E0057');
|
|
}
|
|
|
|
/**
|
|
* Get all currently active workers in the past 10 minutes
|
|
* @param none
|
|
* @return data mixed int count if any workers are active, false otherwise
|
|
**/
|
|
public function getCountAllActiveWorkers() {
|
|
$this->debug->append("STA " . __METHOD__, 4);
|
|
$stmt = $this->mysqli->prepare("
|
|
SELECT COUNT(DISTINCT(username)) AS total
|
|
FROM " . $this->share->getTableName() . "
|
|
WHERE our_result = 'Y'
|
|
AND time > DATE_SUB(now(), INTERVAL 10 MINUTE)");
|
|
if ($this->checkStmt($stmt) && $stmt->execute() && $result = $stmt->get_result())
|
|
return $result->fetch_object()->total;
|
|
return $this->sqlError();
|
|
}
|
|
|
|
/**
|
|
* Add new worker to an existing web account
|
|
* The webuser name is prefixed to the worker name
|
|
* Passwords are plain text for pushpoold
|
|
* @param account_id int User ID
|
|
* @param workerName string Worker name
|
|
* @param workerPassword string Worker password
|
|
* @return bool
|
|
**/
|
|
public function addWorker($account_id, $workerName, $workerPassword) {
|
|
$this->debug->append("STA " . __METHOD__, 4);
|
|
if ('' === $workerName || '' === $workerPassword) {
|
|
$this->setErrorMessage($this->getErrorMsg('E0058'));
|
|
return false;
|
|
}
|
|
$username = $this->user->getUserName($account_id);
|
|
$workerName = "$username.$workerName";
|
|
$stmt = $this->mysqli->prepare("INSERT INTO $this->table (account_id, username, password) VALUES(?, ?, ?)");
|
|
if ($this->checkStmt($stmt) && $stmt->bind_param('iss', $account_id, $workerName, $workerPassword)) {
|
|
if (!$stmt->execute()) {
|
|
if ($stmt->sqlstate == '23000') return $this->sqlError('E0059');
|
|
} else {
|
|
return true;
|
|
}
|
|
}
|
|
return $this->sqlError('E0060');
|
|
}
|
|
|
|
/**
|
|
* Delete existing worker from account
|
|
* @param account_id int User ID
|
|
* @param id int Worker ID
|
|
* @return bool
|
|
**/
|
|
public function deleteWorker($account_id, $id) {
|
|
$this->debug->append("STA " . __METHOD__, 4);
|
|
$stmt = $this->mysqli->prepare("DELETE FROM $this->table WHERE account_id = ? AND id = ?");
|
|
if ($this->checkStmt($stmt) && $stmt->bind_param('ii', $account_id, $id) && $stmt->execute() && $stmt->affected_rows == 1)
|
|
return true;
|
|
return $this->sqlError('E0061');
|
|
}
|
|
}
|
|
|
|
$worker = new Worker();
|
|
$worker->setDebug($debug);
|
|
$worker->setMysql($mysqli);
|
|
$worker->setShare($share);
|
|
$worker->setConfig($config);
|
|
$worker->setUser($user);
|
|
$worker->setErrorCodes($aErrorCodes);
|
|
|
|
?>
|