1. Nachrichten
  2. Forum
    1. Unerledigte Themen
    2. Forenregeln
  3. Spenden
  • Anmelden
  • Registrieren
  • Suche
Alles
  • Alles
  • Artikel
  • Seiten
  • Forum
  • Erweiterte Suche
  1. camp-firefox.de
  2. milupo

Beiträge von milupo

  • suche ersatz für "Focus Last Selected Tab"

    • milupo
    • 24. Mai 2019 um 22:51

    Hinweis zum von captain chaos verlinkten Skript: Dort muss ab Firefox 69 (derzeit Nightly) browser.xul durch browser.xhtml ersetzt werden.

  • Aktuelle Nightly Version - Scripte funktionieren nicht mehr

    • milupo
    • 24. Mai 2019 um 22:27

    Für die, die sich dafür interessieren: Hier ist der LInk zum Bugreport, der die Änderung von createElement in createXULElement beinhaltet:

    https://bugzilla.mozilla.org/show_bug.cgi?id=1551320

  • Ungeladene Tabs werden beim Anklicken nach Firefox-Start manchmal aktualisiert, manchmal nicht

    • milupo
    • 24. Mai 2019 um 15:12
    Zitat von testerer


    Für angeheftete Tabs hatte mir aborix ein Script erstellt:

    https://www.camp-firefox.de/forum/viewtopi…105227#p1105227


    Nur mal so geraten, also teste bitte:

    Entferne im Skript in der while-Zeile && tabs.pinned nebst Leerzeichen aus der Klammer, sodass dort nur (tab) steht. Vielleicht klappt es.

  • Aktuelle Nightly Version - Scripte funktionieren nicht mehr

    • milupo
    • 24. Mai 2019 um 10:26

    Für die, die das Skript ExtensionOptionsMenu.uc.js verwenden, hier die angepasste Variante:

    CSS
    // ==UserScript==
    // @name          ExtensionOptionsMenu.uc.js
    // @description   Symbolleistenschaltfläche zur Add-ons-Verwaltung
    // @include       main
    // @charset       UTF-8
    // @version       3.1.6 Anpassung an Firefox 65 von aborix
    // @version       3.1.5 Deaktivieren der Erweiterungen mit Rechtsklick repariert von aborix
    // @version       3.1.4 Anpassung an Firefox 61+ von aborix
    // @version       3.1.2 Auf Grund von Problemen, wurde die Fensteranzeige der Erweiterungseinstellungen entfernt
    // @version       3.1.1 Öffnen des Erweiterungen-Ordners funktionierte nicht
    // @version       3.1.0 Unterstützt Fx 57 oder später. System Add-ons, konnten nicht deaktiviert werden
    // @version       3.0.10 Fx52以降で右クリック時に出る既存メニューを出ないように修正 (2ch該当スレより拝借)
    // @version       3.0.9 表示したくないアドオンを設定できるように(コメントアウト内の説明参照)、選択アドオンのidをAlt+左クリックでコピーできるように
    // @version       3.0.8 再起動に関する修正
    // @version       3.0.7 メニューにアイコンが出ていなかったのを修正
    // @version       3.0.6 互換性を考慮して書き換え デフォルトでボタンはカスタマイズパレットに配置
    // @version       3.0.5 ツールチップに操作法を表示するように コメントアウト内CSSを更新
    // @version       3.0.4 一部アドオンの設定画面が機能していなかったのを修正、メニューパネル内でドロップマーカーが出ないようにするCSSを追記
    // @version       3.0.3 ボタンをツールバーパレットから自由に配置できるように変更(メニューパネル内への配置にも対応 ※コメントアウト内のcssを追加するように)
    // ==/UserScript==
    /*
    
    
    Schaltflächensymbol:
    Linksklick: Erweiterungsliste anzeigen
    Mittelklick: Firefox neustarten
    Rechtsklick: Add-ons-Manager öffnen
    
    
    Erweiterungen:
    Linksklick: Erweiterungseinstellungen öffnen, wenn vorhanden
    Mittelklick: Internetseite der Erweiterung öffnen
    Rechtsklick: Erweiterungen aktivieren/deaktivieren
    Strg + Linksklick: Erweiterungsordner öffnen
    Strg + Mittelklick: Erweiterungs-ID in Zwischenablage kopieren
    Strg + Rechtsklick: Erweiterung entfernen / Deinstallation rückgängig machen
    *Nach Firefox-Neustart kann dies nicht mehr Rückgängig gemacht werden.
    
    
    Bei "blackListArray" in Zeile 50 können Add-ons, die nicht im Menü angezeigt werden sollen,
    mit der ID des Add-ons eingegeben werden. Sie können die ID mit Strg + Mittelklick kopieren.
    Einige Systemerweiterungen werden standardmäßig hinzugefügt.
    
    
    */
    
    
    'use strict';
    
    
    var EOM = {
    
    
    	showVersion:  true,    // Versionsinfo anzeigen (true = Versionsinfo anzeigen, false = nicht anzeigen)
    	showAll:      true,    // Alles anzeigen, auch bei Erweiterungen ohne Einstellungen
    	showDisabled: true,    // deaktivierte Erweiterungen anzeigen (deaktivierte Add-ons anzeigen)
    	autoRestart:  false,   // Firefox nach Installation bzw. Deinstallation automatisch neu starten
    	iconURL:      '',
    
    
    	blackListArray: [
    		"clicktoplay-rollout@mozilla.org",
    		"firefox@getpocket.com",
    		"screenshots@mozilla.org",
    		"followonsearch@mozilla.com",
    		"formautofill@mozilla.org",
    		"onboarding@mozilla.org",
    		"shield-recipe-client@mozilla.org",
    		"webcompat@mozilla.org",
    		"activity-stream@mozilla.org",
    		"presentation@mozilla.org",
    		"aushelper@mozilla.org",
    		"webcompat-reporter@mozilla.org",
    		"e10srollout@mozilla.org"
    	],
    
    
    	sort: {
    		enabled: 0,
    		disabled: 1
    			// 0, 0 - In alphabetischer Reihenfolge
    			// 0, 1 - Reihenfolge wie im Add-On-Manager
    	},
    
    
    	init: function() {
    		var style = `
    			@namespace url('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul');
    			#eom-button {
    				list-style-image: url('');
    			}
    
    
    			.addon-disabled > .menu-iconic-left { filter: grayscale(1); }
    			.addon-disabled label { color: Gray !important; }
    			.addon-uninstall label { font-weight: bold !important; }
    			.addon-uninstall label:after { content: '-'; }
    
    
    			#eom-button[cui-areatype="menu-panel"],
    			toolbarpaletteitem[place="palette"] > #eom-button {
    				list-style-image: url('');
    			}
    		`;
    
    
    		style = style.replace(/\s+/g, " ");
    		var sspi = document.createProcessingInstruction(
    			'xml-stylesheet',
    			'type="text/css" href="data:text/css,' + encodeURIComponent(style) + '"'
    		);
    		document.insertBefore(sspi, document.documentElement);
    		sspi.getAttribute = function(name) {
    			return document.documentElement.getAttribute(name);
    		};
    
    
    		const XUL_NS = 'http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul';
    
    
    		try {
    			CustomizableUI.createWidget({
    				id: 'eom-button',
    				type: 'custom',
    				onBuild: function(aDocument) {
    					var toolbaritem = aDocument.createElementNS(XUL_NS, 'toolbarbutton');
    					var attributes = {
    						id: 'eom-button',
    						class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    						type: 'menu',
    						label: 'Extension Options Menu',
    						tooltiptext: 'Extension Options Menu\n\nLinksklick: Erweiterungsliste anzeigen\nMittelklick: Firefox neu starten\nRechtsklick: Add-ons-Manager öffnen',
    						oncontextmenu: 'return false'
    					};
    					for (var a in attributes) {
    						toolbaritem.setAttribute(a, attributes[a]);
    					};
    					return toolbaritem;
    				}
    			});
    		} catch(e) { };
    
    
    		var btn = document.getElementById('eom-button');
    		btn.addEventListener('click', EOM.iconClick);
    
    
    		var mp = btn.appendChild(document.createElementNS(XUL_NS, 'menupopup'));
    		mp.setAttribute('id', 'eom-button-popup');
    		mp.setAttribute('onclick', 'event.preventDefault(); event.stopPropagation();');
    		mp.addEventListener('popupshowing', (event) => EOM.populateMenu(event));
    
    
    		function copyList() {
    			AddonManager.getAddonsByTypes(["extension"]).then(function(extensions) {
    				Cc['@mozilla.org/widget/clipboardhelper;1'].getService(Ci.nsIClipboardHelper).copyString(extensions.map(function(item, id) {
    					return (id + 1 + ". " + item.name + " [" + item.version + "]" + "\nID:" + item.id);
    				}).join("\n"));
    			});
    
    
    			var alertsService = Cc['@mozilla.org/alerts-service;1'].getService(Ci.nsIAlertsService);
    			alertsService.showAlertNotification(null, null, "Add-ons-Liste in die Zwischenablage kopiert.", null, null, null, "copyList");
    			setTimeout(function() {
    				alertsService.closeAlert("copyList");
    			}, 5000);
    		};
    
    
    		var mMenus = [
    			{
    				alabel: 'Firefox neu starten',
    				label: 'Script-Cache löschen',
    				image: "",
    				oncommand: "Services.appinfo.invalidateCachesOnRestart() || BrowserUtils.restartApplication();",
    				style: "min-width: 260px;"
    			},
    			{
    				label: "Erweiterungsordner öffnen",
    				image: "",
    				oncommand: "FileUtils.getFile('ProfD', ['extensions']).reveal();"
    			},
    			{
    				label: "Add-ons-Liste in die Zwischenablage kopieren",
    				image: "",
    				oncommand: '(' + copyList.toString() + ')()'
    			}
    		];
    
    
    		var menugroup = mp.appendChild($C("menugroup", {
    			id: "eom-menugroup"
    		}));
    		mp.appendChild($C('menuseparator'));
    
    
    		for (let i = 0, menu; menu = mMenus[i]; i++) {
    			menugroup.appendChild($C("menuitem", {
    				label: menu.alabel,
    				tooltiptext: menu.label,
    				image: menu.image,
    				class: "menuitem-iconic",
    				oncommand: menu.oncommand,
    				style: menu.style || "max-width: 10px;"
    			}));
    		};
    
    
    		function $C(name, attr) {
    			var el = document.createXULElement(name);
    			if (attr) {
    				Object.keys(attr).forEach(function(n) {
    					el.setAttribute(n, attr[n]);
    				});
    			};
    			return el;
    		};
    	},
    
    
    	populateMenu: function(event) {
    		var prevState;
    		var showItem = true;
    
    
    		var popup = event.target;
    		if (popup !== event.currentTarget) {
    			return;
    		}
    
    
    		while (popup.childElementCount > 2) {
    			popup.removeChild(popup.lastChild);
    		}
    
    
    		var addons;
    		AddonManager.getAddonsByTypes(['extension']).then(function(aAddons) {
    			addons = aAddons;
    		});
    
    
    		var thread = Services.tm.mainThread;
    		while (addons === void 0) {
    			thread.processNextEvent(true);
    		}
    
    
    		addons.sort((a, b) => {
    			var ka = this.key(a);
    			var kb = this.key(b);
    			return (ka < kb) ? -1 : 1;
    		}).forEach((addon) => {
    			if (!addon.appDisabled && ((addon.isActive && addon.optionsURL)
    				 || ((addon.userDisabled && this.showDisabled)
    				 || (!addon.userDisabled && this.showAll)))) {
    				var state = addon.isActive;
    				if (this.sort.disabled === 1 && (prevState && state !== prevState)) {
    					popup.appendChild(document.createXULElement('menuseparator'));
    				}
    				prevState = state;
    
    
    				var mi = document.createXULElement('menuitem');
    				var label = addon.name;
    				if (this.showVersion) label = label += ' ' + '[' + addon.version + ']';
    				mi.setAttribute('label', label);
    				mi.setAttribute('class', 'menuitem-iconic');
    				mi.setAttribute('tooltiptext', 'ID: ' + addon.id + '\nGröße: ' + Math.floor(addon.size / 1024) + ' KB' + '\n\nLinksklick = Add-on-Einstellungen öffnen\nMittelklick = Add-on-Homepage öffnen\nRechtsklick = Add-on aktivieren / deaktivieren\nStrg + Linksklick = Add-on-Ordner öffnen\nStrg + Mittelklick = Add-on ID kopieren\nStrg + Rechtsklick = Add-on deinstallieren *\n* Diese Aktion kann nicht rückgängig gemacht werden.');
    				var icon = addon.iconURL || addon.iconURL64 || this.iconURL || '';
    				mi.setAttribute('image', icon);
    				mi.addEventListener('click', (event) => this.handleClick(event));
    				mi._Addon = addon;
    
    
    				if (!addon.optionsURL && addon.isActive) {
    					mi.setAttribute('style', 'color: Gray');
    				}
    				if (!addon.operationsRequiringRestart) {
    					mi.setAttribute('style', 'color: Green');
    				}
    
    
    				this.setDisable(mi, addon.userDisabled);
    				this.setUninstall(mi, this.isPending(addon));
    
    
    				if (this.blackListArray) {
    					for (var i = 0; i < this.blackListArray.length; i++) {
    						if (this.blackListArray[i] == addon.id.toLowerCase()) {
    							showItem = false;
    							break;
    						} else {
    							showItem = true;
    						}
    					}
    				}
    				if (showItem) popup.appendChild(mi);
    			}
    		});
    	},
    
    
    	iconClick: function(event) {
    		if (event.target !== event.currentTarget) {
    			return;
    		}
    		if (event.button === 1) {
    			EOM.restart();
    		} else if (event.button === 2) {
    			BrowserOpenAddonsMgr('addons://list/extension');
    		}
    	},
    
    
    	handleClick: function(event) {
    		var mi = event.target;
    		if (mi !== event.currentTarget) {
    			return;
    		}
    		if (!('_Addon' in mi)) {
    			return;
    		}
    
    
    		var addon = mi._Addon;
    		var pending = this.isPending(addon);
    		var hasMdf = event.ctrlKey || event.shiftKey || event.altKey || event.metaKey;
    
    
    		switch (event.button) {
    			case 0:
    				if (addon.optionsURL && !hasMdf) {
    					this.openAddonOptions(addon);
    				} else if (event.ctrlKey) {
    					this.browseDir(addon);
    				}
    				break;
    			case 1:
    				if (addon.homepageURL && !hasMdf) {
    					openURL(addon.homepageURL);
    				} else if (event.ctrlKey) {
    					Cc['@mozilla.org/widget/clipboardhelper;1'].getService(Ci.nsIClipboardHelper).copyString(addon.id);
    				}
    				break;
    			case 2:
    				if (!hasMdf) {
    					var stateDisabled = !addon.userDisabled;
    					stateDisabled ? addon.disable() : addon.enable();
    					this.setDisable(mi, stateDisabled);
    					if (addon.operationsRequiringRestart && this.autoRestart) {
    						EOM.restart();
    					}
    				} else if (event.ctrlKey) {
    					if (pending) {
    						addon.cancelUninstall();
    					} else {
    						addon.uninstall();
    					}
    					this.setUninstall(mi, pending);
    				}
    				break;
    		}
    	},
    
    
    	setDisable: function(mi, dis) {
    		var cls = mi.classList;
    		dis ? cls.add('addon-disabled') : cls.remove('addon-disabled');
    	},
    
    
    	setUninstall: function(mi, uninst) {
    		var cls = mi.classList;
    		uninst ? cls.add('addon-uninstall') : cls.remove('addon-uninstall');
    	},
    
    
    	isPending: function(addon) {
    		return addon.pendingOperations & AddonManager.PENDING_UNINSTALL;
    	},
    
    
    	openAddonOptions: function(addon) {
    		var optionsURL = addon.optionsURL || '';
    		if (!addon.isActive || !optionsURL) {
    			return;
    		}
    		switch (Number(addon.optionsType)) {
    			case 3:
    				"switchToTabHavingURI" in window ? switchToTabHavingURI(optionsURL, true) : openTab("contentTab", { contentPage: optionsURL });
    			break;
    			default:
    				openDialog(optionsURL, addon.name, 'chrome,titlebar,toolbar,resizable,scrollbars,centerscreen,dialog=no,modal=no');
    		}
    	},
    
    
    	browseDir: function(addon) {
    		var dir = Services.dirsvc.get('ProfD', Ci.nsIFile);
    		var nsLocalFile = Components.Constructor('@mozilla.org/file/local;1', 'nsIFile', 'initWithPath');
    		dir.append('extensions');
    		dir.append(addon.id);
    		var fileOrDir = dir.path + (dir.exists() ? '' : '.xpi');
    		try {
    			new nsLocalFile(fileOrDir).reveal();
    		} catch (e) {
    			var addonDir = /.xpi$/.test(fileOrDir) ? dir.parent : dir;
    			try {
    				if (addonDir.exists()) {
    					addonDir.launch();
    				}
    			} catch (e) {
    				var uri = Services.io.newFileURI(addonDir);
    				var protSvc = Cc['@mozilla.org/uriloader/external-protocol-service;1'].getService(Ci.nsIExternalProtocolService);
    				protSvc.loadUrl(uri);
    			}
    		}
    	},
    
    
    	key: function(addon) {
    		var sort = this.sort;
    		var sortPos = addon.isActive ? sort.enabled : sort.disabled;
    		return sortPos + '\n' + addon.name.toLowerCase();
    	},
    
    
    	restart: BrowserUtils.restartApplication
    
    
    };
    
    
    if (location == 'chrome://browser/content/browser.xhtml')
    	EOM.init();
    Alles anzeigen
  • Aktuelle Nightly Version - Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 23:12
    Zitat von Abendstern2010


    Ihr lieben habt recht vielen Dank für eure Mühe ,jetzt ist mein Fuchs wieder schick :klasse:


    Gern geschehen.

    Zitat

    In dem ein oder anderem Code müssen auch diese Anpassungen vorgenommen werden,ist mir heute mal mit
    so aufgefallen.


    Dem ist so. Aber alles der Reihe nach.

  • Firefox 67: Fehler in deutscher Übersetzung

    • milupo
    • 23. Mai 2019 um 20:59
    Zitat von Speravir


    Lies noch einmal meine Nachricht direkt über dir. :)


    Ach, habe ich überlesen. Macht nichts. Doppelt hält besser. :)

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 20:56
    Zitat von robotest


    Leute! Esfunktioniert alles wieder! Ich bin so dumm, ich habe vergessen diese Dateien zu kopieren: config.js, userChromeJS, config-prefs.js. Jetzt ist alles wieder gut! ich entschuldige mich vielmals für die entstandenen Unannehmlichkeiten! Ganz herzlichen Dank für die Hilfe! :D


    Hat sich mit meinem nachfolgenden Beitrag überschnitten.

    Zum Helfen snd wir da. Alles nur menschlich. Also: gern geschehen. :)

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 20:47
    Zitat von robotest


    Die liegen schon alle da wo sie hingehören, ich habe FFPortable, also brauchte ich immer nur neue Firefox Dateien in den Ordner "Firefox Portable\App\Firefox" zu kopieren, bis jetzt funktioniert alles einwandfrei


    Das solltest du sicherheitshalber immer dazu erwähnen. Es könnte Unterschiede geben. Und was heißt hier "bis jetzt funktioniert alles einwandfrei". Also funktionieren die Skripte doch?

  • FF 67: alle Tabs reagieren nicht mehr (Meldung Tabsabsturz)

    • milupo
    • 23. Mai 2019 um 20:44
    Zitat von mr.b.


    Ergänzung: die von dir verlinkte Anleitung ist anders als die, die hier geschrieben steht (von ardiman:(
    https://github.com/ardiman/userChrome.js und nach der ich mich gerichtet hatte.
    Aborix schreibt u.a.: " Die userChromeJS.js im Installationsordner kommt weg und es kommt ein Ordner userChromeJS hinzu"
    Und von dem ist |bei ardiman keine Rede.
    Ich habe auch diesen Ordner nicht auf meiner Festplatte und trotzdem funktionieren die Skripte jetzt.


    Die Seite von ardiman ist veraltet. Seit Firefox 57 arbeiten wir mit dem Ordner. Wir als Helfer müssen eine einheitliche Linie fahren, wir können Neulingen in dieser Thematik nicht erzählen, das kannst du so machen aber auch noch so machen. Die sind dann nur verwirrt. Von uns wird die alte Methode nicht mehr unterstützt. Du hast Glück, dass sie noch funktioniert. Du kannst gerne dein eigenes Süppchen kochen, wenn dir die Zeit zu schade ist - und so lange dauert das nicht - alles nach der neuen Methode einzurichten.

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 20:26

    Lies dir mal auf dieser Seite die Beschreibung durch. Du kannst von hier auch die Datei firefox-anpassungen.zip herunterladen.

    https://github.com/Endor8/userChr…ster/userChrome

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 20:24
    Zitat von robotest


    Muss man alles neu machen? Wusste ich nicht. :shock:


    Na klar, oder hast du gedacht die Dateien fliegen von alleine ins richtige Verzeichnis? Was hast du denn nun neu gemacht: Profil, Installationsverzeichns oder beides?

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 20:20

    Die ist in Ordnung.

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 20:17
    Zitat von 2002Andreas


    Hattest du denn alle Vorbereitungen getroffen um Scripte nutzen zu können?


    Ja, hast du für Fx 69 ein neues Installationsverzeichbnis oder neues Profil angelegt oder beides? Dann musst du die entsprechenden Vorbereitungen noch einmal treffen.

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 20:14
    Zitat von robotest


    Mehr habe ich nicht, nur userChrome funktioniert, das hier, nach änderung funktioniert wieder:


    Du meinst die userChrome.css? Die hat mit Skripten nichts zu tun. Du brauchst die userChrome.js Hast du CSS-Dateien, die zu den 6 Skripten gehören?

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 20:11

    Skript 5 funktioniert ebenfalls. Das skript legt den Menüeintrag "Neustarten" im Menü "Datei" an.

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 20:05

    Skript 4 funktioniert hier ebenfalls. Es wird der Lesezeichenmenü-Ordner angezeigt.

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 19:55
    Zitat von robotest


    Danke milupo, sieht jetzt so aus, und funktionieren leider nicht. Oder mache ich was falsch? Im FF 68.0b2 funktioniert alles. :(


    Im ersten Skript hast du jetzt einen Fehler eingebaut. Du hattest ursprünglich schon browser.xul durch browser.xhtml ersetzt. Das hast du jetzt aber fehlerhafterweise wieder rückgängig gemacht. browser.xhtml ist richtig.

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 19:25

    Skript 6: Ersetze browser.xul durch browser.xhtml

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 19:23

    Skript 5: Ersetze createElement durch createXULElement.

  • 69.0a1- ein Paar Scripte funktionieren nicht mehr

    • milupo
    • 23. Mai 2019 um 19:20

    ZU den Skripten 2 und 3 kann ich nichts sagen. Diese haben - soweit ich das sehen kann - keine Beziehung zu unseren derzeitigen Problemursachen.

    Skript 4: Ersetze browser.xul durch browser.xhtml.

Unterstütze uns!

Jährlich (2025)

101,9 %

101,9% (662,48 von 650 EUR)

Jetzt spenden
  1. Kontakt
  2. Datenschutz
  3. Impressum
Community-Software: WoltLab Suite™
Mastodon