CORE-POS/IS4C

View on GitHub
fannie/auth/utilities.php

Summary

Maintainability
A
45 mins
Test Coverage
F
38%
<?php
/*******************************************************************************

    Copyright 2009 Whole Foods Co-op

    This file is part of CORE-POS.

    CORE-POS 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.

    CORE-POS 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

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

/*
utility functions
*/


/* --COMMENTS - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    * 12Nov2012 Eric Lee In getGID() test FANNIE_DBMS_SERVER for SQL syntax.
*/

/*
connect to the database
having this as a separate function makes changing
the database easier
*/
function dbconnect()
{
    if (!class_exists("FannieAPI")){
        include(dirname(__FILE__).'/../classlib2.0/FannieAPI.php');
    }
    $dbc = FannieDB::get(FannieConfig::config('OP_DB'));

    return $dbc;
}

function guesspath(){
    $path = "";
    $found = False;
    $uri = $_SERVER["REQUEST_URI"];
    $tmp = explode("?",$uri);
    if (count($tmp) > 1) $uri = $tmp[0];
    foreach(explode("/",$uri) as $x){
        if (strpos($x,".php") === False
            && strlen($x) != 0){
            $path .= "../";
        }
        if (!$found && stripos($x,"fannie") !== False){
            $found = True;
            $path = "";
        }
        
    }
    return $path;
}

function init_check(){
    return file_exists(dirname(__FILE__)."/init.php");
}

/*
checking whether a string is alphanumeric is
a good idea to prevent sql injection
*/
function isAlphanumeric($str){
  if (preg_match("/^\\w*$/",$str) == 0){
    return false;
  }
  return true;
}

function getUID($name){
  if (!auth_enabled()) return '0000';

  $sql = dbconnect();
  $fetchQ = $sql->prepare("select uid from Users where name=?");
  $fetchR = $sql->execute($fetchQ,array($name));
  if ($sql->num_rows($fetchR) == 0){
    return false;
  }
  $uid = $sql->fetchRow($fetchR);
  $uid = $uid[0];
  return $uid;
}

function getNumUsers(){
  if (!auth_enabled()) return 9999;
    
  $sql = dbconnect();
  $fetchQ = $sql->prepare("select uid from Users");
  $fetchR = $sql->execute($fetchQ);

  return $sql->num_rows($fetchR);
}

function getNumAdmins(){
    $sql = dbconnect();
    $num = 0;
    if ($sql->table_exists('userPrivs')){
        $q = $sql->prepare("SELECT uid FROM userPrivs WHERE auth_class='admin'");
        $r = $sql->execute($q);
        $num += $sql->num_rows($r);
    }
    if ($sql->table_exists('userGroups') && $sql->table_exists('userGroupPrivs')){
        $q = $sql->prepare("SELECT username FROM userGroups AS g LEFT JOIN
            userGroupPrivs AS p ON g.gid=p.gid
            WHERE p.auth='admin'");
        $r = $sql->execute($q);
        $num += $sql->num_rows($r);

    }
    return $num;
}

function getGID($group)
{
    if (!isAlphaNumeric($group)) {
        return false;
    }
    $sql = dbconnect();

    $gidQ = "select gid from userGroups where name=?";
    $gidQ = $sql->addSelectLimit($gidQ,1); 
    $gidP = $sql->prepare($gidQ);
    $gidR = $sql->execute($gidP,array($group));

    if ($sql->num_rows($gidR) == 0)
        return false;

    $row = $sql->fetchRow($gidR);
    return $row[0];
}

function genSessID(){
  $session_id = '';
  srand(time());
  for ($i = 0; $i < 50; $i++){
    $digit = (rand() % 35) + 48;
    if ($digit > 57){
      $digit+=7;
    }
    $session_id .= chr($digit);
  }
  return $session_id;
}

function doLogin($name){
    $session_id = genSessID();  

    $sql = dbconnect();
    $sessionQ = $sql->prepare("update Users set session_id = ? where name=?");
    $sessionR = $sql->execute($sessionQ,array($session_id,$name));

    /**
      Periodically purge expired records
        9May13 EL Not periodic.
    */
    $delP = $sql->prepare('DELETE FROM userSessions
            WHERE expires < '.$sql->now());
    $delR = $sql->execute($delP);

    /**
      New behavior - Store session id in dedicated table.
      This allows more than one session record per user
      record - i.e., someone can be logged in on multiple
      computers simultaneously.
    */
    $uid = getUID($name);
    $ip = (isset($_SERVER['REMOTE_ADDR'])) ? $_SERVER['REMOTE_ADDR'] : 'unknown';
    $expires = date('Y-m-d',strtotime('tomorrow'));
    $sessionP = $sql->prepare('INSERT INTO userSessions 
                (uid,session_id,ip,expires)
                VALUES (?,?,?,?)');
    $sessionR = $sql->execute($sessionP,array($uid,$session_id,$ip,$expires));

    $session_data = array("name"=>$name,"session_id"=>$session_id);
    $cookie_data = serialize($session_data);

    setcookie('session_data',base64_encode($cookie_data),0,'/');
}

function syncUserShadow($name){
    $localdata = posix_getpwnam($name);

    $currentUID = getUID($name);
    $posixUID = str_pad($localdata['uid'],4,"0",STR_PAD_LEFT);
    $realname = str_replace("'","''",$localdata['gecos']);
    $sql = dbconnect(); 

    if (!$currentUID){
        $addQ = $sql->prepare("INSERT INTO Users 
            (name,password,salt,uid,session_id,real_name)
            VALUES (?,'','',?,'',?)");
        $sql->execute($addQ,array($name,$posixUID,$realname));
    }
    else {
        $upQ1 = $sql->prepare("UPDATE Users SET real_name=?
                WHERE name=?");
        $sql->execute($upQ1,array($realname,$name));
    }
}

function syncUserLDAP($name,$uid,$fullname){
    $currentUID = getUID($name);
    $sql = dbconnect();

    if (!$currentUID){
        $addQ = $sql->prepare("INSERT INTO Users 
            (name,password,salt,uid,session_id,real_name)
            VALUES (?,'','',?,'',?)");
        $sql->execute($addQ,array($name,$uid,$fullname));
    }
    else {
        $upQ1 = $sql->prepare("UPDATE Users SET real_name=?
                WHERE name=?");
        $sql->execute($upQ1,array($fullname,$name));
    }
}

function auth_enabled()
{
    if (!class_exists('FannieConfig')) {
        include(dirname(__FILE__) . '/../classlib2.0/FannieConfig.php');
    }

    return FannieConfig::config('AUTH_ENABLED', false);
}