%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /data/www_bck/varak.net_bck/ampache.varak.net/lib/class/
Upload File :
Create Path :
Current File : //data/www_bck/varak.net_bck/ampache.varak.net/lib/class/access.class.php

<?php
/* vim:set softtabstop=4 shiftwidth=4 expandtab: */
/**
 *
 * LICENSE: GNU General Public License, version 2 (GPLv2)
 * Copyright 2001 - 2014 Ampache.org
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License v2
 * as published by the Free Software Foundation.
 *
 * This program 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
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 *
 */

/**
 * Access Class
 *
 * This class handles the access list mojo for Ampache, it is meant to restrict
 * access based on IP and maybe something else in the future.
 *
 */
class Access
{
    // Variables from DB
    public $id;
    public $name;
    public $start;
    public $end;
    public $level;
    public $user;
    public $type;
    public $enabled;

    public $f_start;
    public $f_end;
    public $f_user;
    public $f_level;
    public $f_type;

    /**
     * constructor
     *
     * Takes an ID of the access_id dealie :)
     */
    public function __construct($access_id = '')
    {
        if (!$access_id) { return false; }

        /* Assign id for use in get_info() */
        $this->id = intval($access_id);

        $info = $this->_get_info();
        foreach ($info as $key=>$value) {
            $this->$key = $value;
        }

        return true;
    }

    /**
     * _get_info
     *
     * Gets the vars for $this out of the database.
     */
    private function _get_info()
    {
        $sql = 'SELECT * FROM `access_list` WHERE `id` = ?';
        $db_results = Dba::read($sql, array($this->id));

        $results = Dba::fetch_assoc($db_results);

        return $results;
    }

    /**
     * format
     *
     * This makes the Access object a nice fuzzy human readable object, spiffy
     * ain't it.
     */
    public function format()
    {
        $this->f_start = inet_ntop($this->start);
        $this->f_end = inet_ntop($this->end);

        $this->f_user = $this->get_user_name();
        $this->f_level = $this->get_level_name();
        $this->f_type = $this->get_type_name();
    }

    /**
     * _verify_range
     *
     * This outputs an error if the IP range is bad.
     */
    private static function _verify_range($startp, $endp)
    {
        $startn = @inet_pton($startp);
        $endn = @inet_pton($endp);

        if (!$startn && $startp != '0.0.0.0' && $startp != '::') {
            Error::add('start', T_('Invalid IPv4 / IPv6 Address Entered'));
            return false;
        }
        if (!$endn) {
            Error::add('end', T_('Invalid IPv4 / IPv6 Address Entered'));
        }

        if (strlen(bin2hex($startn)) != strlen(bin2hex($endn))) {
            Error::add('start', T_('IP Address Version Mismatch'));
            Error::add('end', T_('IP Address Version Mismatch'));
            return false;
        }

        return true;
    }

    /**
     * update
     *
     * This function takes a named array as a datasource and updates the current
     * access list entry.
     */
    public function update($data)
    {
        if (!self::_verify_range($data['start'], $data['end'])) {
            return false;
        }

        $start = @inet_pton($data['start']);
        $end = @inet_pton($data['end']);
        $name = $data['name'];
        $type = self::validate_type($data['type']);
        $level = intval($data['level']);
        $user = $data['user'] ?: '-1';
        $enabled = make_bool($data['enabled']) ? 1 : 0;

        $sql = 'UPDATE `access_list` SET `start` = ?, `end` = ?, `level` = ?, ' .
            '`user` = ?, `name` = ?, `type` = ?, `enabled` = ? WHERE `id` = ?';
        Dba::write($sql,
            array($start, $end, $level, $user, $name, $type, $enabled, $this->id));

        return true;
    }

    /**
     * create
     *
     * This takes a keyed array of data and trys to insert it as a
     * new ACL entry
     */
    public static function create($data)
    {
        if (!self::_verify_range($data['start'], $data['end'])) {
            return false;
        }

        // Check existing ACLs to make sure we're not duplicating values here
        if (self::exists($data)) {
            debug_event('ACL Create', 'Error: An ACL equal to the created one already exists. Not adding another one: ' . $data['start'] . ' - ' . $data['end'], 1);
            Error::add('general', T_('Duplicate ACL defined'));
            return false;
        }

        $start = @inet_pton($data['start']);
        $end = @inet_pton($data['end']);
        $name = $data['name'];
        $user = $data['user'] ?: '-1';
        $level = intval($data['level']);
        $type = self::validate_type($data['type']);
        $enabled = make_bool($data['enabled']) ? 1 : 0;

        $sql = 'INSERT INTO `access_list` (`name`, `level`, `start`, `end`, ' .
            '`user`,`type`,`enabled`) VALUES (?, ?, ?, ?, ?, ?, ?)';
        Dba::write($sql, array($name, $level, $start, $end, $user, $type, $enabled));

        return true;

    }

