1
0

Neu: DSGVO-Export Hilfe

This commit is contained in:
Akamaru 2025-03-18 21:22:57 +01:00
parent dd51bd50a7
commit f74c22eff8
4 changed files with 656 additions and 0 deletions

197
dsgvo_helper/data.json Normal file
View File

@ -0,0 +1,197 @@
[
{
"dienst": "Amazon",
"url": "https://www.amazon.de/gp/help/customer/display.html?nodeId=GXPU9YPGZP5WMVC3",
"anleitung": "\"Alle ihre Daten anfordern\" auswählen"
},
{
"dienst": "AniList",
"url": "https://anilist.co/settings/account",
"anleitung": "\"GDPR Data Download\" auswählen"
},
{
"dienst": "Apple",
"url": "https://privacy.apple.com/",
"anleitung": "\"Obtain a copy of your data\""
},
{
"dienst": "ChatGPT",
"url": "https://chat.openai.com/",
"anleitung": "E-Mail links unten > Settings"
},
{
"dienst": "Discord",
"url": "https://discord.com/channels/@me",
"anleitung": "Einstellungen > Privatsphäre & Sicherheit > ganz runterscrollen > \"Daten anfordern\""
},
{
"dienst": "DISQUS",
"url": "https://privacyportal-cdn.onetrust.com/dsarwebform/bc2d3301-11a5-4de5-b15e-ce796187a352/9a049fa1-37af-4598-a87a-d0df2e2d904b.html",
"anleitung": ""
},
{
"dienst": "Dropbox",
"url": "https://www.dropbox.com/account/privacy",
"anleitung": ""
},
{
"dienst": "EA",
"url": "https://myaccount.ea.com/cp-ui/downloaddata/index",
"anleitung": ""
},
{
"dienst": "eBay",
"url": "https://ocswf.ebay.de/privacy",
"anleitung": "\"Kopie der personenbezogenen Daten von eBay erhalten\""
},
{
"dienst": "Epic Games",
"url": "https://www.epicgames.com/account/personal?lang=de&productName=epicgames",
"anleitung": "Ganz runter scrollen"
},
{
"dienst": "Facebook",
"url": "https://www.facebook.com/settings?tab=your_facebook_information",
"anleitung": ""
},
{
"dienst": "Gandi.net",
"url": "https://help.gandi.net/en/contact/my-rights",
"anleitung": ""
},
{
"dienst": "GitHub",
"url": "https://github.com/settings/admin",
"anleitung": ""
},
{
"dienst": "Google",
"url": "https://takeout.google.com/",
"anleitung": "Dienste auswählen und Export anfordern"
},
{
"dienst": "IFTTT",
"url": "https://ifttt.com/settings",
"anleitung": ""
},
{
"dienst": "Instagram",
"url": "https://www.instagram.com/download/request/",
"anleitung": ""
},
{
"dienst": "itch.io",
"url": "https://itch.io/user/settings/data-export",
"anleitung": ""
},
{
"dienst": "Joyn",
"url": "https://www.joyn.de/mein-account/datenschutz",
"anleitung": ""
},
{
"dienst": "Kickstarter",
"url": "https://legal.kickstarter.com/policies/en/?modal=take-control",
"anleitung": ""
},
{
"dienst": "Lebensmittel-Sonderposten.de",
"url": "https://www.lebensmittel-sonderposten.de/account",
"anleitung": "Ganz runter scrollen"
},
{
"dienst": "Medium",
"url": "https://medium.com/me/settings/security",
"anleitung": ""
},
{
"dienst": "MEGA",
"url": "https://mega.nz/fm/account/security/personal-data-container",
"anleitung": ""
},
{
"dienst": "Microsoft",
"url": "https://account.microsoft.com/privacy/export",
"anleitung": ""
},
{
"dienst": "MyAnimeList",
"url": "https://myanimelist.net/panel.php?go=export",
"anleitung": "Nur Anime/Manga-Liste"
},
{
"dienst": "MyDealz",
"url": "https://www.mydealz.de/",
"anleitung": "Einstellungen > Profil > Nutzerdaten"
},
{
"dienst": "Netflix",
"url": "https://www.netflix.com/account/getmyinfo",
"anleitung": ""
},
{
"dienst": "Nintendo",
"url": "https://ponypaste.de/?20ffd7e694c842f2=#FCSxEQmfVM6jmoWb5YV3BNmPUivGGdxKrm2qcwxp9NBq",
"anleitung": "E-Mail an privacyinquiry.ncl@nintendo.de"
},
{
"dienst": "PayPal",
"url": "https://www.paypal.com/myaccount/privacy/data/dar",
"anleitung": ""
},
{
"dienst": "Plex",
"url": "https://preferences.plex.tv/",
"anleitung": ""
},
{
"dienst": "Pokémon Club",
"url": "https://club.pokemon.com/de/pokemon-trainer-club/profil-bearbeiten/",
"anleitung": "Ganz unten bei \"Optionen zur Datensicherheit\""
},
{
"dienst": "Reddit",
"url": "https://www.reddit.com/settings/data-request",
"anleitung": "Achtung, nur im \"neuen Reddit\" möglich!"
},
{
"dienst": "Spotify",
"url": "https://www.spotify.com/account/privacy/",
"anleitung": "Account > Datenschutz > Daten herunterladen"
},
{
"dienst": "Telegram",
"url": "",
"anleitung": "Über den Desktop-Client: Einstellungen > Erweitert > ganz unten: \"Daten exportieren\""
},
{
"dienst": "Trustpilot",
"url": "https://de.trustpilot.com/users/data",
"anleitung": ""
},
{
"dienst": "TikTok",
"url": "https://www.tiktok.com/setting/download-your-data",
"anleitung": ""
},
{
"dienst": "Ubisoft",
"url": "https://account.ubisoft.com/de-DE/privacy-settings",
"anleitung": ""
},
{
"dienst": "Waipu.tv",
"url": "https://customer-self-care.waipu.tv/ui/settings",
"anleitung": ""
},
{
"dienst": "WhatsApp",
"url": "",
"anleitung": "Einstellungen > Konto > Konto-Info anfordern"
},
{
"dienst": "X",
"url": "https://x.com/settings/download_your_data",
"anleitung": ""
}
]

