CORE-POS/IS4C

View on GitHub
pos/is4c-nf/lib/Authenticate.php

Summary

Maintainability
B
4 hrs
Test Coverage
A
93%
<?php
/*******************************************************************************

    Copyright 2010 Whole Foods Co-op

    This file is part of IT CORE.

    IT CORE is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.

    IT CORE 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 General Public License for more details.

    You should have received a copy of the GNU General Public License
    in the file license.txt along with IT CORE; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

*********************************************************************************/

namespace COREPOS\pos\lib;
use COREPOS\pos\lib\Database;
use COREPOS\pos\lib\CoreState;

/**
  @class Authenticate
  Functions for user authentication
*/
class Authenticate 
{

/**
  Authenticate an employee by password
  @param $password password from employee table
  @return True or False

  If no one is currently logged in, any valid
  password will be accepted. If someone is logged
  in, then only passwords for that user <i>or</i>
  a user with frontendsecurity >= 30 in the
  employee table will be accepted.
*/
static public function checkPassword($password)
{
    $password = strtoupper($password);
    $password = str_replace("'", "", $password);
    $password = str_replace(",", "", $password);
    $paswword = str_replace("+", "", $password);

    if ($password == "TRAINING") {
        $password = 9999; // if password is training, change to '9999'
    }

    $query = "select LoggedIn,CashierNo from globalvalues";
    $dbg = Database::pDataConnect();
    $result = $dbg->query($query);
    $row = $dbg->fetchRow($result);

    if ($row["LoggedIn"] == 0) {
        $queryq = '
            SELECT emp_no, 
                FirstName, 
                LastName, '
                . $dbg->yeardiff($dbg->now(),'birthdate') . ' AS age
            FROM employees 
            WHERE EmpActive = 1 
                AND CashierPassword = ?';
        $prepq = $dbg->prepare($queryq);
        $resultq = $dbg->execute($prepq, array($password));
        $numRows = $dbg->num_rows($resultq);

        if ($numRows > 0) {
            $rowq = $dbg->fetchRow($resultq);

            Database::loadglobalvalues();

            $transno = Database::gettransno($rowq["emp_no"]);
            $globals = array(
                "CashierNo" => $rowq["emp_no"],
                "Cashier" => $rowq["FirstName"]." ".substr($rowq["LastName"], 0, 1).".",
                "TransNo" => $transno,
                "LoggedIn" => 1
            );
            Database::setglobalvalues($globals);

            CoreState::cashierLogin($transno, $rowq['age']);

        } elseif ($password == 9999) {
            Database::loadglobalvalues();

            $transno = Database::gettransno(9999);
            $globals = array(
                "CashierNo" => 9999,
                "Cashier" => _("Training Mode"),
                "TransNo" => $transno,
                "LoggedIn" => 1
            );
            Database::setglobalvalues($globals);

            CoreState::cashierLogin($transno, 0);
        } else {
            return False;
        }
    } else {
        // longer query but simpler. since someone is logged in already,
        // only accept password from that person OR someone with a high
        // frontendsecurity setting
        $querya = '
            SELECT emp_no, 
                FirstName, 
                LastName, '
                . $dbg->yeardiff($dbg->now(),'birthdate') . ' AS age
            FROM employees 
            WHERE EmpActive = 1 
                AND (frontendsecurity >= 30 OR emp_no = ?)
                AND (CashierPassword = ? OR AdminPassword = ?)';
        $args = array($row['CashierNo'], $password, $password);
        $prepa = $dbg->prepare($querya);
        $resulta = $dbg->execute($prepa, $args);

        $numRows = $dbg->num_rows($resulta);

        if ($numRows > 0) {

            Database::loadglobalvalues();
            $rowa = $dbg->fetch_row($resulta);
            CoreState::cashierLogin(False, $rowa['age']);
        } elseif ($row["CashierNo"] == "9999" && $password == "9999") {
            Database::loadglobalvalues();
            CoreState::cashierLogin(False, 0);
        } else {
            return false;
        }
    }

    return true;
}

static public function checkPermission($password, $level)
{
    $emp = self::getEmployeeByPassword($password);
    if ($emp !== false && $emp['frontendsecurity'] >= $level) {
        return true;
    }

    return false;
}

static public function getEmployeeByPassword($password)
{
    $dbc = Database::pDataConnect();
    $prep = $dbc->prepare('
        SELECT *
        FROM employees
        WHERE EmpActive=1 
            AND (CashierPassword=? OR AdminPassword=?)');
    return $dbc->getRow($prep, array($password, $password));
}

static public function getEmployeeByNumber($emp_no)
{
    $dbc = Database::pDataConnect();
    $prep = $dbc->prepare('
        SELECT *
        FROM employees
        WHERE EmpActive=1 
            AND emp_no=?');
    return $dbc->getRow($prep, array($emp_no));
}

static public function getPermission($emp_no)
{
    $emp = self::getEmployeeByNumber($emp_no);
    if ($emp !== false) {
        return $emp['frontendsecurity'];
    }

    return 0;
}

} // end class Authenticate