%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /backups/router/usr/local/opnsense/mvc/app/views/OPNsense/DHCPv6/
Upload File :
Create Path :
Current File : //backups/router/usr/local/opnsense/mvc/app/views/OPNsense/DHCPv6/leases.volt

{#
 # 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.
 #}

<script>
    $( document ).ready(function() {
        let show_inactive = false;
        let selected_interfaces = [];

        if (window.localStorage) {
            if (window.localStorage.getItem("api.dhcp.leases6.inactive") !== null) {
                show_inactive = window.localStorage.getItem("api.dhcp.leases6.inactive") == 'true'
                $("#show-inactive").prop('checked', show_inactive);
            }
        }

        $("#show-inactive").change(function() {
            show_inactive = this.checked;
            if (window.localStorage) {
                window.localStorage.setItem("api.dhcp.leases6.inactive", show_inactive);
            }

            $("#grid-leases").bootgrid('reload');
        });

        $("#interface-selection").on("changed.bs.select", function (e) {
            console.log($(this).val());
            selected_interfaces = $(this).val();
            $("#grid-leases").bootgrid('reload');
        })

        $("#grid-leases").UIBootgrid({
            search:'/api/dhcpv6/leases/searchLease/',
            del:'/api/dhcpv6/leases/delLease/',
            options: {
                selection: false,
                multiSelect: false,
                useRequestHandlerOnGet: true,
                requestHandler: function(request) {
                    request['inactive'] = show_inactive;
                    request['selected_interfaces'] = selected_interfaces;
                    return request;
                },
                responseHandler: function (response) {
                    if (response.hasOwnProperty('interfaces')) {
                        for ([intf, descr] of Object.entries(response['interfaces'])) {
                            let exists = false;
                            $('#interface-selection option').each(function() {
                                if (this.value == intf) {
                                    exists = true;
                                }
                            });

                            if (!exists) {
                                $("#interface-selection").append($('<option>', {
                                    value: intf,
                                    text: descr
                                }));
                            }
                        }
                        $("#interface-selection").selectpicker('refresh');
                    }
                    return response;
                },
                formatters: {
                    "macformatter": function (column, row) {
                        let mac = '<span class="overflow">' + row.mac + '</span>';
                        if (row.man != '') {
                            mac = mac + '<br/>' + '<small><i>' + row.man + '</i></small>';
                        }
                        return mac;
                    },
                    "overflow": function (column, row) {
                        return '<span class="overflow">' + row[column.id] + '</span><br/>'
                    },
                    "statusformatter": function (column, row) {
                        let connected = row.status == 'online' ? 'text-success' : 'text-danger';
                        return '<i class="fa fa-plug ' + connected +'" title="' + row.status + '" data-toggle="tooltip"></i>'
                    },
                    "commands": function (column, row) {
                        /* we override the default commands data formatter in order to utilize
                         * two different types of data keys for two different actions. The mapping
                         * action needs a DUID, while the delete action requires an IPv6 address.
                         */
                        if (row.type == 'static') {
                            return '';
                        }

                        let static_map = '';

                        if (row.if != '') {
                            static_map = '<a class="btn btn-default btn-xs" href="/services_dhcpv6_edit.php?if=' + row.if +
                                '&amp;duid=' + row.duid + '">' +
                                '<i class="fa fa-plus fa-fw act-map" data-value="' + row.duid + '" data-toggle="tooltip" ' +
                                'title="{{lang._("Add a static mapping for this MAC address")}}"></i>' +
                                '</a>';
                        }

                        /* The delete action can be hooked up to the default bootgrid behaviour */
                        let deleteip = '<button type="button" class="btn btn-xs btn-default bootgrid-tooltip command-delete"' +
                                'data-row-id="' + row.address + '" data-action="deleteSelected">' +
                                '<i class="fa fa-trash fa-fw"></i>' +
                                '</a>';

                        return static_map + ' ' + deleteip;
                    }
                }
            }
        }).on("loaded.rs.jquery.bootgrid", function (e) {
            $(".lease-tooltip").tooltip({placement: "auto left"});
        });

        $("#grid-prefixes").UIBootgrid({
            search:'/api/dhcpv6/leases/searchPrefix/'
        });

        $("#inactive-selection-wrapper").detach().prependTo('#grid-leases-header > .row > .actionBar');
        $("#interface-selection-wrapper").detach().prependTo('#grid-leases-header > .row > .actionBar > .actions');

        if (window.location.hash != "") {
            $('a[href="' + window.location.hash + '"]').click();
        } else {
            $('a[href="#leases"]').click();
        }

        updateServiceControlUI('dhcpv6');
    });
</script>

<style>
.overflow {
    text-overflow: clip;
    white-space: normal;
    word-break: break-word;
}
</style>

<ul class="nav nav-tabs" data-tabs="tabs" id="maintabs">
    <li><a data-toggle="tab" href="#leases" id="leases_tab">{{ lang._('Leases') }}</a></li>
    <li><a data-toggle="tab" href="#prefixes" id="prefixes_tab">{{ lang._('Delegated Prefixes') }}</a></li>
</ul>
<div class="tab-content content-box col-xs-12 __mb">
    <div id="leases" class="tab-pane fade in active">
        <div id="inactive-selection-wrapper" style="float: left;">
            <label>
                <input id="show-inactive" type="checkbox"/>
                {{ lang._('Show inactive') }}
            </label>
        </div>
        <div class="btn-group" id="interface-selection-wrapper">
            <select class="selectpicker" multiple="multiple" data-live-search="true" id="interface-selection" data-width="auto" title="All Interfaces">
            </select>
        </div>
        <table id="grid-leases" class="table table-condensed table-hover table-striped table-responsive">
            <tr>
            <thead>
            <tr>
                <th data-column-id="if_descr" data-type="string" data-formatter="overflow">{{ lang._('Interface') }}</th>
                <th data-column-id="address" data-identifier="true" data-width="12em" data-formatter="overflow">{{ lang._('IP Address') }}</th>
                <th data-column-id="iaid" data-type="number" data-formatter="overflow">{{ lang._('IAID') }}</th>
                <th data-column-id="duid" data-type="string" data-formatter="overflow">{{ lang._('DUID') }}</th>
                <th data-column-id="mac" data-type="string" data-width="9em" data-formatter="macformatter">{{ lang._('MAC Address') }}</th>
                <th data-column-id="descr" data-type="string" data-formatter="overflow">{{ lang._('Description') }}</th>
                <th data-column-id="cltt" data-type="string" data-formatter="overflow">{{ lang._('Last Transaction Time') }}</th>
                <th data-column-id="ends" data-type="string" data-formatter="overflow">{{ lang._('End') }}</th>
                <th data-column-id="status" data-type="string" data-formatter="statusformatter">{{ lang._('Status') }}</th>
                <th data-column-id="state" data-type="string">{{ lang._('State') }}</th>
                <th data-column-id="type" data-type="string">{{ lang._('Lease Type') }}</th>
                <th data-column-id="commands" data-formatter="commands", data-sortable="false"></th>
            </tr>
            </thead>
            <tbody>
            </tbody>
            <tfoot>
            </tfoot>
            </tr>
        </table>
    </div>
    <div id="prefixes" class="tab-pane fade in">
        <table id="grid-prefixes" class="table table-condensed table-hover table-striped table-responsive">
            <tr>
            <thead>
            <tr>
                <th data-column-id="prefix" data-type="string">{{ lang._('IPv6 Prefix') }}</th>
                <th data-column-id="iaid" data-type="number" data-width="5em">{{ lang._('IAID') }}</th>
                <th data-column-id="duid" data-type="string">{{ lang._('DUID') }}</th>
                <th data-column-id="cltt" data-type="string">{{ lang._('Last Transaction Time') }}</th>
                <th data-column-id="ends" data-type="string">{{ lang._('End') }}</th>
                <th data-column-id="state" data-type="string">{{ lang._('State') }}</th>
            </tr>
            </thead>
            <tbody>
            </tbody>
            <tfoot>
            </tfoot>
            </tr>
        </table>
    </div>
</div>

Zerion Mini Shell 1.0