454
dsgvo_helper/index.html Normal file
View File

@ -0,0 +1,454 @@
<!DOCTYPE html>
<html lang="de">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>DSGVO-Export Hilfe | PonyWave Tools</title>
<meta name="description" content="Informationen zum Beantragen von DSGVO-Exporten bei verschiedenen Diensten">
<meta property="og:title" content="DSGVO-Export Hilfe">
<meta property="og:description" content="Informationen zum Beantragen von DSGVO-Exporten bei verschiedenen Diensten">
<meta property="og:url" content="https://tools.ponywave.de/dsgvo_helper">
<meta property="og:type" content="website">
<link rel="icon" href="../favicon.png">
<script defer src="https://stats.ponywave.de/script" data-website-id="9ef713d2-adb9-4906-9df5-708d8a8b9131" data-tag="dsgvo_helper"></script>
<style>
:root {
--bg-color: #f5f5f5;
--text-color: #333;
--primary-color: #6200ea;
--secondary-color: #b388ff;
--accent-color: #3700b3;
--card-bg: #ffffff;
--card-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
--table-header: #f0f0f0;
--table-row-odd: #ffffff;
--table-row-even: #f9f9f9;
--table-border: #e0e0e0;
}
[data-theme="dark"] {
--bg-color: #121212;
--text-color: #e0e0e0;
--primary-color: #bb86fc;
--secondary-color: #03dac6;
--accent-color: #cf6679;
--card-bg: #1e1e1e;
--card-shadow: 0 4px 6px rgba(0, 0, 0, 0.3);
--table-header: #2d2d2d;
--table-row-odd: #1e1e1e;
--table-row-even: #252525;
--table-border: #333333;
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
transition: background-color 0.3s, color 0.3s;
}
body {
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
background-color: var(--bg-color);
color: var(--text-color);
line-height: 1.6;
padding: 0;
margin: 0;
}
header {
background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
color: white;
text-align: center;
padding: 2rem 1rem;
margin-bottom: 2rem;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
h1 {
margin-bottom: 0.5rem;
font-size: 2.5rem;
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: 0 1rem;
}
.card {
background-color: var(--card-bg);
border-radius: 8px;
box-shadow: var(--card-shadow);
padding: 2rem;
margin-bottom: 2rem;
}
.intro {
margin-bottom: 1.5rem;
}
/* Tabellenstile */
.table-container {
overflow-x: auto;
}
table {
width: 100%;
border-collapse: collapse;
margin: 1rem 0;
font-size: 0.95rem;
}
th, td {
padding: 12px 15px;
text-align: left;
border-bottom: 1px solid var(--table-border);
}
th {
background-color: var(--table-header);
font-weight: bold;
}
tr:nth-child(odd) {
background-color: var(--table-row-odd);
}
tr:nth-child(even) {
background-color: var(--table-row-even);
}
td a {
color: var(--primary-color);
text-decoration: none;
}
td a:hover {
text-decoration: underline;
}
/* Themenschalter */
.theme-switch {
position: fixed;
top: 20px;
right: 20px;
z-index: 999;
}
.theme-switch button {
background-color: var(--card-bg);
color: var(--text-color);
border: 2px solid var(--primary-color);
border-radius: 30px;
padding: 8px 15px;
cursor: pointer;
font-weight: bold;
display: flex;
align-items: center;
gap: 8px;
transition: all 0.3s ease;
}
.theme-switch button:hover {
background-color: var(--primary-color);
color: white;
}
.theme-icon {
font-size: 18px;
}
/* Footer */
footer {
text-align: center;
padding: 2rem 1rem;
margin-top: 2rem;
background-color: var(--card-bg);
border-top: 1px solid var(--table-border);
}
footer a {
color: var(--primary-color);
text-decoration: none;
}
footer a:hover {
text-decoration: underline;
}
.heart {
color: var(--accent-color);
animation: heartbeat 1.5s infinite;
}
@keyframes heartbeat {
0%, 100% { transform: scale(1); }
50% { transform: scale(1.1); }
}
/* Responsive Design */
@media (max-width: 768px) {
h1 {
font-size: 2rem;
}
.card {
padding: 1.5rem;
}
th, td {
padding: 8px 10px;
font-size: 0.9rem;
}
}
/* Sortierfunktion Stile */
.sortable th {
cursor: pointer;
position: relative;
}
.sortable th::after {
content: '↕';
position: absolute;
right: 8px;
color: #999;
}
.sortable th.asc::after {
content: '↓';
color: var(--primary-color);
}
.sortable th.desc::after {
content: '↑';
color: var(--primary-color);
}
/* Suchfeld Stile */
.search-container {
margin-bottom: 1.5rem;
}
.search-input {
width: 100%;
padding: 10px 15px;
border: 1px solid var(--table-border);
border-radius: 4px;
font-size: 1rem;
background-color: var(--card-bg);
color: var(--text-color);
}
.search-input:focus {
outline: none;
border-color: var(--primary-color);
}
</style>
</head>
<body>
<div class="theme-switch">
<button id="theme-toggle">
<span class="theme-icon">🌙</span>
</button>
</div>
<header>
<div class="container">
<h1>DSGVO-Export Hilfe</h1>
<p>Informationen zum Beantragen von DSGVO-Exporten bei verschiedenen Diensten</p>
</div>
</header>
<div class="container">
<div class="card intro">
<h2>DSGVO-Exports einfach erklärt</h2>
<p>Nach der Datenschutz-Grundverordnung (DSGVO) haben Sie das Recht, eine Kopie Ihrer persönlichen Daten von Unternehmen anzufordern, die diese verarbeiten. Diese Seite hilft Ihnen dabei, Informationen über die Beantragung von DSGVO-Exporten bei verschiedenen Diensten zu finden.</p>
<p>Fehler oder fehlende Dienste können Sie als <a href="https://github.com/Akamaru/issues" target="_blank" rel="noopener noreferrer">Issue auf GitHub</a> melden.</p>
</div>
<div class="card">
<div class="search-container">
<input type="text" id="searchInput" class="search-input" placeholder="Suche nach Diensten, URLs, ..." aria-label="Suche">
</div>
<div class="table-container">
<table id="dsgvoTable" class="sortable">
<thead>
<tr>
<th data-sort="dienst" class="asc">Dienst</th>
<th data-sort="url">URL</th>
<th data-sort="anleitung">Anleitung</th>
</tr>
</thead>
<tbody>
<!-- Tabellendaten werden per JavaScript geladen -->
</tbody>
</table>
</div>
</div>
</div>
<footer>
<div class="container">
<p><a href="https://tools.ponywave.de/">Zurück zur Startseite</a> | &copy; <span id="current-year"></span> Akamaru | Made with <span class="heart">❤️</span> by Claude</p>
</div>
</footer>
<script>
// DOM-Elemente
const themeToggle = document.getElementById('theme-toggle');
const themeIcon = themeToggle.querySelector('.theme-icon');
const table = document.getElementById('dsgvoTable');
const tableBody = table.querySelector('tbody');
const searchInput = document.getElementById('searchInput');
const currentYearSpan = document.getElementById('current-year');
// Aktuelles Jahr im Footer setzen
currentYearSpan.textContent = new Date().getFullYear();
// Theme-Erkennung und Einstellung
function setTheme(isDark) {
document.documentElement.setAttribute('data-theme', isDark ? 'dark' : 'light');
themeIcon.textContent = isDark ? '☀️' : '🌙';
localStorage.setItem('dsgvoHelperTheme', isDark ? 'dark' : 'light');
}
// Bevorzugtes Theme des Nutzers erkennen
function detectPreferredTheme() {
const savedTheme = localStorage.getItem('dsgvoHelperTheme');
if (savedTheme) {
return savedTheme === 'dark';
}
return window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches;
}
// Theme beim Laden setzen
setTheme(detectPreferredTheme());
// Theme-Wechsel
themeToggle.addEventListener('click', () => {
const currentTheme = document.documentElement.getAttribute('data-theme');
setTheme(currentTheme !== 'dark');
});
// Daten aus JSON-Datei laden
let dsgvoData = [];
fetch('data.json')
.then(response => response.json())
.then(data => {
dsgvoData = data;
// Initial nach Dienst sortieren
currentSort = { column: 'dienst', direction: 'asc' };
renderTableData(dsgvoData);
})
.catch(error => {
console.error('Fehler beim Laden der Daten:', error);
// Fallback-Daten anzeigen, falls JSON-Datei nicht geladen werden kann
tableBody.innerHTML = '<tr><td colspan="3" style="text-align: center;">Fehler beim Laden der Daten. Bitte versuchen Sie es später erneut.</td></tr>';
});
// Tabellendaten rendern
function renderTableData(data) {
tableBody.innerHTML = '';
if (data.length === 0) {
const row = document.createElement('tr');
const cell = document.createElement('td');
cell.setAttribute('colspan', '3');
cell.textContent = 'Keine Ergebnisse gefunden';
cell.style.textAlign = 'center';
row.appendChild(cell);
tableBody.appendChild(row);
return;
}
data.forEach(item => {
const row = document.createElement('tr');
const dienstCell = document.createElement('td');
dienstCell.textContent = item.dienst;
row.appendChild(dienstCell);
const urlCell = document.createElement('td');
const urlLink = document.createElement('a');
urlLink.href = item.url;
urlLink.textContent = item.url;
urlLink.target = '_blank';
urlLink.rel = 'noopener noreferrer';
urlCell.appendChild(urlLink);
row.appendChild(urlCell);
const anleitungCell = document.createElement('td');
anleitungCell.textContent = item.anleitung;
row.appendChild(anleitungCell);
tableBody.appendChild(row);
});
}
// Suchfunktion
searchInput.addEventListener('input', function() {
const searchTerm = this.value.toLowerCase();
const filteredData = dsgvoData.filter(item => {
return Object.values(item).some(value =>
value.toLowerCase().includes(searchTerm)
);
});
renderTableData(filteredData);
});
// Sortierfunktion
let currentSort = { column: null, direction: 'asc' };
function sortTable(column) {
const headers = table.querySelectorAll('th');
// Reset alle Header-Klassen
headers.forEach(header => {
header.classList.remove('asc', 'desc');
});
const header = table.querySelector(`th[data-sort="${column}"]`);
// Sortierdirection festlegen
let direction = 'asc';
if (currentSort.column === column && currentSort.direction === 'asc') {
direction = 'desc';
}
// Header-Klasse aktualisieren
header.classList.add(direction);
// Daten sortieren
const sortedData = [...dsgvoData].sort((a, b) => {
const valueA = a[column].toLowerCase();
const valueB = b[column].toLowerCase();
if (valueA < valueB) {
return direction === 'asc' ? -1 : 1;
}
if (valueA > valueB) {
return direction === 'asc' ? 1 : -1;
}
return 0;
});
// Sortierungsstatusvariable aktualisieren
currentSort = { column, direction };
// Neu rendern
renderTableData(sortedData);
}
// Event-Listener für Tabellensortierung
table.querySelectorAll('th').forEach(header => {
const column = header.getAttribute('data-sort');
if (column) {
header.addEventListener('click', () => sortTable(column));
}
});
</script>
</body>
</html>

View File

@ -193,6 +193,10 @@
<h2 class="tool-title">Text Decoder</h2>
<p class="tool-description">Kodiere und dekodiere Text in verschiedene Formate wie Base64, URL, HTML und mehr.</p>
</a>
<a href="https://tools.ponywave.de/dsgvo_helper" class="tool-bubble">
<h2 class="tool-title">DSGVO-Export Hilfe</h2>
<p class="tool-description">Informationen zum Beantragen von DSGVO-Exporten bei verschiedenen Diensten.</p>
</a>
<a href="https://tools.ponywave.de/text_cleaner" class="tool-bubble">
<h2 class="tool-title">Text Cleaner</h2>
<p class="tool-description">Entferne doppelte Zeilen aus einem Text</p>

View File

@ -2,6 +2,7 @@ https://tools.ponywave.de/
https://tools.ponywave.de/text_decoder
https://tools.ponywave.de/sys_info
https://tools.ponywave.de/zeitzonen
https://tools.ponywave.de/dsgvo_helper
https://tools.ponywave.de/text_cleaner
https://tools.ponywave.de/text_sorter
https://tools.ponywave.de/yt_thumb