mirror of https://github.com/BOINC/boinc.git
158 lines
4.9 KiB
PHP
158 lines
4.9 KiB
PHP
<?php
|
|
// This file is part of BOINC.
|
|
// http://boinc.berkeley.edu
|
|
// Copyright (C) 2011 University of California
|
|
//
|
|
// BOINC is free software; you can redistribute it and/or modify it
|
|
// under the terms of the GNU Lesser General Public License
|
|
// as published by the Free Software Foundation,
|
|
// either version 3 of the License, or (at your option) any later version.
|
|
//
|
|
// BOINC is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
// See the GNU Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
// Tables related to job submission
|
|
|
|
require_once("../inc/common_defs.inc");
|
|
|
|
class BoincBatch {
|
|
static function lookup_id($id) {
|
|
$db = BoincDb::get();
|
|
return $db->lookup_id($id, 'batch', 'BoincBatch');
|
|
}
|
|
static function lookup_name($name) {
|
|
$db = BoincDb::get();
|
|
$name = BoincDb::escape_string($name);
|
|
return $db->lookup('batch', 'BoincBatch', "name='$name'");
|
|
}
|
|
static function enum($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->enum('batch', 'BoincBatch', $clause);
|
|
}
|
|
static function insert($clause) {
|
|
$db = BoincDb::get();
|
|
$ret = $db->insert('batch', $clause);
|
|
if (!$ret) return $ret;
|
|
return $db->insert_id();
|
|
}
|
|
function update($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->update($this, 'batch', $clause);
|
|
}
|
|
static function update_aux($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->update_aux('batch', $clause);
|
|
}
|
|
function get_cpu_time() {
|
|
$db = BoincDb::get();
|
|
$x = $db->get_double(
|
|
"select sum(result.cpu_time) as total_cpu_time from workunit join result on workunit.id = result.workunitid where workunit.batch=$this->id",
|
|
"total_cpu_time"
|
|
);
|
|
return $x;
|
|
}
|
|
}
|
|
|
|
class BoincUserSubmit {
|
|
static function enum($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->enum('user_submit', 'BoincUserSubmit', $clause);
|
|
}
|
|
static function insert($clause) {
|
|
$db = BoincDb::get();
|
|
$ret = $db->insert('user_submit', $clause);
|
|
if (!$ret) return false;
|
|
return true;
|
|
}
|
|
static function lookup_userid($user_id) {
|
|
$db = BoincDb::get();
|
|
return $db->lookup('user_submit', 'BoincUserSubmit', "user_id=$user_id");
|
|
}
|
|
function update($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->update_aux('user_submit', "$clause where user_id=$this->user_id");
|
|
}
|
|
static function update_aux($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->update_aux('user_submit', $clause);
|
|
}
|
|
}
|
|
|
|
class BoincUserSubmitApp {
|
|
static function enum($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->enum('user_submit_app', 'BoincUserSubmitApp', $clause);
|
|
}
|
|
static function lookup($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->lookup('user_submit_app', 'BoincUserSubmitApp', $clause);
|
|
}
|
|
static function insert($clause) {
|
|
$db = BoincDb::get();
|
|
$ret = $db->insert('user_submit_app', $clause);
|
|
if (!$ret) return false;
|
|
return true;
|
|
}
|
|
static function delete_user($user_id) {
|
|
$db = BoincDb::get();
|
|
$db->delete_aux('user_submit_app', "user_id=$user_id");
|
|
}
|
|
function update($clause) {
|
|
$db = BoincDb::get();
|
|
$db->update_aux('user_submit_app', "$clause where user_id=$this->user_id and app_id=$this->app_id");
|
|
}
|
|
}
|
|
|
|
class BoincJobFile {
|
|
static function insert($clause) {
|
|
$db = BoincDb::get();
|
|
$ret = $db->insert('job_file', $clause);
|
|
if (!$ret) return false;
|
|
return true;
|
|
}
|
|
static function lookup_md5($md5) {
|
|
$db = BoincDb::get();
|
|
return $db->lookup('job_file', 'BoincJobFile', "md5='$md5'");
|
|
}
|
|
function delete() {
|
|
$db = BoincDb::get();
|
|
$db->delete($this, 'job_file');
|
|
}
|
|
function update($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->update($this, 'job_file', $clause);
|
|
}
|
|
}
|
|
|
|
class BoincBatchFileAssoc {
|
|
static function insert($clause) {
|
|
$db = BoincDb::get();
|
|
$ret = $db->insert('batch_file_assoc', $clause);
|
|
if (!$ret) return false;
|
|
return true;
|
|
}
|
|
static function lookup($clause) {
|
|
$db = BoincDb::get();
|
|
return $db->lookup('batch_file_assoc', 'BoincBatchFileAssoc', $clause);
|
|
}
|
|
function delete() {
|
|
$db = BoincDb::get();
|
|
$db->delete_aux('batch_file_assoc',
|
|
"job_file_id=$this->job_file_id and batch_id=$this->batch_id"
|
|
);
|
|
}
|
|
static function delete_batch($batch_id) {
|
|
$db = BoincDb::get();
|
|
$db->delete_aux('batch_file_assoc',
|
|
"batch_id=$batch_id"
|
|
);
|
|
}
|
|
}
|
|
|
|
?>
|