| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 | <html>    <head>        <title>Runtime Adjustment</title>        <meta charset="UTF-8">        <meta name="viewport" content="width=device-width, initial-scale=1.0 user-scalable=no">        <link rel="stylesheet" href="../../script/semantic/semantic.min.css">        <script type="text/javascript" src="../../script/jquery.min.js"></script>        <script type="text/javascript" src="../../script/semantic/semantic.min.js"></script>        <meta name="viewport" content="width=device-width, initial-scale=1.0 user-scalable=no">        <script type="text/javascript" src="../../script/applocale.js"></script>        <style>        </style>    </head>    <body>        <div class="ui container">            <div class="ui basic segment">                <h3 class="ui header">                    <i class="play icon"></i>                    <div class="content">                        <span locale="runtime/runtime_adjustment">Runtime Adjustment</span>                        <div class="sub header" locale="runtime/update_system_startup_parameters">Update system startup parameters in runtime</div>                    </div>                </h3>                <div class="ui divider"></div>                <form id="setupform" class="ui form" onsubmit="handleFormSubmit(event, this);">                    <div class="field">                        <label locale="runtime/host_name">Host Name</label>                        <input class="config" type="text" name="Hostname" placeholder="My ArOZ">                    </div>                    <div class="field">                        <label locale="runtime/max_upload_size">Max Upload Size (MB)</label>                        <input class="config" type="number" name="MaxUploadSize" placeholder="8192">                    </div>                    <div class="field">                        <label locale="runtime/file_upload_buffer">File Upload Buffer (MB)</label>                        <input class="config" type="number" name="MaxFileUploadBuff" placeholder="25">                    </div>                    <div class="field">                        <label locale="runtime/file_io_buffer">File IO Buffer (Bytes, Default 1024)</label>                        <input class="config" type="number" name="FileIOBuffer" placeholder="1024">                    </div>                    <div class="field">                        <div class="ui toggle checkbox">                            <input class="config" type="checkbox" name="DisableIPResolver" tabindex="0">                            <label locale="runtime/disable_ip_resolver">Disable IP Resolver</label>                            <small locale="runtime/disable_ip_resolver_note">Not trying to analyze Client IP address, useful when the server is hosted under NAT or Reverse Proxy</small>                        </div>                    </div>                    <div class="field">                        <div class="ui toggle checkbox">                            <input class="config" type="checkbox" name="EnableHomePage" tabindex="0">                            <label locale="runtime/enable_home_page">Enable Home Page</label>                            <small locale="runtime/enable_home_page_note">Allowing users to host their own static web pages</small>                        </div>                    </div>                    <div class="field">                        <div class="ui toggle checkbox">                            <input class="config" type="checkbox" name="EnableDirListing" tabindex="0">                            <label locale="runtime/enable_directory_listing">Enable Directory Listing</label>                            <small locale="runtime/enable_directory_listing_note">Allow listing the contents of a directory if the request URL is a folder</small>                        </div>                    </div>                    <div class="ui divider"></div>                    <p locale="runtime/confirmation_message">To continue updating your boot configuration, please confirm that: </p>                    <div class="field">                        <div class="ui checkbox">                            <input type="checkbox" tabindex="0" onchange="toggleConfirmBtn(this.checked)">                            <label locale="runtime/i_know_what_i_am_doing">I know exactly what I am doing</label>                            <small locale="runtime/i_know_what_i_am_doing_note">These changes are only applied to the current runtime session. If something goes wrong, you can restart your system to restore it to the default value.</small>                        </div>                    </div>                    <button id="confirmbtn" class="ui red disabled button" type="submit" locale="runtime/write_to_runtime">Write to Runtime</button>                </form>                <div class="ui red message" style="display:none;" id="failedmsg" locale="runtime/update_failed">                    <div class="header">                        <i class="remove icon"></i> Flags Update Failed                    </div>                    <ul class="list">                        <p id="errmsg">Your settings were not applied due to an unknown error.</p>                    </ul>                </div>                <div id="succmsg" class="ui green message transition" style="display:none;" locale="runtime/param_updated">                    <div class="header">                        <i class="checkmark icon"></i> Startup parameter Updated                    </div>                    <ul class="list">                        <p locale="runtime/param_updated_note">These settings will only be available in the current runtime session. Restart your server to restore the original settings.</p>                    </ul>                </div>            </div>        </div>                    <br><br>        </div>        <script>            var runtimeLocale = NewAppLocale();            runtimeLocale.init("../locale/system_settings/runtime.json", function(){                runtimeLocale.translate();                initCurrentSettingList();            });            function handleFormSubmit(event, obj){                event.preventDefault();                var result = {};                $(obj).find(".config").each(function(){                    var name = $(this).attr("name");                    var value = $(this).val();                    if ($(this).attr('type') == "checkbox"){                        value =  $(this)[0].checked                    }else if ($(this).attr('type') == "number"){                        value = parseInt(value);                    }                    result[name] = value;                });                //Send the results back to the backend                console.log(result);                $.ajax({                    url: "../../system/bootflags",                    data: {opr: "set", value: JSON.stringify(result)},                    method: "POST",                    success: function(data){                        if (data.error != undefined){                            $("#errmsg").text(data.error);                            $("#failedmsg").slideDown("fast").delay(10000).slideUp('fast');                        }else{                            $("#succmsg").slideDown("fast").delay(3000).slideUp('fast');                        }                        //Update the list again                        initCurrentSettingList();                    }                })            }            function initCurrentSettingList(){                $.get("../../system/bootflags", function(data){                    if (data.errpr !== undefined){                        $("#errmsg").text(data.error);                        $("#failedmsg").slideDown("fast").delay(10000).slideUp('fast');                    }else{                        //Load the data                        for (var [key, value] of Object.entries(data)) {                            var targetInputField = $(`[name ='${key}']`);                            if (targetInputField.attr("type") == "text"){                                targetInputField.val(value);                            }else if (targetInputField.attr("type") == "checkbox"){                                targetInputField[0].checked = value;                            }else if (targetInputField.attr("type") == "number"){                                targetInputField.val(value);                            }                        }                    }                });            }            function toggleConfirmBtn(value){                if (value == true){                    $("#confirmbtn").removeClass("disabled");                }else{                    $("#confirmbtn").addClass("disabled");                }            }        </script>    </body></html>
 |