KGRKJGETMRETU895U-589TY5MIGM5JGB5SDFESFREWTGR54TY
Server : Apache/2.4.62
System : FreeBSD fbsdweb2.web.rcn.net 14.1-RELEASE FreeBSD 14.1-RELEASE releng/14.1-n267679-10e31f0946d8 GENERIC amd64
User : www ( 80)
PHP Version : 8.3.8
Disable Function : NONE
Directory :  /domains/irtiweb/CATS/lib/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /domains/irtiweb/CATS/lib/AJAXInterface.php
<?php
/**
 * CATS
 * AJAX Interface Class
 *
 * Copyright (C) 2005 - 2007 Cognizo Technologies, Inc.
 *
 *
 * The contents of this file are subject to the CATS Public License
 * Version 1.1a (the "License"); you may not use this file except in
 * compliance with the License. You may obtain a copy of the License at
 * http://www.catsone.com/.
 *
 * Software distributed under the License is distributed on an "AS IS"
 * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
 * License for the specific language governing rights and limitations
 * under the License.
 *
 * The Original Code is "CATS Standard Edition".
 *
 * The Initial Developer of the Original Code is Cognizo Technologies, Inc.
 * Portions created by the Initial Developer are Copyright (C) 2005 - 2007
 * (or from the year in which this file was created to the year 2007) by
 * Cognizo Technologies, Inc. All Rights Reserved.
 *
 *
 * @package    CATS
 * @subpackage Library
 * @copyright Copyright (C) 2005 - 2007 Cognizo Technologies, Inc.
 * @version    $Id: AJAXInterface.php 3587 2007-11-13 03:55:57Z will $
 */

/**
 *	Standard AJAX Interface
 *	@package    CATS
 *	@subpackage Library
 */
class AJAXInterface
{
    /**
     * Echos an XML document back to the company. The XML string should not
     * contain the <?xml tag.
     *
     * @param string Output XML.
     * @return void
     */
    public function outputXMLPage($xmlString)
    {
        header('Content-type: text/xml');

        echo '<?xml version="1.0" encoding="', AJAX_ENCODING, '"?>', "\n";
        echo $xmlString;
    }

    /**
     * Echos an XML error document back to the company.
     *
     * @param string Error output XML.
     * @return void
     */
    public function outputXMLErrorPage($errorCode, $errorMessage)
    {
        $this->outputXMLPage(
            "<data>\n" .
            "    <errorcode>"    . $errorCode . "</errorcode>\n" .
            "    <errormessage>" . $errorMessage . "</errormessage>\n" .
            "</data>\n"
        );
    }

    /**
     * Echos an XML success document back to the company.
     *
     * @param string XML response message.
     * @return void
     */
    public function outputXMLSuccessPage($response = 'Success!')
    {
        $this->outputXMLPage(
            "<data>\n" .
            "    <errorcode>0</errorcode>\n" .
            "    <errormessage></errormessage>\n" .
            "    <response>" . $response . "</response>\n" .
            "</data>\n"
        );
    }

    /**
     * Returns true if a required numeric ID ($key) is a) present in $_POST,
     * b) not empty, and c) a digit / whole number.
     *
     * @param string Request key name of ID.
     * @param string Allow ID to be 0?
     * @param string Allow ID to be negative?
     * @return boolean Does the value pass all tests?
     */
    public function isRequiredIDValid($key, $allowZero = true,
        $allowNegative = false)
    {
        /* Return false if the key is not present. */
        if (!isset($_REQUEST[$key]))
        {
            return false;
        }

        $value = (string) $_REQUEST[$key];

        /* Return false if the key is empty, or if the key is zero and
         * zero-values are not allowed.
         */
        if (empty($value) && ($value !== '0' || !$allowZero))
        {
            return false;
        }

        /* -0 should not be allowed. */
        if ($value === '-0')
        {
            return false;
        }

        /* If allowing negatives, strip the first character if it's a '-'. */
        if ($allowNegative && $value[0] === '-')
        {
            $value = substr($value, 1);
        }

        /* Only allow digits. */
        if (!ctype_digit($value))
        {
            return false;
        }

        return true;
    }

    /**
     * Returns true if an optional numeric ID ($key) is a) present in $_POST,
     * b) not empty, and c) either 'NULL' / a digit / whole number.
     *
     * @param string Request key name of ID.
     * @return boolean Does the value pass all tests?
     */
    public function isOptionalIDValid($key)
    {
        if (isset($_REQUEST[$key]) && !empty($_REQUEST[$key]) &&
            ($_REQUEST[$key] == 'NULL' ||
            ctype_digit((string) $_REQUEST[$key])))
        {
            return true;
        }

        return false;
    }

    /**
     * Returns true if a checkbox by the name of $key is checked in $request.
     *
     * @param string Request variable name / key.
     * @param array $_GET, $_POST, or $_REQUEST
     * @return boolean Is checkbox checked?
     */
    public function isChecked($key)
    {
        if (isset($_REQUEST[$key]) && !empty($_REQUEST[$key]) &&
            $_REQUEST[$key] != 'false' && $_REQUEST[$key] != 'off')
        {
            return true;
        }

        return false;
    }

    /**
     * Returns trim()'d form input if $key is in $request; otherwise ''.
     *
     * @param string Request variable name / key.
     * @return string Trimmed value or ''.
     */
    public function getTrimmedInput($key)
    {
        if (isset($_REQUEST[$key]))
        {
            return trim($_REQUEST[$key]);
        }

        return '';
    }
}

/**
 *	Secure AJAX Interface
 *	@package    CATS
 *	@subpackage Library
 */
class SecureAJAXInterface extends AJAXInterface
{
    private $_siteID;
    private $_userID;


    public function __construct()
    {
        /* Give the session a unique name to avoid conflicts and start the
         * session. */
        @session_name(CATS_SESSION_NAME);
        session_start();

        /* Validate the session. */
        if (!$this->isSessionLoggedIn())
        {
            $this->outputXMLErrorPage(
                -1, 'You are not logged in. Please log out and log back in.'
            );
            die();
        }

        /* Grab the current user's site ID. */
        $this->_siteID = $_SESSION['CATS']->getSiteID();

        /* Grab the current user's user ID. */
        $this->_userID = $_SESSION['CATS']->getUserID();
    }


    /**
     * Returns the current session's site ID.
     *
     * @return integer Site ID.
     */
    public function getSiteID()
    {
        return $this->_siteID;
    }

    /**
     * Returns the current session's user ID.
     *
     * @return integer User ID.
     */
    public function getUserID()
    {
        return $this->_userID;
    }

    /**
     * Checks to see if we have a valid, logged in session.
     *
     * @return boolean Is the current session valid and logged in?
     */
    public function isSessionLoggedIn()
    {
        if (!isset($_SESSION['CATS']) || empty($_SESSION['CATS']) ||
            !$_SESSION['CATS']->isLoggedIn())
        {
            return false;
        }

        return true;
    }
}

?>

Anon7 - 2021