rentgen/components/toolbar/toolbar.tsx

285 lines
12 KiB
TypeScript
Raw Normal View History

2022-04-15 13:58:29 +02:00
import React, { Fragment } from 'react';
import ReactDOM from 'react-dom';
import { useEmitter } from '../../util';
import { getMemory } from '../../memory';
2021-10-03 09:03:56 +02:00
async function getCurrentTab() {
const [tab] = await browser.tabs.query({
active: true,
windowId: browser.windows.WINDOW_ID_CURRENT,
});
return tab;
2021-10-03 09:03:56 +02:00
}
import './../../styles/global.scss';
import './toolbar.scss';
function isDomainHighlySuspicious(domain: string): boolean {
return (
domain.includes('facebook') ||
domain.includes('twitter') ||
domain.includes('linkedin') ||
false
);
}
const Toolbar = () => {
const [origin, setOrigin] = React.useState<string | null>(null);
2022-07-09 15:28:37 +02:00
const [eventCounts] = useEmitter(getMemory());
2022-04-15 10:34:29 +02:00
const [cookieDomainCopy, setCookieDomainCopy] = React.useState<string | null>(null);
2022-07-09 15:28:37 +02:00
const [_, setMarksOccurrence] = React.useState<boolean>(false);
2022-04-15 10:34:29 +02:00
const [exposedOriginDomainCopy, setExposedOriginDomainCopy] = React.useState<string | null>(
null
);
2021-11-06 21:48:25 +01:00
2022-06-29 19:31:20 +02:00
const first_sentence_cookie = 'Strona dokonała zapisu i odczytu plików Cookie dla domen ';
const first_sentence_history =
'Część informacji o Twojej historii przeglądania została wysłana do ';
React.useEffect(() => {
const listener = async () => {
const tab = await getCurrentTab();
2022-04-22 13:00:02 +02:00
2022-07-09 15:51:34 +02:00
if (tab !== undefined && tab.url) {
2022-04-22 13:00:02 +02:00
const url = new URL(tab.url);
if (url.origin.startsWith('moz-extension')) {
return;
}
setOrigin(url.origin);
} else {
console.warn('Out of the tab scope');
}
};
browser.tabs.onUpdated.addListener(listener);
listener();
return () => {
browser.tabs.onUpdated.removeListener(listener);
};
});
2021-11-06 21:48:25 +01:00
React.useEffect(() => {
2022-07-09 15:51:34 +02:00
if (!origin) return;
2022-04-15 10:34:29 +02:00
const exposedOriginDomains = Object.values(getMemory().getClustersForOrigin(origin))
.filter((cluster) => cluster.exposesOrigin())
.sort((cluster1, cluster2) =>
isDomainHighlySuspicious(cluster1.id)
? -1
: isDomainHighlySuspicious(cluster2.id)
? 1
: 0
)
2022-04-15 10:34:29 +02:00
.map((cluster) => cluster.id);
setExposedOriginDomainCopy('');
switch (exposedOriginDomains.length) {
case 0:
2022-07-09 15:28:37 +02:00
break;
2022-04-15 10:34:29 +02:00
case 1:
2022-07-09 15:28:37 +02:00
setExposedOriginDomainCopy(`${exposedOriginDomains[0]}.`);
break;
2022-04-15 10:34:29 +02:00
case 2:
2022-07-09 15:28:37 +02:00
setExposedOriginDomainCopy(
2022-06-29 19:31:20 +02:00
`${exposedOriginDomains[0]} oraz ${exposedOriginDomains[1]}.`
2022-04-15 10:34:29 +02:00
);
2022-07-09 15:28:37 +02:00
break;
2022-04-15 10:34:29 +02:00
case 3:
2022-07-09 15:28:37 +02:00
setExposedOriginDomainCopy(
2022-06-29 19:31:20 +02:00
`${exposedOriginDomains[0]}, ${exposedOriginDomains[1]} oraz ${exposedOriginDomains[2]}.`
2022-04-15 10:34:29 +02:00
);
2022-07-09 15:28:37 +02:00
break;
2022-04-15 10:34:29 +02:00
default:
2022-07-09 15:28:37 +02:00
setExposedOriginDomainCopy(
2022-06-29 19:31:20 +02:00
`${exposedOriginDomains[0]}, ${exposedOriginDomains[1]} (i ${
exposedOriginDomains.length - 2 < 2 ? 2 : exposedOriginDomains.length - 2
} innych).`
2022-04-15 10:34:29 +02:00
);
2022-07-09 15:28:37 +02:00
break;
}
2022-04-15 10:34:29 +02:00
}, [eventCounts['*'], origin]);
2022-04-11 13:52:45 +02:00
2022-04-15 10:34:29 +02:00
React.useEffect(() => {
2022-07-09 15:51:34 +02:00
if (!origin) return;
2022-04-15 10:34:29 +02:00
const cookieDomains = Object.values(getMemory().getClustersForOrigin(origin))
.filter((cluster) => cluster.hasCookies())
.sort((cluster1, cluster2) =>
isDomainHighlySuspicious(cluster1.id)
? -1
: isDomainHighlySuspicious(cluster2.id)
? 1
: 0
)
2022-04-15 10:34:29 +02:00
.map((cluster) => cluster.id);
2022-04-15 13:58:29 +02:00
setCookieDomainCopy('');
2022-04-15 10:34:29 +02:00
switch (cookieDomains.length) {
case 0:
2022-07-09 15:51:34 +02:00
break;
2022-04-15 10:34:29 +02:00
case 1:
2022-07-09 15:28:37 +02:00
setCookieDomainCopy(`${cookieDomains[0]}.`);
break;
2022-04-15 10:34:29 +02:00
case 2:
2022-07-09 15:28:37 +02:00
setCookieDomainCopy(`${cookieDomains[0]} oraz ${cookieDomains[1]}.`);
break;
2022-04-15 10:34:29 +02:00
case 3:
2022-07-09 15:28:37 +02:00
setCookieDomainCopy(
2022-06-29 19:31:20 +02:00
`${cookieDomains[0]}, ${cookieDomains[1]} oraz ${cookieDomains[2]}.`
2022-04-15 10:34:29 +02:00
);
2022-07-09 15:28:37 +02:00
break;
2022-04-15 10:34:29 +02:00
default:
2022-07-09 15:28:37 +02:00
setCookieDomainCopy(
2022-06-29 19:31:20 +02:00
`${cookieDomains[0]}, ${cookieDomains[1]} (i ${
cookieDomains.length - 2 < 2 ? 2 : cookieDomains.length - 2
} innych).`
2022-04-15 10:34:29 +02:00
);
2022-07-09 15:28:37 +02:00
break;
2022-04-15 10:34:29 +02:00
}
}, [eventCounts['*'], origin]);
2022-01-19 14:12:52 +01:00
2022-04-24 22:11:33 +02:00
React.useEffect(() => {
2022-07-09 15:28:37 +02:00
if (!origin) return;
2022-04-24 22:11:33 +02:00
for (const cluster of Object.values(getMemory().getClustersForOrigin(origin))) {
if (cluster.hasMarks()) {
return setMarksOccurrence(true);
}
}
return setMarksOccurrence(false);
}, [eventCounts['*']]);
function autoMark() {
2022-07-09 15:28:37 +02:00
if (!origin) return;
2022-04-24 22:11:33 +02:00
for (const cluster of Object.values(getMemory().getClustersForOrigin(origin))) {
cluster.autoMark();
}
return setMarksOccurrence(true);
}
return (
<div className="toolbar">
2022-07-09 18:05:56 +02:00
<header className={origin ? 'header' : 'header header--no-page'}>
2022-04-13 13:57:31 +02:00
<img src="../../assets/icon-addon.svg" height={32}></img>
2022-04-15 10:34:29 +02:00
<div className="webpage-metadata">
{origin ? (
<>
<span>Analiza strony</span>
2022-02-02 10:33:09 +01:00
<span className="webpage-metadata--hyperlink">{origin}</span>
</>
2022-01-29 21:16:53 +01:00
) : (
<span>Przejdź do wybranej strony internetowej</span>
2022-01-29 21:16:53 +01:00
)}
</div>
2022-07-06 19:03:15 +02:00
{origin ? (
<a href="https://internet-czas-dzialac.pl">
2022-02-02 10:33:09 +01:00
<img src="/assets/icons/info_circle_outline.svg" width="20" height="20" />
</a>
2022-07-06 19:03:15 +02:00
) : null}
</header>
2022-01-29 21:16:53 +01:00
2022-07-09 18:05:56 +02:00
{origin ? (
2022-04-15 10:34:29 +02:00
<Fragment>
2022-07-09 18:05:56 +02:00
{' '}
<section className="summary">
<div className="counters-wrapper">
<div className="counters">
<div className="counter counter--cookies">
<img
src="/assets/icons/cookie.svg#color"
width="24"
height="24"
/>
<span data-event={`${eventCounts['*']}`}>
{
Object.values(
getMemory().getClustersForOrigin(origin)
).filter((cluster) => cluster.hasCookies()).length
}
</span>
</div>
<div className="counter counter--browser-history">
<img
src="/assets/icons/warning.svg#color"
width="24"
height="24"
/>
<span data-event={`${eventCounts['*']}`}>
{
Object.values(
getMemory().getClustersForOrigin(origin)
).filter((cluster) => cluster.exposesOrigin()).length
}
</span>
</div>
</div>
<div className="big-counter" data-event={`${eventCounts['*']}`}>
{Object.values(getMemory().getClustersForOrigin(origin)).length}
</div>
</div>
<span className="notice">Liczba wykrytych domen podmiotów trzecich</span>
2022-04-15 10:34:29 +02:00
</section>
2022-07-09 18:05:56 +02:00
<section className="details">
{cookieDomainCopy ? (
<p
data-event={`${eventCounts['*']}`}
title={Object.values(getMemory().getClustersForOrigin(origin))
.filter((cluster) => cluster.hasCookies())
.map((domain) => domain.id)
.join(', ')}
>
{first_sentence_cookie}
<strong>{cookieDomainCopy}</strong>
</p>
) : null}
{exposedOriginDomainCopy ? (
<p
data-event={`${eventCounts['*']}`}
title={Object.values(getMemory().getClustersForOrigin(origin))
.filter((cluster) => cluster.exposesOrigin())
.map((domain) => domain.id)
.join(', ')}
>
{first_sentence_history}
<strong>{exposedOriginDomainCopy}</strong>
</p>
) : null}
2022-06-29 19:31:20 +02:00
</section>
2022-07-09 18:05:56 +02:00
{exposedOriginDomainCopy || cookieDomainCopy ? (
<Fragment>
<section className="about">
<p>
Takie przetwarzanie danych może być niezgodne z prawem. Przejdź
do analizy aby pomóc ustalić, czy ta strona nie narusza RODO lub
ustawy Prawo Telekomunikacyjne.
2022-07-09 18:05:56 +02:00
</p>
</section>
<section className="actions">
<button
className="button button--report"
onClick={() => {
autoMark();
window.open(
`/components/sidebar/sidebar.html?origin=${origin}`,
'new_tab'
);
window.close(); // close toolbar popup
}}
>
Przejdź do analizy
</button>
</section>
</Fragment>
) : (
<Fragment>
<section className="about about__no-errors">
<p>Nie znaleziono problemów na tej stronie.</p>
</section>
</Fragment>
)}
2022-06-29 19:31:20 +02:00
</Fragment>
2022-07-09 18:05:56 +02:00
) : null}
</div>
);
2021-10-03 09:03:56 +02:00
};
ReactDOM.render(<Toolbar />, document.getElementById('toolbar'));