Skip to content

Commit

Permalink
Type api/*
Browse files Browse the repository at this point in the history
The first step was to rework the ApiRouter to
clearly state that it was using a trie and add
an appropriate TrieNode. This helped clean up
the types a bit.

Typed the handlers/validators though their
return value is anything that `json_encode`
can consume (so anything effectively :-)).
  • Loading branch information
jchaffraix authored and cpeel committed Jan 18, 2025
1 parent e2919d8 commit 94f29d0
Show file tree
Hide file tree
Showing 4 changed files with 36 additions and 34 deletions.
50 changes: 26 additions & 24 deletions api/v1_projects.inc
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ function get_return_fields(?array $query_params, ?Project $project)
return $return_fields;
}

function api_v1_projects($method, $data, $query_params)
function api_v1_projects(string $method, array $data, array $query_params)
{
// set which fields are queryable and their column names
$valid_fields = get_project_fields_with_attr("queryable", null);
Expand Down Expand Up @@ -306,7 +306,7 @@ function create_or_update_project(Project $project)
return $project;
}

function api_v1_project($method, $data, $query_params)
function api_v1_project(string $method, array $data, array $query_params)
{
if ($method == "GET") {
// restrict to list of desired fields, if set
Expand Down Expand Up @@ -373,7 +373,7 @@ function render_project_json(Project $project, ?array $return_fields = null)
//---------------------------------------------------------------------------
// projects/:projectID/wordlists/:type

function api_v1_project_wordlists($method, $data, $query_params)
function api_v1_project_wordlists(string $method, array $data, array $query_params)
{
// get the project this is for and the type of word list
$project = $data[":projectid"];
Expand Down Expand Up @@ -406,7 +406,7 @@ function api_v1_project_wordlists($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/:projectID/holdstates

function api_v1_project_holdstates($method, $data, $query_params)
function api_v1_project_holdstates(string $method, array $data, array $query_params)
{
$project = $data[":projectid"];

Expand Down Expand Up @@ -446,7 +446,7 @@ function api_v1_project_holdstates($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/:projectid/pages

function api_v1_project_pages($method, $data, $query_params)
function api_v1_project_pages(string $method, array $data, array $query_params)
{
$project = $data[":projectid"];

Expand All @@ -468,7 +468,7 @@ function api_v1_project_pages($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/:projectid/pagedetails

function api_v1_project_pagedetails($method, $data, $query_params)
function api_v1_project_pagedetails(string $method, array $data, array $query_params)
{
// optional page round IDs (one or more) to filter down to
$only_rounds = null;
Expand All @@ -479,7 +479,7 @@ function api_v1_project_pagedetails($method, $data, $query_params)
$pageroundids = [$pageroundids];
}
foreach ($pageroundids as $pageroundid) {
validate_page_round($pageroundid, null);
validate_page_round($pageroundid, []);
if ($pageroundid === "OCR") {
$only_rounds[] = "OCR";
} else {
Expand Down Expand Up @@ -524,7 +524,7 @@ function api_v1_project_pagedetails($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/:projectid/pages/:pagename/pagerounds/:pageroundid

function api_v1_project_page_round($method, $data, $query_params)
function api_v1_project_page_round(string $method, array $data, array $query_params)
{
if ($data[":pageroundid"] == "OCR") {
$text_column = "master_text";
Expand Down Expand Up @@ -583,7 +583,7 @@ function render_project_page_json($row)
//---------------------------------------------------------------------------
// projects/:projectid/transitions

function api_v1_project_transitions($method, $data, $query_params)
function api_v1_project_transitions(string $method, array $data, array $query_params)
{
$sql = sprintf(
"
Expand All @@ -610,7 +610,7 @@ function api_v1_project_transitions($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/difficulties

function api_v1_projects_difficulties($method, $data, $query_params)
function api_v1_projects_difficulties(string $method, array $data, array $query_params)
{
$difficulties = get_project_difficulties();
return array_keys($difficulties);
Expand All @@ -619,7 +619,7 @@ function api_v1_projects_difficulties($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/genres

function api_v1_projects_genres($method, $data, $query_params)
function api_v1_projects_genres(string $method, array $data, array $query_params)
{
$genres = ProjectSearchForm::genre_options();
unset($genres['']);
Expand All @@ -629,7 +629,7 @@ function api_v1_projects_genres($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/languages

function api_v1_projects_languages($method, $data, $query_params)
function api_v1_projects_languages(string $method, array $data, array $query_params)
{
$languages = ProjectSearchForm::language_options();
unset($languages['']);
Expand All @@ -639,7 +639,7 @@ function api_v1_projects_languages($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/states

function api_v1_projects_states($method, $data, $query_params)
function api_v1_projects_states(string $method, array $data, array $query_params)
{
$states = ProjectSearchForm::state_options();
unset($states['']);
Expand All @@ -649,15 +649,15 @@ function api_v1_projects_states($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/pagerounds

function api_v1_projects_pagerounds($method, $data, $query_params)
function api_v1_projects_pagerounds(string $method, array $data, array $query_params)
{
return array_merge(["OCR"], Rounds::get_ids());
}

//---------------------------------------------------------------------------
// projects/charsuites

function api_v1_projects_charsuites($method, $data, $query_params)
function api_v1_projects_charsuites(string $method, array $data, array $query_params)
{
$enabled_filter = _get_enabled_filter($query_params);
if ($enabled_filter === null) {
Expand Down Expand Up @@ -686,7 +686,7 @@ function api_v1_projects_charsuites($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/specialdays

function api_v1_projects_specialdays($method, $data, $query_params)
function api_v1_projects_specialdays(string $method, array $data, array $query_params)
{
$return_data = [];

Expand Down Expand Up @@ -720,7 +720,7 @@ function api_v1_projects_specialdays($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/imagesources

function api_v1_projects_imagesources($method, $data, $query_params)
function api_v1_projects_imagesources(string $method, array $data, array $query_params): array
{
$return_data = [];

Expand Down Expand Up @@ -755,7 +755,7 @@ function api_v1_projects_imagesources($method, $data, $query_params)
//---------------------------------------------------------------------------
// projects/holdstates

function api_v1_projects_holdstates($method, $data, $query_params)
function api_v1_projects_holdstates(string $method, array $data, array $query_params): array
{
return Project::get_holdable_states();
}
Expand All @@ -780,7 +780,7 @@ function _get_enabled_filter($query_params)
// Proofreading functions

// checkout a page
function api_v1_project_checkout($method, array $data, array $query_params)
function api_v1_project_checkout(string $method, array $data, array $query_params): array
{
try {
$project = $data[":projectid"];
Expand All @@ -795,14 +795,14 @@ function api_v1_project_checkout($method, array $data, array $query_params)
}
}

function api_v1_project_validatetext(string $method, array $data, array $query_params)
function api_v1_project_validatetext(string $method, array $data, array $query_params): array
{
$project = $data[":projectid"];
$invalid_characters = $project->find_invalid_characters(receive_project_text_from_request_body('text'));
return ["invalid_chars" => $invalid_characters];
}

function api_v1_project_wordcheck($method, $data, array $query_params)
function api_v1_project_wordcheck(string $method, array $data, array $query_params): array
{
$project = $data[":projectid"];
$accepted_words = receive_data_from_request_body("accepted_words") ?? [];
Expand Down Expand Up @@ -832,6 +832,8 @@ function api_v1_project_pickersets(string $method, array $data, array $query_par
return $verbose_pickersets;
}

// TODO(jchaffraix): Refine this return once all callees have been typed.
/** @return mixed */
function api_v1_project_page(string $method, array $data, array $query_params)
{
global $pguser;
Expand Down Expand Up @@ -895,7 +897,7 @@ function api_v1_project_page_wordcheck(string $method, array $data, array $query
}
}

