本文整理汇总了PHP中Data::composeUpdateQuery方法的典型用法代码示例。如果您正苦于以下问题:PHP Data::composeUpdateQuery方法的具体用法?PHP Data::composeUpdateQuery怎么用?PHP Data::composeUpdateQuery使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Data
的用法示例。
在下文中一共展示了Data::composeUpdateQuery方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: processAdjustUserDataRequest
function processAdjustUserDataRequest($request)
{
$prfx = DB_PREFIX;
$user_row = RequestUtils::testSession($request->sessionID);
$adjust_user_id = $request->userID;
$adjust_user_row = Data::getRow(sprintf("SELECT * FROM {$prfx}user WHERE id=%s", Data::quote_smart($adjust_user_id)));
if (!$adjust_user_row) {
throwBusinessLogicError(2);
}
if ($user_row['user_type'] === 'Participant') {
throwBusinessLogicError(0);
}
if ($user_row['user_type'] === 'ContestAdmin' && $user_row['contest_id'] != $adjust_user_row['contest_id']) {
throwBusinessLogicError(0);
}
$queries = array();
if (!is_null($request->login)) {
$queries['login'] = $request->login;
}
if (!is_null($request->password)) {
$queries['password'] = $request->password;
}
if (!is_null($request->userData)) {
$queries['user_data'] = @serialize($request->userData);
}
if (!is_null($request->newType)) {
$queries['user_type'] = $request->newType;
}
$q = Data::composeUpdateQuery("user", $queries, sprintf("id=%s", Data::quote_smart($adjust_user_id)));
Data::submitModificationQuery($q);
return new AcceptedResponse();
}
示例2: processAdjustPluginRequest
function processAdjustPluginRequest($request)
{
$prfx = DB_PREFIX;
$user_row = RequestUtils::testSession($request->sessionID);
//authorize
if ($user_row['user_type'] !== 'SuperAdmin') {
throwBusinessLogicError(0);
}
//test plugin alias
if (preg_match('/^[\\p{L}0-9 ]+$/', $request->pluginAlias) === 0) {
throwBusinessLogicError(238);
}
$plugin_type = $request->side === 'Client' ? 'client' : 'server';
//test if there already is such plugin
$where_clause = sprintf("alias=%s", Data::quote_smart($request->pluginAlias));
$plugin_row = Data::getRow("SELECT * FROM {$prfx}{$plugin_type}_plugin WHERE {$where_clause}");
if ($plugin_row) {
$modify = true;
} else {
$modify = false;
}
//test all parameters specified
if (!$modify && is_null($request->description)) {
$request->description = "";
}
if (!$modify && (is_null($request->pluginData) || is_null($request->description))) {
throwBusinessLogicError(1);
}
//TODO test pluginAlias to be secure
if ($plugin_type === 'client') {
$ext = '.jar';
} else {
$ext = '.php';
}
//set file data
if (!is_null($request->pluginData)) {
file_put_contents($GLOBALS["dces_dir_{$plugin_type}_plugins"] . '/' . $request->pluginAlias . $ext, $request->pluginData);
}
//prepare set plugin description
$col_value = array();
if (!is_null($request->description)) {
$col_value['description'] = $request->description;
}
if ($modify) {
$query = Data::composeUpdateQuery("{$plugin_type}_plugin", $col_value, $where_clause);
} else {
$col_value['alias'] = $request->pluginAlias;
$query = Data::composeInsertQuery("{$plugin_type}_plugin", $col_value);
}
Data::submitModificationQuery($query);
return new AcceptedResponse();
}
示例3: processConnectToContestRequest
function processConnectToContestRequest($request)
{
$prfx = DB_PREFIX;
//find user in table
$row = Data::getRow(sprintf("SELECT {$prfx}user.*, {$prfx}contest.settings\r\n FROM {$prfx}user\r\n LEFT JOIN {$prfx}contest\r\n ON {$prfx}user.contest_id = {$prfx}contest.id\r\n WHERE login=%s AND contest_id=%s", Data::quote_smart($request->login), Data::quote_smart($request->contestID)));
//test if there is at least one user
if (!$row) {
throwBusinessLogicError(12);
}
//test password
if ($row['password'] !== $request->password) {
throwBusinessLogicError(12);
}
//get contest settings and contest time
$settings = Data::_unserialize($row['settings'], null);
if (is_null($row['contest_start'])) {
$now = getdate();
$now = $now[0];
$q = Data::composeUpdateQuery('user', array('contest_start' => DatePHPToMySQL($now)), "id={$row['id']}");
Data::submitModificationQuery($q);
$row['contest_start'] = $now;
}
$contest_time = getCurrentContestTime($settings, DateMySQLToPHP($row['contest_start']), DateMySQLToPHP($row['contest_finish']));
if ($contest_time['interval'] === 'before' && $row['user_type'] === 'Participant') {
throwBusinessLogicError(19);
}
//start new session
$session_id = RequestUtils::createSession($row['id']);
//get finish time
if (is_null($settings)) {
$finish_time = 0;
} elseif ($settings->contestTiming->selfContestStart) {
$finish_time = $row['contest_start'] + 60 * $settings->contestTiming->maxContestDuration;
} else {
$finish_time = $settings->finish;
}
if (is_null($finish_time)) {
$finish_time = 0;
}
$res = new ConnectToContestResponse();
$res->sessionID = $session_id;
$res->finishTime = $finish_time;
$res->user = new UserDescription();
$res->user->userID = (int) $row['id'];
$res->user->login = $request->login;
$res->user->dataValue = Data::_unserialize($row['user_data'], array());
$res->user->userType = $row['user_type'];
return $res;
}
示例4: processStopContestRequest
/**
* Created by IntelliJ IDEA.
* User: Посетитель
* Date: 17.04.2009
* Time: 15:57:17
* To change this template use File | Settings | File Templates.
*/
function processStopContestRequest($request)
{
$user_row = RequestUtils::testSession($request->sessionID);
$requested_contest_id = $user_row['contest_id'];
if ($requested_contest_id <= 0) {
throwBusinessLogicError(0);
}
$settings = Data::_unserialize($user_row['settings']);
if (!$settings->contestTiming->selfContestStart) {
throwBusinessLogicError(0);
}
$time = getCurrentContestTime($settings, DateMySQLToPHP($user_row['contest_start']), DateMySQLToPHP($user_row['contest_finish']));
if ($time['interval'] === 'before') {
throwBusinessLogicError(19);
}
if ($time['interval'] === 'after') {
throwBusinessLogicError(20);
}
$now = getdate();
$now = $now[0];
Data::submitModificationQuery(Data::composeUpdateQuery('user', array('contest_finish' => DatePHPToMySQL($now)), "id={$user_row['id']}"));
}
示例5: processSubmitSolutionRequest
function processSubmitSolutionRequest($request)
{
$prfx = DB_PREFIX;
//get user_id or die, if session is invalid
$userRow = RequestUtils::testSession($request->sessionID);
$user_id = $userRow['id'];
//authorize user for this operation
// get contest ID
$user_type = $userRow['user_type'];
//get problem row
$problem_row = Data::getRow(sprintf("SELECT * FROM {$prfx}problem WHERE id=%s", Data::quote_smart($request->problemID)));
if (!$problem_row) {
throwBusinessLogicError(4);
}
//get contest id of a problem
$problem_contest_id = $problem_row['contest_id'];
//test if we have rights to submit solution for the contest
$contest_id = RequestUtils::getRequestedContest($problem_contest_id, $userRow['contest_id'], $user_type);
if ($contest_id < 0) {
throwBusinessLogicError(0);
}
//get all settings
$contest_settings = Data::_unserialize($userRow['settings']);
//test submission time
$cur_time = getCurrentContestTime($contest_settings, DateMySQLToPHP($userRow['contest_start']), DateMySQLToPHP($userRow['contest_finish']));
if ($cur_time['interval'] === 'before') {
throwBusinessLogicError(19);
}
if ($cur_time['interval'] === 'after') {
throwBusinessLogicError(20);
}
$problem_settings = Data::_unserialize($problem_row['contest_settings']);
//test that not all submission attempts were used
$hist = Data::getRow(sprintf("SELECT COUNT(*) AS cnt FROM {$prfx}submission_history WHERE (problem_id=%s) AND (user_id=%s)", Data::quote_smart($request->problemID), Data::quote_smart($user_id)));
if ($hist >= getSetting($contest_settings->problemsDefaultSettings->sendCount, $problem_settings->sendCount)) {
throwBusinessLogicError(21);
}
//save submission result in history
$cur_php_time = getdate();
$col_value = array();
$col_value['problem_id'] = $request->problemID;
$col_value['user_id'] = $user_id;
$col_value['submission'] = serialize($request->problemResult);
$col_value['result'] = null;
//serialize($check_result);
$col_value['submission_time'] = DatePHPToMySQL($cur_php_time[0]);
//TODO implement asynchronous plugin
//get problem and create plugin
$problem = new Problem(getProblemFile($request->problemID));
$plugin_alias = $problem->getServerPlugin();
require_once getServerPluginFile();
require_once getServerPluginFile($plugin_alias);
$plugin = new $plugin_alias($problem);
//check solution
$last_result = $plugin->checkSolution(Data::getInsertedID(), $request->problemResult);
$col_value['result'] = serialize($last_result);
Data::submitModificationQuery(Data::composeInsertQuery('submission_history', $col_value));
//get result for result table and store in user
$all_results = Data::_unserialize($userRow['results']);
$user_result = ResultUtils::getUserResults($user_id, $request->problemID, getSetting($contest_settings->problemsDefaultSettings->tableResultChoice, $problem_settings->tableResultChoice), getSetting($contest_settings->problemsDefaultSettings->resultTransition, $problem_settings->resultTransition), $plugin, $last_result);
//update user result for results table
$all_results[$request->problemID] = $user_result;
Data::submitModificationQuery(Data::composeUpdateQuery('user', array('results' => serialize($all_results)), 'id=' . Data::quote_smart($user_id)));
//return submission result
$res = new AcceptedResponse();
return $res;
}
示例6: queriesToAdjustProblems
/**
* creates queries to change problem set
* @param $problems new problems
* @param $contest_id contest id
* @return array() list of temporary files. NULL if the existing file was used
*/
function queriesToAdjustProblems($problems, $contest_id)
{
$prfx = DB_PREFIX;
$changed_probs = array();
//problems that will be changed by request
$temp_probs = array();
//find all contest problems
$prob2settings = array();
$res = Data::getRows(sprintf("SELECT * FROM {$prfx}problem WHERE contest_id=%s", Data::quote_smart($contest_id)));
while ($row = Data::getNextRow($res)) {
$prob2settings[$row['id']] = Data::_unserialize($row['contest_settings']);
}
$contest_pos = 1;
foreach ($problems as $p) {
$col_value = array();
//new problem must have 1) data 2) settings
//set contest id
$col_value['contest_id'] = $contest_id;
$col_value['contest_pos'] = $contest_pos++;
if ($p->id != -1 && !isset($prob2settings[$p->id])) {
throwBusinessLogicError(4);
}
//find problem file or make temporary if a new problem was sent
if ($p->problem) {
$problem_file = getTemporaryProblemFile();
@file_put_contents($problem_file, $p->problem) or throwServerProblem(200, 'failed to write problem file: ' . $problem_file);
$temp_probs[] = $problem_file;
} else {
if ($p->id < 0) {
throwBusinessLogicError(1);
}
$problem_file = getProblemFile($p->id);
$temp_probs[] = NULL;
}
$problem = new Problem($problem_file);
//get server plugin
//TODO improve security here
$plugin_alias = $problem->getServerPlugin();
require_once getServerPluginFile($plugin_alias);
$plugin = new $plugin_alias($problem);
//TODO consider calling updaters here instead of manual insertion of values
//TODO recheck all values if new plugin specified
$col_value['checker_columns'] = serialize($plugin->getColumnNames());
$col_value['result_columns'] = serialize(array());
//copy per contest settings
if ($p->settings) {
if ($p->id != -1) {
$new_settings = $prob2settings[$p->id];
copyValues($p->settings, $new_settings);
} else {
$new_settings = $p->settings;
}
$col_value['contest_settings'] = serialize($new_settings);
} else {
if ($p->id < 0) {
throwBusinessLogicError(1);
}
}
//query depends on whether we add or change a problem
if ($p->id == -1) {
Data::submitModificationQuery(Data::composeInsertQuery('problem', $col_value));
} else {
Data::submitModificationQuery(Data::composeUpdateQuery('problem', $col_value, "id='{$p->id}'"));
$changed_probs[$p->id] = 1;
}
}
//delete extra problems
foreach (array_keys($prob2settings) as $id) {
if (!isset($changed_probs[$id])) {
Data::submitModificationQuery("DELETE FROM {$prfx}problem WHERE id='{$id}'");
}
}
return $temp_probs;
}