%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /backups/router/usr/local/opnsense/mvc/app/models/OPNsense/Firewall/
Upload File :
Create Path :
Current File : //backups/router/usr/local/opnsense/mvc/app/models/OPNsense/Firewall/Group.php

<?php

/*
 * Copyright (C) 2023 Deciso B.V.
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain the above copyright notice,
 *    this list of conditions and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 * AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
 * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

namespace OPNsense\Firewall;

use OPNsense\Base\BaseModel;
use OPNsense\Core\Config;

/**
 * Class Group
 * @package OPNsense\Firewall
 */
class Group extends BaseModel
{
    private function ruleIterator()
    {
        $sources = [
            ['filter', 'rule'],
            ['nat', 'rule'],
            ['nat', 'onetoone'],
            ['nat', 'outbound', 'rule'],
        ];
        // os-firewall plugin paths
        $sources[] = ['OPNsense', 'Firewall', 'Filter', 'rules', 'rule'];
        $sources[] = ['OPNsense', 'Firewall', 'Filter', 'snatrules', 'rule'];
        $sources[] = ['OPNsense', 'Firewall', 'Filter', 'npt', 'rule'];

        foreach ($sources as $aliasref) {
            $cfgsection = Config::getInstance()->object();
            foreach ($aliasref as $cfgName) {
                if ($cfgsection != null) {
                    $cfgsection = $cfgsection->$cfgName;
                }
            }
            if ($cfgsection != null) {
                $idx = 0;
                foreach ($cfgsection as $node) {
                    $tmp = $node->attributes();
                    if (!empty($tmp) && !empty($tmp['uuid'])) {
                        yield sprintf("%s.%s", implode('.', $aliasref), $tmp['uuid']) => $node;
                    } else {
                        yield sprintf("%s.%d", implode('.', $aliasref), $idx) => $node;
                    }
                    $idx++;
                }
            }
        }
    }

    /**
     * refactor group usage (replace group in rules)
     */
    public function refactor($oldname, $newname)
    {
        $has_changed = false;
        foreach ($this->ruleIterator() as $node) {
            $interfaces = explode(",", (string)$node->interface);
            if (in_array($oldname, $interfaces)) {
                  unset($interfaces[array_search((string)$oldname, $interfaces)]);
                  $interfaces[] = $newname;
                  $node->interface = implode(",", $interfaces);
                  $has_changed = true;
            }
            foreach (['source', 'destination'] as $net) {
                if (!empty($node->$net) && !empty($node->$net->network) && (string)$node->$net->network == $oldname) {
                    $node->$net->network = $newname;
                    $has_changed = true;
                }
            }
        }
        return $has_changed;
    }

    /**
     * is group used
     */
    public function whereUsed($name)
    {
        $result = [];
        foreach ($this->ruleIterator() as $path => $node) {
            $isUsed = false;
            if (in_array($name, explode(",", (string)$node->interface))) {
                $isUsed = true;
            }
            foreach (['source', 'destination'] as $net) {
                if (!empty($node->$net) && !empty($node->$net->network) && (string)$node->$net->network == $name) {
                    $isUsed = true;
                }
            }
            if ($isUsed) {
                $result[$path] = !empty($node->descr) ? (string)$node->descr : "";
            }
        }
        return $result;
    }
}

Zerion Mini Shell 1.0