function validate_project_state($project, $state)
function validate_project_state(Project $project, ?string $state): void
{
if (null === $state) {
throw new InvalidValue("No project state found in request.");
Expand All @@ -914,7 +916,7 @@ function validate_project_state($project, $state)
}
}

function validate_page_state($project_page, $page_state)
function validate_page_state(ProjectPage $project_page, ?string $page_state): void
{
if (null === $page_state) {
throw new InvalidValue("No page state found in request.");
Expand Down Expand Up @@ -942,7 +944,7 @@ function receive_project_text_from_request_body(): string
return $page_text;
}

function receive_data_from_request_body($field)
function receive_data_from_request_body(string $field)
{
$request_data = api_get_request_body();
return $request_data[$field] ?? null;
Expand Down
6 changes: 3 additions & 3 deletions api/v1_queues.inc
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ include_once("api_common.inc");
function api_v1_queues(string $method, array $data, array $query_params): array
{
$roundid = $query_params["roundid"] ?? null;
$round = !is_null($roundid) ? validate_round($roundid, null) : null;
$round = !is_null($roundid) ? validate_round($roundid, []) : null;

$show = get_enumerated_param($query_params, "show", "all", ["enabled", "populated", "all"]);

Expand Down Expand Up @@ -68,7 +68,7 @@ function api_v1_queue_stats(string $method, array $data, array $query_params): a
{
$queue = $data[":queueid"];

$round = validate_round($queue["round_id"], null);
$round = validate_round($queue["round_id"], []);
$name = $queue["name"];

return fetch_queue_stats_data($round, $name);
Expand Down Expand Up @@ -96,7 +96,7 @@ function api_v1_queue_projects(string $method, array $data, array $query_params)
$return_fields = array_get_as_array($query_params, "field", $valid_return_fields);
$return_fields = array_intersect($return_fields, $valid_return_fields);

$round = validate_round($queue["round_id"], null);
$round = validate_round($queue["round_id"], []);

$output = [];
foreach (fetch_queue_projects_data($round, $queue["project_selector"], $unheld_only) as $proj_data) {
Expand Down
10 changes: 5 additions & 5 deletions api/v1_validators.inc
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ include_once($relPath.'release_queue.inc');
//===========================================================================
// Validators

function validate_round($roundid, $data)
function validate_round(string $roundid, array $_data): Round
{
try {
$round = Rounds::get_by_id($roundid);
Expand All @@ -18,7 +18,7 @@ function validate_round($roundid, $data)
}
}

function validate_project($projectid, $data)
function validate_project(string $projectid, array $_data): Project
{
// validate and load the specified projectid
try {
Expand All @@ -28,15 +28,15 @@ function validate_project($projectid, $data)
}
}

function validate_wordlist($wordlist, $data)
function validate_wordlist(string $wordlist, array $_data): string
{
if (!in_array($wordlist, ["good", "bad"])) {
throw new NotFoundError();
}
return $wordlist;
}

function validate_page_name($pagename, $data)
function validate_page_name(string $pagename, array $data): ProjectPage
{
try {
return $data[":projectid"]->get_project_page($pagename);
Expand All @@ -45,7 +45,7 @@ function validate_page_name($pagename, $data)
}
}

function validate_page_round($pageround, $data)
function validate_page_round(string $pageround, array $_data): string
{
try {
$pagerounds = array_merge(["OCR"], Rounds::get_ids());
Expand Down
4 changes: 2 additions & 2 deletions pinc/Project.inc
Original file line number Diff line number Diff line change
Expand Up @@ -1525,7 +1525,7 @@ class Project
DPDatabase::query($sql);
}

public static function get_holdable_states()
public static function get_holdable_states(): array
{
$states = [];
foreach (Rounds::get_all() as $round) {
Expand Down Expand Up @@ -1792,7 +1792,7 @@ class Project
}
}

public function get_project_page($pagename)
public function get_project_page(?string $pagename): ProjectPage
{
if (!$this->pages_table_exists) {
throw new NoProjectPageTable(_("Project page table does not exist."));
Expand Down

0 comments on commit 94f29d0

Please sign in to comment.