AnonSec Shell
Server IP : 54.36.91.62  /  Your IP : 216.73.217.94
Web Server : Apache
System : Linux webm013.cluster127.gra.hosting.ovh.net 5.15.206-ovh-vps-grsec-zfs-classid #1 SMP Fri May 15 02:41:25 UTC 2026 x86_64
User : coopiak ( 151928)
PHP Version : 8.3.23
Disable Function : _dyuweyrj4,_dyuweyrj4r,dl
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/coopiak/plats-individuels/lyon/media/plg_system_jcepro/editor/plugins/mediamanager/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     

Current File : /home/coopiak/plats-individuels/lyon/media/plg_system_jcepro/editor/plugins/mediamanager/plugin.js
/* jce - 2.9.82 | 2024-11-20 | https://www.joomlacontenteditor.net | Source: https://github.com/widgetfactory/jce | Copyright (C) 2006 - 2024 Ryan Demmer. All rights reserved | GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html */
!function() {
    var each = tinymce.each, extend = tinymce.extend, DOM = tinymce.DOM, Event = tinymce.dom.Event, htmlSchema = new tinymce.html.Schema(), DomParser = tinymce.html.DomParser, Uuid = tinymce.util.Uuid;
    function isMedia(node) {
        return node && DOM.getParent(node, "[data-mce-object]");
    }
    var mediaProviders = {
        youtube: /youtu(\.)?be(.+)?\/(.+)/,
        vimeo: /vimeo(.+)?\/(.+)/,
        dailymotion: /dai\.?ly(motion)?(\.com)?/,
        scribd: /scribd\.com\/(.+)/,
        slideshare: /slideshare\.net\/(.+)\/(.+)/,
        soundcloud: /soundcloud\.com\/(.+)/,
        spotify: /spotify\.com\/(.+)/,
        ted: /ted\.com\/talks\/(.+)/,
        twitch: /twitch\.tv\/(.+)/,
        facebook: /facebook\.com\/(.+)/,
        instagram: /instagram\.com\/(.+)/,
        threads: /threads\.net\/(.+)/,
        video: /\.(mp4|ogv|ogg|webm)$/,
        audio: /\.(mp3|ogg|webm|wav|m4a|aiff)$/
    };
    function stripQuery(value) {
        return value = -1 !== value.indexOf("?") ? value.substring(0, value.indexOf("?")) : value;
    }
    function insertMedia(ed, data, provider) {
        var attribs, node = ed.selection.getNode(), mediaApi = ed.plugins.media;
        data.html && (attribs = function(html) {
            var attribs = {
                html: ""
            }, parser = new DomParser({
                verify_html: !0,
                validate: !0,
                forced_root_block: !1,
                invalid_elements: "script,noscript,svg"
            }, htmlSchema);
            return parser.addNodeFilter("iframe", function(nodes) {
                for (var node, i = nodes.length; i--; ) {
                    node = nodes[i], each(node.attributes.map, function(val, name) {
                        attribs[name] = val;
                    });
                    var child = node.firstChild;
                    if (child && htmlSchema.isValid(child.name)) for (;child.value && (attribs.html += child.value), 
                    child = child.next; );
                }
            }), parser.parse(html), attribs;
        }(data.html), data.width && delete attribs.width, data.height && delete attribs.height, 
        extend(data, attribs)), data.query && (-1 !== data.src.indexOf("?") ? data.src += "&" + data.query : data.src += "?" + data.query), 
        isMedia(node) ? mediaApi.updateMedia(data) : (attribs = getMediaHtml(ed, data), 
        ed.execCommand("insertMediaHtml", !1, attribs)), ed.undoManager.add(), ed.nodeChanged();
    }
    function getMediaHtml(ed, value) {
        var nodeName = "iframe", attribs = {}, innerHTML = "", src = stripQuery((value = "string" == typeof value ? {
            src: value
        } : value).src), boolAttrs = (/\.(mp4|m4v|ogg|webm|ogv)$/.test(src) ? nodeName = "video" : /\.(mp3|m4a|oga)$/.test(src) && (nodeName = "audio"), 
        ed.schema.getBoolAttrs());
        return each(value, function(val, name) {
            if ("" == val && !boolAttrs[name]) return !0;
            value.html && (innerHTML = value.html), !ed.schema.isValid(nodeName, name) && -1 === name.indexOf("-") || (attribs[name] = val);
        }), ed.dom.createHTML(nodeName, attribs, innerHTML);
    }
    function isSupportedMedia(ed, url) {
        var mediaApi, match;
        return !(!url || "string" != typeof url || (mediaApi = ed.plugins.media, 
        match = !1, ed = ed.getParam("mediamanager", {}), url = stripQuery(url), 
        each(mediaProviders, function(rx, key) {
            rx.test(url) && mediaApi.isSupportedMedia(url) && (match = key);
        }), match || (/\.(mov|qt|mpg|mpeg)$/i.test(url) && (match = "quicktime"), 
        /\.(swf|dcr)$/i.test(url) && (match = "flash"), /\.divx$/i.test(url) && (match = "divx")), 
        match && !1 === ed.quickmedia[match])) && (ed.custom_embed && each(ed.custom_embed, function(values, name) {
            values = values.expression || name;
            if (new RegExp(values).test(url)) return match = name, !0;
        }), match);
    }
    function getMediaProps(ed, data, provider) {
        var mediaApi = ed.plugins.media, value = data.src || "", defaultValues = {}, mediaApi = (defaultValues[provider] = mediaApi.getMediaProps(data, provider), 
        ed.getParam("mediamanager", {})), attribs = (mediaApi.custom_embed && mediaApi.custom_embed[provider] && (defaultValues[provider] = mediaApi.custom_embed[provider] || {}, 
        delete defaultValues[provider].expression, defaultValues[provider] = extend({
            src: value,
            width: 560,
            height: 315,
            frameborder: 0
        }, defaultValues[provider])), data.attributes || {}), args = {}, attribsMap = [ "title", "id", "class", "style", "width", "height" ];
        return each(attribs, function(val, key) {
            key === provider ? args = extend(args, attribs[provider]) : -1 !== tinymce.inArray(attribsMap, key) && (args[key] = val);
        }), defaultValues[provider] = extend(defaultValues[provider], args), defaultValues;
    }
    function getEmbedData(ed, data, provider) {
        var defaultProviderData = data[provider] || "";
        return new Promise(function(resolve, reject) {
            if (!defaultProviderData) return reject();
            var video, value;
            if ("video" === provider) (video = document.createElement("video")).onloadedmetadata = function() {
                data.video.width || data.video.height || tinymce.extend(data.video, {
                    width: video.videoWidth,
                    height: video.videoHeight
                }), video = null, tinymce.is(data.video.controls) || (data.video.controls = "controls"), 
                resolve(data.video);
            }, video.onerror = function() {
                video = null, resolve(data.video);
            }, video.src = ed.documentBaseURI.toAbsolute(data.video.src); else {
                if ("audio" !== provider) return defaultProviderData.oembed ? (value = defaultProviderData.url || defaultProviderData.src, 
                value = {
                    id: Uuid.uuid("wf_"),
                    method: "getEmbedData",
                    params: [ provider, encodeURIComponent(value), "" ]
                }, void tinymce.util.XHR.send({
                    url: ed.getParam("site_url") + "index.php?option=com_jce&task=plugin.rpc&plugin=mediamanager&" + ed.settings.query,
                    data: "json=" + JSON.stringify(value),
                    content_type: "application/x-www-form-urlencoded",
                    success: function(response) {
                        var data = "";
                        try {
                            data = JSON.parse(response);
                        } catch (e) {
                            return resolve(defaultProviderData);
                        }
                        if (!data.result) return resolve(defaultProviderData);
                        if (data.result.error) return reject(data.result.error);
                        response = tinymce.is(data.result, "object") ? data.result : {};
                        if ("string" == typeof data.result) try {
                            response = JSON.parse(data.result);
                        } catch (e) {
                            return resolve(defaultProviderData);
                        }
                        !response.src && response.url && (response.src = response.url), 
                        data = tinymce.extend(defaultProviderData, response), resolve(data);
                    },
                    error: function(err, xhr) {
                        return resolve(defaultProviderData);
                    }
                })) : resolve(defaultProviderData);
                tinymce.is(data.audio.controls) || (data.audio.controls = "controls"), 
                resolve(data.audio);
            }
        });
    }
    function getDataAndInsert(ed, data) {
        return new Promise(function(resolve, reject) {
            if (data.src) {
                var provider = isSupportedMedia(ed, data.src);
                if (!provider) return ed.windowManager.alert({
                    title: ed.getLang("mediamanager.error", "Media Manager Error"),
                    text: ed.getLang("mediamanager.url_unsupported", "This URL is not currently supported")
                });
                ed.setProgressState(!0);
                var props = getMediaProps(ed, data, provider);
                props[provider].url = data.src, getEmbedData(ed, props, provider).then(function(args) {
                    ed.setProgressState(!1), insertMedia(ed, args), resolve();
                }, function(msg) {
                    ed.setProgressState(!1), msg && ed.windowManager.alert({
                        title: ed.getLang("mediamanager.insert_error", "Media Manager Insert Error"),
                        text: msg
                    }), reject();
                });
            }
        });
    }
    tinymce.PluginManager.add("mediamanager", function(ed, url) {
        var self = this;
        function isMediaElm(n) {
            if (n = ed.dom.getParent(n, "[data-mce-object]")) {
                n = ed.plugins.media.getMediaData();
                if (n.src) return !1 !== isSupportedMedia(ed, n.src);
            }
        }
        function isPopup(n) {
            return !!ed.dom.is(n, "a.jcepopup") && (/(flash|quicktime|divx|video|audio)/.test(n.type) || isSupportedMedia(ed, n.href));
        }
        ed.addCommand("mceMedia", function() {
            var se = ed.selection, n = se.getNode();
            isPopup(n) && se.select(n), ed.windowManager.open({
                file: ed.getParam("site_url") + "index.php?option=com_jce&task=plugin.display&plugin=mediamanager",
                size: "mce-modal-portrait-full"
            }, {
                plugin_url: url
            });
        }), ed.onNodeChange.add(function(ed, cm, n, collapsed) {
            var node, nonEditClass, state = !1, disabled = !0;
            node = n, nonEditClass = tinymce.settings.noneditable_noneditable_class || "mceNonEditable", 
            (node.attr ? node.hasClass(nonEditClass) : DOM.hasClass(node, nonEditClass)) || (disabled = !1), 
            isMediaElm(n) && (state = !0), cm.setDisabled("mediamanager", disabled && !collapsed), 
            cm.setActive("mediamanager", state || isPopup(n));
        }), ed.onPreInit.add(function() {
            var cm, form, urlCtrl, args, attribs, mediaApi = ed.plugins.media, params = ed.getParam("mediamanager", {});
            !0 === params.basic_dialog && (cm = ed.controlManager, form = cm.createForm("media_form"), 
            args = {
                label: ed.getLang("dlg.url", "URL"),
                name: "src",
                clear: !0
            }, params.basic_dialog_filebrowser && tinymce.extend(args, {
                picker: !0,
                picker_label: "browse",
                picker_icon: "media",
                onpick: function() {
                    ed.execCommand("mceFileBrowser", !0, {
                        caller: "mediamanager",
                        callback: function(selected, data) {
                            data = data[0].url;
                            urlCtrl.value(data), window.setTimeout(function() {
                                urlCtrl.focus();
                            }, 10);
                        },
                        filter: params.filetypes.join(","),
                        value: urlCtrl.value()
                    });
                }
            }), params.upload && extend(args, {
                upload_label: "upload.label",
                upload_accept: params.upload.filetypes,
                upload: function(e, file) {
                    if (file && file.name) {
                        var url = self.getUploadURL(file);
                        if (!url) return ed.windowManager.alert({
                            text: ed.getLang("upload.file_extension_error", "File type not supported"),
                            title: ed.getLang("upload.error", "Upload Error")
                        }), !1;
                        urlCtrl.setLoading(!0), extend(file, {
                            filename: file.name.replace(/[\+\\\/\?\#%&<>"\'=\[\]\{\},;@\^\(\)\xa3\u20ac$~]/g, ""),
                            upload_url: url
                        }), ed.plugins.upload.upload(file, function(response) {
                            urlCtrl.setLoading(!1);
                            response = response.files || [], response = response.length ? response[0] : {};
                            if (response.file) return urlCtrl.value(response.file), 
                            !0;
                            ed.windowManager.alert({
                                text: "File upload failed!",
                                title: ed.getLang("upload.error", "Upload Error")
                            });
                        }, function(message) {
                            ed.windowManager.alert({
                                text: message,
                                title: ed.getLang("upload.error", "Upload Error")
                            }), urlCtrl.setLoading(!1);
                        });
                    }
                }
            }), urlCtrl = cm.createUrlBox("media_url", args), form.add(urlCtrl), 
            attribs = {
                src: ""
            }, ed.addCommand("mceMedia", function() {
                ed.windowManager.open({
                    title: ed.getLang("mediamanager.desc", ""),
                    items: [ form ],
                    size: "mce-modal-landscape-small",
                    open: function() {
                        var label = ed.getLang("insert", "Insert"), node = ed.selection.getNode(), data = {
                            src: ""
                        };
                        isMedia(node) && (data = mediaApi.getMediaData(), each([ "width", "height", "style", "class", "id", "title" ], function(name) {
                            var val = ed.dom.getAttrib(node, name);
                            "" !== val && ("class" === name && (val = val.replace(/mce-item-(\w+)/gi, "").replace(/\s+/g, " "), 
                            val = tinymce.trim(val)), attribs[name] = val), "width" !== name && "height" !== name || (val = ed.dom.getStyle(node, name) || ed.dom.getAttrib(node, name), 
                            attribs[name] = parseInt(val, 10));
                        })), isPopup(node) && (data.src = ed.dom.getAttrib(node, "href")), 
                        data.src && (label = ed.getLang("update", "Update")), urlCtrl.value(data.src), 
                        window.setTimeout(function() {
                            urlCtrl.focus();
                        }, 10), DOM.setHTML(this.id + "_insert", label);
                    },
                    buttons: [ {
                        title: ed.getLang("cancel", "Cancel"),
                        id: "cancel"
                    }, {
                        title: ed.getLang("insert", "Insert"),
                        id: "insert",
                        onsubmit: function(e) {
                            var data = form.submit(), node = ed.selection.getNode();
                            return Event.cancel(e), !!data.src && (isMedia(node) ? mediaApi.updateMedia(data) : isPopup(node) ? ed.dom.setAttrib(node, "href", data.src) : !mediaApi.isMediaObject(node) && (attribs = tinymce.extend(params.attributes || {}, attribs), 
                            data = tinymce.extend(data, {
                                attributes: attribs
                            }), void getDataAndInsert(ed, data).then(function() {})));
                        },
                        classes: "primary",
                        scope: self
                    } ]
                });
            }));
        }), ed.onInit.add(function() {
            var params = ed.getParam("mediamanager", {});
            ed && ed.plugins.contextmenu && ed.plugins.contextmenu.onContextMenu.add(function(th, m, e) {
                m.add({
                    title: "mediamanager.desc",
                    icon: "mediamanager",
                    cmd: "mceMedia"
                });
            }), !1 !== params.quickmedia && ed.plugins.clipboard && (ed.onGetClipboardContent.add(function(ed, content) {
                var provider, data, html, text = content["text/plain"] || "";
                text && (text = new RegExp("^((http|https)://[-!#$%&'*+\\./0-9=?A-Z^_`a-z{|}~;\\[\\]]+\\.[-!#$%&'*+\\./0-9=?A-Z^_`a-z{|}~;\\[\\]]+)$").exec(text)) && (provider = isSupportedMedia(ed, text = tinymce.trim(text[0]))) && (content["text/plain"] = "", 
                data = getMediaProps(ed, {
                    src: text
                }, provider), html = "\x3c!-- x-tinymce/html --\x3e", html += getMediaHtml(ed, tinymce.extend({
                    "data-mce-clipboard-media": text
                }, data[provider])), content["text/html"] = content["x-tinymce/html"] = html);
            }), ed.onPasteBeforeInsert.add(function(ed, o) {
                var node = ed.dom.create("div", 0, o.content), media = ed.dom.select("[data-mce-clipboard-media]", node);
                media.length && (each(media, function(el) {
                    var value = el.getAttribute("data-mce-clipboard-media"), provider = isSupportedMedia(ed, value);
                    provider && (ed.setProgressState(!0), el = self.getAttributes(params.attributes || {}), 
                    (el = getMediaProps(ed, {
                        src: value,
                        attributes: el
                    }, provider))[provider].url = value, getEmbedData(ed, el, provider).then(function(data) {
                        each(ed.dom.select("[data-mce-clipboard-media]", ed.getBody()), function(el) {
                            el.getAttribute("data-mce-clipboard-media") === value && (ed.selection.select(el), 
                            el.removeAttribute("data-mce-clipboard-media"), insertMedia(ed, data, provider));
                        }), ed.setProgressState(!1);
                    }));
                }), o.content = ed.serializer.serialize(node, {
                    getInner: 1,
                    forced_root_block: ""
                }), ed.dom.remove(node));
            }));
        }), this.createControl = function(n, cm) {
            var params, html, self = this, mediaApi = ed.plugins.media;
            return "mediamanager" !== n ? null : !1 === (params = ed.getParam("mediamanager", {})).quickmedia || !0 === params.basic_dialog ? cm.createButton("mediamanager", {
                title: "mediamanager.desc",
                cmd: "mceMedia"
            }) : (html = '<div class="mceToolbarRow">   <div class="mceToolbarItem mceFlexAuto">       <input type="text" id="' + ed.id + '_media_input" aria-label="' + ed.getLang("mediamanager.src", "URL") + '" />   </div>   <div class="mceToolbarItem">       <button type="button" id="' + ed.id + '_media_submit" class="mceButton mceButtonMedia">           <span class="mceIcon mce_check"></span>       </button>   </div></div>', 
            (n = cm.createSplitButton("mediamanager", {
                title: "mediamanager.desc",
                cmd: "mceMedia",
                max_width: 264,
                onselect: function(node) {
                    "" !== node.value && (node && isMedia(node) ? mediaApi.updateMedia({
                        src: node.value
                    }) : getDataAndInsert(ed, {
                        src: node.value
                    }).then(function() {}));
                }
            })).onRenderMenu.add(function(c, m) {
                var item = m.add({
                    onclick: function(e) {
                        e.preventDefault(), item.setSelected(!1);
                        e = ed.dom.getParent(e.target, ".mceButton");
                        if (e && !e.disabled) {
                            var e = ed.selection.getNode(), value = DOM.getValue(ed.id + "_media_input");
                            if ("" !== value) if (isMedia(e)) mediaApi.updateMedia({
                                src: value
                            }); else {
                                if (mediaApi.isMediaObject(e)) return !1;
                                getDataAndInsert(ed, {
                                    src: value,
                                    attributes: self.getAttributes(params.attributes || {})
                                }).then(function() {});
                            }
                            m.hideMenu();
                        }
                    },
                    html: html
                });
                m.onShowMenu.add(function() {
                    var data = {}, node = ed.selection.getNode();
                    node && isMedia(node) && (data = mediaApi.getMediaData()), window.setTimeout(function() {
                        DOM.get(ed.id + "_media_input").focus();
                    }, 10), DOM.setValue(ed.id + "_media_input", data.src || "");
                });
            }), n);
        }, this.getAttributes = function(data) {
            return data.style && tinymce.is(data.style, "string") && (data.style = ed.dom.parseStyle(data.style)), 
            data.styles && tinymce.is(data.styles, "object") && (data.style = extend(data.styles, data.style || {})), 
            data.style && (data.style = ed.dom.serializeStyle(data.style)), data;
        }, this.insertUploadedFile = function(o) {
            var data = this.getUploadConfig();
            if (data && data.filetypes && new RegExp(".(" + data.filetypes.join("|") + ")$", "i").test(o.name)) return data = this.getAttributes(o.attributes || {}), 
            getDataAndInsert(ed, {
                src: o.file,
                attributes: data
            }).then(function() {}), !0;
            return !1;
        }, this.getUploadURL = function(file) {
            var data = this.getUploadConfig();
            return !!(data && data.filetypes && new RegExp(".(" + data.filetypes.join("|") + ")$", "i").test(file.name)) && ed.getParam("site_url") + "index.php?option=com_jce&task=plugin.display&plugin=mediamanager";
        }, this.getUploadConfig = function() {
            return ed.getParam("mediamanager", {}).upload || {};
        }, this.isSupportedMedia = function(url) {
            return isSupportedMedia(ed, url);
        }, this.getMediaProps = function(data, provider) {
            return getMediaProps(ed, data, provider);
        };
    });
}();

Anon7 - 2022
AnonSec Team