[ Mini Kiebo ]
Server: Windows NT DESKTOP-5B8S0D4 6.2 build 9200 (Windows 8 Professional Edition) i586
Path:
D:
/
Backup
/
14082024
/
Data
/
htdocs
/
htdocs
/
ojs
/
kesmas
/
33018
/
pages
/
oai
/
[
Home
]
File: OAIHandler.inc.php
<?php /** * @file pages/oai/OAIHandler.inc.php * * Copyright (c) 2014-2021 Simon Fraser University * Copyright (c) 2003-2021 John Willinsky * Distributed under the GNU GPL v3. For full terms see the file docs/COPYING. * * @class OAIHandler * @ingroup pages_oai * * @brief Handle OAI protocol requests. */ define('SESSION_DISABLE_INIT', 1); // FIXME? import('classes.oai.ojs.JournalOAI'); import('classes.handler.Handler'); use \Firebase\JWT\JWT; class OAIHandler extends Handler { /** * @param $args array * @param $request PKPRequest */ function index($args, $request) { $this->validate(null, $request); PluginRegistry::loadCategory('oaiMetadataFormats', true); $oai = new JournalOAI(new OAIConfig($request->url(null, 'oai'), Config::getVar('oai', 'repository_id'))); if (!$request->getJournal() && $request->getRequestedJournalPath() != 'index') { $dispatcher = $request->getDispatcher(); return $dispatcher->handle404(); } $oai->execute(); } /** * @copydoc PKPHandler::validate() */ function validate($requiredContexts = null, $request = null) { // Site validation checks not applicable //parent::validate($requiredContexts, $request); if (!Config::getVar('oai', 'oai')) { $request->redirect(null, 'index'); } // Permit the use of the Authorization header and an API key for access to unpublished content (article URLs) if ($header = array_search('Authorization', array_flip(getallheaders()))) { list($bearer, $jwt) = explode(' ', $header); if (strcasecmp($bearer, 'Bearer') == 0) { $apiToken = JWT::decode($jwt, Config::getVar('security', 'api_key_secret', ''), array('HS256')); // Compatibility with old API keys // https://github.com/pkp/pkp-lib/issues/6462 if (substr($apiToken, 0, 2) === '""') { $apiToken = json_decode($apiToken); } $this->setApiToken($apiToken); } } } /** * @see PKPHandler::requireSSL() */ function requireSSL() { return false; } }