    /**
     * exists
     *
     * This sees if the ACL that we've specified already exists in order to
     * prevent duplicates. The name is ignored.
     */
    public static function exists($data)
    {
        $start = inet_pton($data['start']);
        $end = inet_pton($data['end']);
        $type = self::validate_type($data['type']);
        $user = $data['user'] ?: '-1';

        $sql = 'SELECT * FROM `access_list` WHERE `start` = ? AND `end` = ? ' .
            'AND `type` = ? AND `user` = ?';
        $db_results = Dba::read($sql, array($start, $end, $type, $user));

        if (Dba::fetch_assoc($db_results)) {
            return true;
        }

        return false;
    }

    /**
     * delete
     *
     * deletes the specified access_list entry
     */
    public static function delete($id)
    {
        Dba::write('DELETE FROM `access_list` WHERE `id` = ?', array($id));
    }

    /**
     * check_function
     *
     * This checks if specific functionality is enabled.
     */
    public static function check_function($type)
    {
        switch ($type) {
            case 'download':
                return AmpConfig::get('download');
            case 'batch_download':
                if (!function_exists('gzcompress')) {
                    debug_event('access', 'ZLIB extension not loaded, batch download disabled', 3);
                    return false;
                }
                if (AmpConfig::get('allow_zip_download') AND $GLOBALS['user']->has_access('25')) {
                    return AmpConfig::get('download');
                }
            break;
            default:
                return false;
        }
    }

    /**
     * check_network
     *
     * This takes a type, ip, user, level and key and then returns whether they
     * are allowed. The IP is passed as a dotted quad.
     */
    public static function check_network($type, $user, $level, $ip=null)
    {
        if (!AmpConfig::get('access_control')) {
            switch ($type) {
                case 'interface':
                case 'stream':
                    return true;
                default:
                    return false;
            }
        }

        // Clean incoming variables
        $ip = $ip ?: $_SERVER['REMOTE_ADDR'];
        $ip = inet_pton($ip);

        switch ($type) {
            case 'init-api':
                if ($user) {
                    $user = User::get_from_username($user);
                    $user = $user->id;
                }
            case 'api':
                $type = 'rpc';
            case 'network':
            case 'interface':
            case 'stream':
            break;
            default:
                return false;
        } // end switch on type

        $sql = 'SELECT `id` FROM `access_list` ' .
            'WHERE `start` <= ? AND `end` >= ? ' .
            'AND `level` >= ? AND `type` = ?';

        $params = array($ip, $ip, $level, $type);

        if (strlen($user) && $user != '-1') {
            $sql .= " AND `user` IN(?, '-1')";
            $params[] = $user;
        } else {
            $sql .= " AND `user` = '-1'";
        }

        $db_results = Dba::read($sql, $params);

        if (Dba::fetch_row($db_results)) {
            // Yah they have access they can use the mojo
            return true;
        }

        return false;
    }

    /**
     * check_access
     *
     * This is the global 'has_access' function.(t can check for any 'type'
     * of object.
     *
     * Everything uses the global 0,5,25,50,75,100 stuff. GLOBALS['user'] is
     * always used.
     */
    public static function check($type, $level)
    {
        if (AmpConfig::get('demo_mode')) {
            return true;
        }
        if (defined('INSTALL')) {
            return true;
        }

        $level = intval($level);

        // Switch on the type
        switch ($type) {
            case 'localplay':
                // Check their localplay_level
                return (AmpConfig::get('localplay_level') >= $level
                    || $GLOBALS['user']->access >= 100);
            case 'interface':
                // Check their standard user level
                return ($GLOBALS['user']->access >= $level);
            default:
                return false;
        }
    }

    /**
     * validate_type
     *
     * This validates the specified type; it will always return a valid type,
     * even if you pass in an invalid one.
     */
    public static function validate_type($type)
    {
        switch ($type) {
            case 'rpc':
            case 'interface':
            case 'network':
                return $type;
            default:
                return 'stream';
        }
    }

    /**
     * get_access_lists
     * returns a full listing of all access rules on this server
     */
    public static function get_access_lists()
    {
        $sql = 'SELECT `id` FROM `access_list`';
        $db_results = Dba::read($sql);

        $results = array();

        while ($row = Dba::fetch_assoc($db_results)) {
            $results[] = $row['id'];
        }

        return $results;
    }


    /**
     * get_level_name
     *
     * take the int level and return a named level
     */
    public function get_level_name()
    {
        if ($this->level >= '75') {
            return T_('All');
        }
        if ($this->level == '5') {
            return T_('View');
        }
        if ($this->level == '25') {
            return T_('Read');
        }
        if ($this->level == '50') {
            return T_('Read/Write');
        }
    }

    /**
     * get_user_name
     *
     * Return a name for the users covered by this ACL.
     */
    public function get_user_name()
    {
        if ($this->user == '-1') { return T_('All'); }

        $user = new User($this->user);
        return $user->fullname . " (" . $user->username . ")";
    }

    /**
     * get_type_name
     *
     * This function returns the pretty name for our current type.
     */
    public function get_type_name()
    {
        switch ($this->type) {
            case 'rpc':
                return T_('API/RPC');
            case 'network':
                return T_('Local Network Definition');
            case 'interface':
                return T_('Web Interface');
            case 'stream':
            default:
                return T_('Stream Access');
        }
    }
}

Zerion Mini Shell 1.0