easyappointments/src/engine/Api/V1/Authorization.php

56 lines
1.6 KiB
PHP
Raw Normal View History

<?php
/* ----------------------------------------------------------------------------
* Easy!Appointments - Open Source Web Scheduler
*
* @package EasyAppointments
* @author A.Tselegidis <alextselegidis@gmail.com>
* @copyright Copyright (c) 2013 - 2016, Alex Tselegidis
* @license http://opensource.org/licenses/GPL-3.0 - GPLv3
* @link http://easyappointments.org
* @since v1.2.0
* ---------------------------------------------------------------------------- */
2016-07-09 13:24:52 +03:00
namespace EA\Engine\Api\V1;
use \EA\Engine\Types\NonEmptyAlphanumeric;
2016-07-09 13:24:52 +03:00
/**
* API v1 Authorization Class
*
* This class will handle the authorization procedure of the API.
2016-07-09 13:24:52 +03:00
*/
class Authorization {
2016-07-09 13:24:52 +03:00
/**
* Framework Instance
*
* @var CI_Controller
*/
protected $framework;
/**
* Class Constructor
*
* @param \CI_Controller $framework
*/
public function __construct(\CI_Controller $framework) {
$this->framework = $framework;
}
/**
* Perform Basic Authentication
*
* @param NonEmptyAlphanumeric $username Admin Username
* @param NonEmptyAlphanumeric $password Admin Password
2016-07-09 13:24:52 +03:00
*
* @throws \EA\Engine\Api\V1\Exception Throws 401-Unauthorized exception if the authentication fails.
*/
public function basic(NonEmptyAlphanumeric $username, NonEmptyAlphanumeric $password) {
2016-07-09 13:24:52 +03:00
$this->framework->load->model('user_model');
if (!$this->framework->user_model->check_login($username->get(), $password->get())) {
throw new Exception('The provided credentials do not match any admin user!', 401, 'Unauthorized');
}
}
}