Updates job documentation

This commit is contained in:
Alicia Sykes 2023-07-08 19:01:32 +01:00
parent 397609e7bc
commit 46f8144a0f
6 changed files with 397 additions and 33 deletions

349
README.md
View File

@ -12,37 +12,350 @@
--- ---
## About ## About
Get an insight into the inner-workings of a given website: uncover potential attack vectors, analyse server architecture, view security configurations, and learn what technologies a site is using.
_Get info on a websites SSL certs, domain, headers, cookies, DNS records, technologies used, performance, hostnames, crawl rules, server info and more_ Currently the dashboard will show: IP info, SSL chain, DNS records, cookies, headers, domain info, search crawl rules, page map, server location, redirect ledger, open ports, traceroute, DNS security extensions, site performance, trackers, associated hostnames, carbon footprint. Stay tuned, as I'll add more soon!
#### Screenshot The aim is to help you easily understand, optimize and secure your website.
### Screenshot
[![Screenshot](https://i.ibb.co/9ZcMVbP/web-check-screenshot3.png)](https://web-check.as93.net/) [![Screenshot](https://i.ibb.co/9ZcMVbP/web-check-screenshot3.png)](https://web-check.as93.net/)
#### Live Demo ### Live Demo
A hosted version can be accessed at: **[web-check.as93.net](https://web-check.as93.net)** A hosted version can be accessed at: **[web-check.as93.net](https://web-check.as93.net)**
#### Mirror ### Mirror
The source for this repo is mirrored to CodeBerg, available at: **[codeberg.org/alicia/web-check](https://codeberg.org/alicia/web-check)** The source for this repo is mirrored to CodeBerg, available at: **[codeberg.org/alicia/web-check](https://codeberg.org/alicia/web-check)**
#### Motivation ### Motivation
Often when I'm looking into a website, there's several things I always check first. Often when I'm looking into a website, there's several things I always check first.
None of this is hard, and can usually be done with a series of curl commands, or using a combination of online tools. None of this is hard, and can usually be done with a series of curl commands, or using a combination of online tools.
But it's so much easier to have everything presented clearly and visible in one place. But it's so much easier to have everything presented clearly and visible in one place.
#### Features #### Features
- Server Location
- SSL Info
- Headers <details>
- Associated hostnames <summary><h4>Expand to see all features</h4></summary>
- Domain Whois
- DNS records <details>
- Cookies <summary><b>IP Address</b></summary>
- Server info
- Crawl rules <img width="300" src="undefined?" align="right" />
- Performance metrics
- Screenshot ###### Description
- Tech stack The IP Address task involves mapping the user provided URL to its corresponding IP address through a process known as Domain Name System (DNS) resolution. An IP address is a unique identifier given to every device on the Internet, and when paired with a domain name, it allows for accurate routing of online requests and responses.
- Site response times
###### Use Cases
Identifying the IP address of a domain can be incredibly valuable for OSINT purposes. This information can aid in creating a detailed map of a target's network infrastructure, pinpointing the physical location of a server, identifying the hosting service, and even discovering other domains that are hosted on the same IP address. In cybersecurity, it's also useful for tracking the sources of attacks or malicious activities.
###### Useful Links
- [https://en.wikipedia.org/wiki/IP_address](https://en.wikipedia.org/wiki/IP_address)
- [https://tools.ietf.org/html/rfc791](https://tools.ietf.org/html/rfc791)
- [https://www.cloudflare.com/learning/dns/what-is-dns/](https://www.cloudflare.com/learning/dns/what-is-dns/)
- [https://www.whois.com/whois-lookup](https://www.whois.com/whois-lookup)
</details>
<details>
<summary><b>SSL</b></summary>
<img width="300" src="https://i.ibb.co/kB7LsV1/wc-ssl.png?" align="right" />
###### Description
The SSL task involves checking if the site has a valid Secure Sockets Layer (SSL) certificate. SSL is a protocol for establishing authenticated and encrypted links between networked computers. It's commonly used for securing communications over the internet, such as web browsing sessions, email transmissions, and more. In this task, we reach out to the server and initiate a SSL handshake. If successful, we gather details about the SSL certificate presented by the server.
###### Use Cases
SSL certificates not only provide the assurance that data transmission to and from the website is secure, but they also provide valuable OSINT data. Information from an SSL certificate can include the issuing authority, the domain name, its validity period, and sometimes even organization details. This can be useful for verifying the authenticity of a website, understanding its security setup, or even for discovering associated subdomains or other services.
###### Useful Links
- [https://en.wikipedia.org/wiki/Transport_Layer_Security](https://en.wikipedia.org/wiki/Transport_Layer_Security)
- [https://tools.ietf.org/html/rfc8446](https://tools.ietf.org/html/rfc8446)
- [https://letsencrypt.org/docs/](https://letsencrypt.org/docs/)
- [https://www.sslshopper.com/ssl-checker.html](https://www.sslshopper.com/ssl-checker.html)
</details>
<details>
<summary><b>DNS Records</b></summary>
<img width="300" src="https://i.ibb.co/7Q1kMwM/wc-dns.png?" align="right" />
###### Description
The DNS Records task involves querying the Domain Name System (DNS) for records associated with the target domain. DNS is a system that translates human-readable domain names into IP addresses that computers use to communicate. Various types of DNS records exist, including A (address), MX (mail exchange), NS (name server), CNAME (canonical name), and TXT (text), among others.
###### Use Cases
Extracting DNS records can provide a wealth of information in an OSINT investigation. For example, A and AAAA records can disclose IP addresses associated with a domain, potentially revealing the location of servers. MX records can give clues about a domain's email provider. TXT records are often used for various administrative purposes and can sometimes inadvertently leak internal information. Understanding a domain's DNS setup can also be useful in understanding how its online infrastructure is built and managed.
###### Useful Links
- [https://en.wikipedia.org/wiki/List_of_DNS_record_types](https://en.wikipedia.org/wiki/List_of_DNS_record_types)
- [https://tools.ietf.org/html/rfc1035](https://tools.ietf.org/html/rfc1035)
- [https://mxtoolbox.com/DNSLookup.aspx](https://mxtoolbox.com/DNSLookup.aspx)
- [https://www.dnswatch.info/](https://www.dnswatch.info/)
</details>
<details>
<summary><b>Cookies</b></summary>
<img width="300" src="https://i.ibb.co/TTQ6DtP/wc-cookies.png?" align="right" />
###### Description
The Cookies task involves examining the HTTP cookies set by the target website. Cookies are small pieces of data stored on the user's computer by the web browser while browsing a website. They hold a modest amount of data specific to a particular client and website, such as site preferences, the state of the user's session, or tracking information.
###### Use Cases
Cookies provide a wealth of information in an OSINT investigation. They can disclose information about how the website tracks and interacts with its users. For instance, session cookies can reveal how user sessions are managed, and tracking cookies can hint at what kind of tracking or analytics frameworks are being used. Additionally, examining cookie policies and practices can offer insights into the site's security settings and compliance with privacy regulations.
###### Useful Links
- [https://developer.mozilla.org/en-US/docs/Web/HTTP/Cookies](https://developer.mozilla.org/en-US/docs/Web/HTTP/Cookies)
- [https://www.cookiepro.com/knowledge/what-is-a-cookie/](https://www.cookiepro.com/knowledge/what-is-a-cookie/)
- [https://owasp.org/www-community/controls/SecureFlag](https://owasp.org/www-community/controls/SecureFlag)
- [https://tools.ietf.org/html/rfc6265](https://tools.ietf.org/html/rfc6265)
</details>
<details>
<summary><b>Crawl Rules</b></summary>
<img width="300" src="https://i.ibb.co/KwQCjPf/wc-robots.png?" align="right" />
###### Description
The Crawl Rules task is focused on retrieving and interpreting the 'robots.txt' file from the target website. This text file is part of the Robots Exclusion Protocol (REP), a group of web standards that regulate how robots crawl the web, access and index content, and serve that content up to users. The file indicates which parts of the site the website owner doesn't want to be accessed by web crawler bots.
###### Use Cases
The 'robots.txt' file can provide valuable information for an OSINT investigation. It often discloses the directories and pages that the site owner doesn't want to be indexed, potentially because they contain sensitive information. Moreover, it might reveal the existence of otherwise hidden or unlinked directories. Additionally, understanding crawl rules may offer insights into a website's SEO strategies.
###### Useful Links
- [https://developers.google.com/search/docs/advanced/robots/intro](https://developers.google.com/search/docs/advanced/robots/intro)
- [https://www.robotstxt.org/robotstxt.html](https://www.robotstxt.org/robotstxt.html)
- [https://moz.com/learn/seo/robotstxt](https://moz.com/learn/seo/robotstxt)
- [https://en.wikipedia.org/wiki/Robots_exclusion_standard](https://en.wikipedia.org/wiki/Robots_exclusion_standard)
</details>
<details>
<summary><b>Headers</b></summary>
<img width="300" src="https://i.ibb.co/t3xcwP1/wc-headers.png?" align="right" />
###### Description
The Headers task involves extracting and interpreting the HTTP headers sent by the target website during the request-response cycle. HTTP headers are key-value pairs sent at the start of an HTTP response, or before the actual data. Headers contain important directives for how to handle the data being transferred, including cache policies, content types, encoding, server information, security policies, and more.
###### Use Cases
Analyzing HTTP headers can provide significant insights in an OSINT investigation. Headers can reveal specific server configurations, chosen technologies, caching directives, and various security settings. This information can help to determine a website's underlying technology stack, server-side security measures, potential vulnerabilities, and general operational practices.
###### Useful Links
- [https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers)
- [https://tools.ietf.org/html/rfc7231#section-3.2](https://tools.ietf.org/html/rfc7231#section-3.2)
- [https://www.w3schools.com/tags/ref_httpheaders.asp](https://www.w3schools.com/tags/ref_httpheaders.asp)
- [https://owasp.org/www-project-secure-headers/](https://owasp.org/www-project-secure-headers/)
</details>
<details>
<summary><b>Quality Report</b></summary>
<img width="300" src="https://i.ibb.co/Kqg8rx7/wc-quality.png?" align="right" />
###### Description
The Headers task involves extracting and interpreting the HTTP headers sent by the target website during the request-response cycle. HTTP headers are key-value pairs sent at the start of an HTTP response, or before the actual data. Headers contain important directives for how to handle the data being transferred, including cache policies, content types, encoding, server information, security policies, and more.
###### Use Cases
Analyzing HTTP headers can provide significant insights in an OSINT investigation. Headers can reveal specific server configurations, chosen technologies, caching directives, and various security settings. This information can help to determine a website's underlying technology stack, server-side security measures, potential vulnerabilities, and general operational practices.
###### Useful Links
- [https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers)
- [https://tools.ietf.org/html/rfc7231#section-3.2](https://tools.ietf.org/html/rfc7231#section-3.2)
- [https://www.w3schools.com/tags/ref_httpheaders.asp](https://www.w3schools.com/tags/ref_httpheaders.asp)
- [https://owasp.org/www-project-secure-headers/](https://owasp.org/www-project-secure-headers/)
</details>
<details>
<summary><b>Server Location</b></summary>
<img width="300" src="https://i.ibb.co/cXH2hfR/wc-location.png?" align="right" />
###### Description
The Server Location task determines the physical location of a server hosting a website based on its IP address. The geolocation data typically includes the country, region, and often city where the server is located. The task also provides additional contextual information such as the official language, currency, and flag of the server's location country.
###### Use Cases
In the realm of OSINT, server location information can be very valuable. It can give an indication of the possible jurisdiction that laws the data on the server falls under, which can be important in legal or investigative contexts. The server location can also hint at the target audience of a website and reveal inconsistencies that could suggest the use of hosting or proxy services to disguise the actual location.
###### Useful Links
- [https://en.wikipedia.org/wiki/Geolocation_software](https://en.wikipedia.org/wiki/Geolocation_software)
- [https://www.iplocation.net/](https://www.iplocation.net/)
- [https://www.cloudflare.com/learning/cdn/glossary/geolocation/](https://www.cloudflare.com/learning/cdn/glossary/geolocation/)
- [https://developers.google.com/maps/documentation/geolocation/intro](https://developers.google.com/maps/documentation/geolocation/intro)
</details>
<details>
<summary><b>Associated Domains and Hostnames</b></summary>
<img width="300" src="https://i.ibb.co/25j1sT7/wc-hosts.png?" align="right" />
###### Description
This task involves identifying and listing all domains and subdomains (hostnames) that are associated with the website's primary domain. This process often involves DNS enumeration to discover any linked domains and hostnames.
###### Use Cases
In OSINT investigations, understanding the full scope of a target's web presence is critical. Associated domains could lead to uncovering related projects, backup sites, development/test sites, or services linked to the main site. These can sometimes provide additional information or potential security vulnerabilities. A comprehensive list of associated domains and hostnames can also give an overview of the organization's structure and online footprint.
###### Useful Links
- [https://en.wikipedia.org/wiki/Domain_Name_System](https://en.wikipedia.org/wiki/Domain_Name_System)
- [https://resources.infosecinstitute.com/topic/dns-enumeration-pentest/](https://resources.infosecinstitute.com/topic/dns-enumeration-pentest/)
- [https://subdomainfinder.c99.nl/](https://subdomainfinder.c99.nl/)
- [https://securitytrails.com/blog/top-dns-enumeration-tools](https://securitytrails.com/blog/top-dns-enumeration-tools)
</details>
<details>
<summary><b>Redirect Chain</b></summary>
<img width="300" src="https://i.ibb.co/hVVrmwh/wc-redirects.png?" align="right" />
###### Description
This task traces the sequence of HTTP redirects that occur from the original URL to the final destination URL. An HTTP redirect is a response with a status code that advises the client to go to another URL. Redirects can occur for several reasons, such as URL normalization (directing to the www version of the site), enforcing HTTPS, URL shorteners, or forwarding users to a new site location.
###### Use Cases
Understanding the redirect chain can be crucial for several reasons. From a security perspective, long or complicated redirect chains can be a sign of potential security risks, such as unencrypted redirects in the chain. Additionally, redirects can impact website performance and SEO, as each redirect introduces additional round-trip-time (RTT). For OSINT, understanding the redirect chain can help identify relationships between different domains or reveal the use of certain technologies or hosting providers.
###### Useful Links
- [https://developer.mozilla.org/en-US/docs/Web/HTTP/Redirections](https://developer.mozilla.org/en-US/docs/Web/HTTP/Redirections)
- [https://en.wikipedia.org/wiki/URL_redirection](https://en.wikipedia.org/wiki/URL_redirection)
- [https://www.screamingfrog.co.uk/server-response-codes/](https://www.screamingfrog.co.uk/server-response-codes/)
- [https://ahrefs.com/blog/301-redirects/](https://ahrefs.com/blog/301-redirects/)
</details>
<details>
<summary><b>TXT Records</b></summary>
<img width="300" src="https://i.ibb.co/wyt21QN/wc-txt-records.png?" align="right" />
###### Description
TXT records are a type of Domain Name Service (DNS) record that provides text information to sources outside your domain. They can be used for a variety of purposes, such as verifying domain ownership, ensuring email security, and even preventing unauthorized changes to your website.
###### Use Cases
In the context of OSINT, TXT records can be a valuable source of information. They may reveal details about the domain's email configuration, the use of specific services like Google Workspace or Microsoft 365, or security measures in place such as SPF and DKIM. Understanding these details can give an insight into the technologies used by the organization, their email security practices, and potential vulnerabilities.
###### Useful Links
- [https://www.cloudflare.com/learning/dns/dns-records/dns-txt-record/](https://www.cloudflare.com/learning/dns/dns-records/dns-txt-record/)
- [https://en.wikipedia.org/wiki/TXT_record](https://en.wikipedia.org/wiki/TXT_record)
- [https://tools.ietf.org/html/rfc7208](https://tools.ietf.org/html/rfc7208)
- [https://dmarc.org/wiki/FAQ](https://dmarc.org/wiki/FAQ)
</details>
<details>
<summary><b>Server Status</b></summary>
<img width="300" src="https://i.ibb.co/V9CNLBK/wc-status.png?" align="right" />
</details>
<details>
<summary><b>Open Ports</b></summary>
<img width="300" src="https://i.ibb.co/F8D1hmf/wc-ports.png?" align="right" />
###### Description
Open ports on a server are endpoints of communication which are available for establishing connections with clients. Each port corresponds to a specific service or protocol, such as HTTP (port 80), HTTPS (port 443), FTP (port 21), etc. The open ports on a server can be determined using techniques such as port scanning.
###### Use Cases
In the context of OSINT, knowing which ports are open on a server can provide valuable information about the services running on that server. This information can be useful for understanding the potential vulnerabilities of the system, or for understanding the nature of the services the server is providing. For example, a server with port 22 open (SSH) might be used for remote administration, while a server with port 443 open is serving HTTPS traffic.
###### Useful Links
- [https://www.netwrix.com/port_scanning.html](https://www.netwrix.com/port_scanning.html)
- [https://nmap.org/book/man-port-scanning-basics.html](https://nmap.org/book/man-port-scanning-basics.html)
- [https://www.cloudflare.com/learning/ddos/glossary/open-port/](https://www.cloudflare.com/learning/ddos/glossary/open-port/)
- [https://en.wikipedia.org/wiki/List_of_TCP_and_UDP_port_numbers](https://en.wikipedia.org/wiki/List_of_TCP_and_UDP_port_numbers)
</details>
<details>
<summary><b>Traceroute</b></summary>
<img width="300" src="https://i.ibb.co/M59qgxP/wc-trace-route.png?" align="right" />
###### Description
Traceroute is a network diagnostic tool used to track in real-time the pathway taken by a packet of information from one system to another. It records each hop along the route, providing details about the IPs of routers and the delay at each point.
###### Use Cases
In OSINT investigations, traceroute can provide insights about the routing paths and geography of the network infrastructure supporting a website or service. This can help to identify network bottlenecks, potential censorship or manipulation of network traffic, and give an overall sense of the network's structure and efficiency. Additionally, the IP addresses collected during the traceroute may provide additional points of inquiry for further OSINT investigation.
###### Useful Links
- [https://www.cloudflare.com/learning/network-layer/what-is-traceroute/](https://www.cloudflare.com/learning/network-layer/what-is-traceroute/)
- [https://tools.ietf.org/html/rfc1393](https://tools.ietf.org/html/rfc1393)
- [https://en.wikipedia.org/wiki/Traceroute](https://en.wikipedia.org/wiki/Traceroute)
- [https://www.ripe.net/publications/docs/ripe-611](https://www.ripe.net/publications/docs/ripe-611)
</details>
<details>
<summary><b>Carbon Footprint</b></summary>
<img width="300" src="https://i.ibb.co/dmbFxjN/wc-carbon.png?" align="right" />
###### Description
This task calculates the estimated carbon footprint of a website. It's based on the amount of data being transferred and processed, and the energy usage of the servers that host and deliver the website. The larger the website and the more complex its features, the higher its carbon footprint is likely to be.
###### Use Cases
From an OSINT perspective, understanding a website's carbon footprint doesn't directly provide insights into its internal workings or the organization behind it. However, it can still be valuable data in broader analyses, especially in contexts where environmental impact is a consideration. For example, it can be useful for activists, researchers, or ethical hackers who are interested in the sustainability of digital infrastructure, and who want to hold organizations accountable for their environmental impact.
###### Useful Links
- [https://www.websitecarbon.com/](https://www.websitecarbon.com/)
- [https://www.thegreenwebfoundation.org/](https://www.thegreenwebfoundation.org/)
- [https://www.nature.com/articles/s41598-020-76164-y](https://www.nature.com/articles/s41598-020-76164-y)
- [https://www.sciencedirect.com/science/article/pii/S0959652620307817](https://www.sciencedirect.com/science/article/pii/S0959652620307817)
</details>
<details>
<summary><b>Server Info</b></summary>
<img width="300" src="https://i.ibb.co/Mk1jx32/wc-server.png?" align="right" />
###### Description
This task retrieves various pieces of information about the server hosting the target website. This can include the server type (e.g., Apache, Nginx), the hosting provider, the Autonomous System Number (ASN), and more. The information is usually obtained through a combination of IP address lookups and analysis of HTTP response headers.
###### Use Cases
In an OSINT context, server information can provide valuable clues about the organization behind a website. For instance, the choice of hosting provider could suggest the geographical region in which the organization operates, while the server type could hint at the technologies used by the organization. The ASN could also be used to find other domains hosted by the same organization.
###### Useful Links
- [https://en.wikipedia.org/wiki/List_of_HTTP_header_fields](https://en.wikipedia.org/wiki/List_of_HTTP_header_fields)
- [https://en.wikipedia.org/wiki/Autonomous_system_(Internet)](https://en.wikipedia.org/wiki/Autonomous_system_(Internet))
- [https://tools.ietf.org/html/rfc7231#section-7.4.2](https://tools.ietf.org/html/rfc7231#section-7.4.2)
- [https://builtwith.com/](https://builtwith.com/)
</details>
<details>
<summary><b>Domain Info</b></summary>
<img width="300" src="https://i.ibb.co/89WLp14/wc-domain.png?" align="right" />
###### Description
This task retrieves Whois records for the target domain. Whois records are a rich source of information, including the name and contact information of the domain registrant, the domain's creation and expiration dates, the domain's nameservers, and more. The information is usually obtained through a query to a Whois database server.
###### Use Cases
In an OSINT context, Whois records can provide valuable clues about the entity behind a website. They can show when the domain was first registered and when it's set to expire, which could provide insights into the operational timeline of the entity. The contact information, though often redacted or anonymized, can sometimes lead to additional avenues of investigation. The nameservers could also be used to link together multiple domains owned by the same entity.
###### Useful Links
- [https://en.wikipedia.org/wiki/WHOIS](https://en.wikipedia.org/wiki/WHOIS)
- [https://www.icann.org/resources/pages/whois-2018-01-17-en](https://www.icann.org/resources/pages/whois-2018-01-17-en)
- [https://whois.domaintools.com/](https://whois.domaintools.com/)
</details>
<details>
<summary><b>DNS Security Extensions</b></summary>
<img width="300" src="https://i.ibb.co/J54zVmQ/wc-dnssec.png?" align="right" />
###### Description
Without DNSSEC, it's possible for MITM attackers to spoof records and lead users to phishing sites. This is because the DNS system includes no built-in methods to verify that the response to the request was not forged, or that any other part of the process wasnt interrupted by an attacker. The DNS Security Extensions (DNSSEC) secures DNS lookups by signing your DNS records using public keys, so browsers can detect if the response has been tampered with. Another solution to this issue is DoH (DNS over HTTPS) and DoT (DNS over TLD).
###### Use Cases
DNSSEC information provides insight into an organization's level of cybersecurity maturity and potential vulnerabilities, particularly around DNS spoofing and cache poisoning. If no DNS secururity (DNSSEC, DoH, DoT, etc) is implemented, this may provide an entry point for an attacker.
###### Useful Links
- [https://dnssec-analyzer.verisignlabs.com/](https://dnssec-analyzer.verisignlabs.com/)
- [https://www.cloudflare.com/dns/dnssec/how-dnssec-works/](https://www.cloudflare.com/dns/dnssec/how-dnssec-works/)
- [https://en.wikipedia.org/wiki/Domain_Name_System_Security_Extensions](https://en.wikipedia.org/wiki/Domain_Name_System_Security_Extensions)
- [https://www.icann.org/resources/pages/dnssec-what-is-it-why-important-2019-03-05-en](https://www.icann.org/resources/pages/dnssec-what-is-it-why-important-2019-03-05-en)
- [https://support.google.com/domains/answer/6147083](https://support.google.com/domains/answer/6147083)
- [https://www.internetsociety.org/resources/deploy360/2013/dnssec-test-sites/](https://www.internetsociety.org/resources/deploy360/2013/dnssec-test-sites/)
</details>
</details>
Read more here: **[web-check.as93.net/about](https://web-check.as93.net/about)**
_Note that not all checks will work for all sites. Sometimes it's not possible to determine some information, and there are limitations imposed by Netlify for the lambda functions._ _Note that not all checks will work for all sites. Sometimes it's not possible to determine some information, and there are limitations imposed by Netlify for the lambda functions._

View File

@ -18,8 +18,8 @@ function App() {
<Container> <Container>
<Routes> <Routes>
<Route path="/" element={<Home />} /> <Route path="/" element={<Home />} />
<Route path="/results/:address" element={<Results />} />
<Route path="/about" element={<About />} /> <Route path="/about" element={<About />} />
<Route path="/results/:address" element={<Results />} />
</Routes> </Routes>
</Container> </Container>
); );

View File

@ -39,6 +39,8 @@ const ModalWindow = styled.div`
animation: appear 0.5s; animation: appear 0.5s;
color: ${colors.textColor}; color: ${colors.textColor};
box-shadow: 4px 4px 0px ${colors.bgShadowColor}; box-shadow: 4px 4px 0px ${colors.bgShadowColor};
max-height: 80%;
overflow-y: auto;
@keyframes appear { @keyframes appear {
0% {opacity: 0; transform: scale(0.9);} 0% {opacity: 0; transform: scale(0.9);}
100% {opacity: 1; transform: scale(1);} 100% {opacity: 1; transform: scale(1);}

View File

@ -10,7 +10,7 @@ import docs, { about, license, fairUse } from 'utils/docs';
const AboutContainer = styled.div` const AboutContainer = styled.div`
width: 80vw; width: 95vw;
max-width: 1000px; max-width: 1000px;
margin: 2rem auto; margin: 2rem auto;
padding-bottom: 1rem; padding-bottom: 1rem;
@ -30,6 +30,7 @@ const HeaderLinkContainer = styled.nav`
const Section = styled(StyledCard)` const Section = styled(StyledCard)`
margin-bottom: 2rem; margin-bottom: 2rem;
overflow: clip;
h3 { h3 {
font-size: 1.5rem; font-size: 1.5rem;
} }
@ -69,6 +70,13 @@ const Section = styled(StyledCard)`
} }
} }
} }
.screenshot {
float: right;
break-inside: avoid;
max-width: 300px;
max-height: 28rem;
border-radius: 6px;
}
`; `;
const makeAnchor = (title: string): string => { const makeAnchor = (title: string): string => {
@ -109,16 +117,25 @@ const About = (): JSX.Element => {
{docs.map((section, sectionIndex: number) => ( {docs.map((section, sectionIndex: number) => (
<section key={section.title}> <section key={section.title}>
<Heading as="h3" size="small" id={makeAnchor(section.title)} color={colors.primary}>{section.title}</Heading> <Heading as="h3" size="small" id={makeAnchor(section.title)} color={colors.primary}>{section.title}</Heading>
<Heading as="h4" size="small">Description</Heading> {section.screenshot &&
<p>{section.description}</p> <img className="screenshot" src={section.screenshot} alt={`Example Screenshot ${section.title}`} />
<Heading as="h4" size="small">Use Cases</Heading> }
<p>{section.use}</p> {section.description && <>
<Heading as="h4" size="small">Useful Links</Heading> <Heading as="h4" size="small">Description</Heading>
<ul> <p>{section.description}</p>
{section.resources.map((link: string) => ( </>}
<li><a href={link}>{link}</a></li> { section.use && <>
))} <Heading as="h4" size="small">Use Cases</Heading>
</ul> <p>{section.use}</p>
</>}
{section.resources && section.resources.length > 0 && <>
<Heading as="h4" size="small">Useful Links</Heading>
<ul>
{section.resources.map((link: string, linkIndx: number) => (
<li key={linkIndx}><a href={link}>{link}</a></li>
))}
</ul>
</>}
{ sectionIndex < docs.length - 1 && <hr /> } { sectionIndex < docs.length - 1 && <hr /> }
</section> </section>
))} ))}

View File

@ -78,6 +78,7 @@ ul {
ul li a { ul li a {
color: ${colors.primary}; color: ${colors.primary};
} }
summary { color: ${colors.primary};}
h4 { h4 {
border-top: 1px solid ${colors.primary}; border-top: 1px solid ${colors.primary};
color: ${colors.primary}; color: ${colors.primary};
@ -141,6 +142,7 @@ const Results = (): JSX.Element => {
}, []); }, []);
const parseJson = (response: Response): Promise<any> => { const parseJson = (response: Response): Promise<any> => {
// return response.json()
return new Promise((resolve) => { return new Promise((resolve) => {
if (response.ok) { if (response.ok) {
response.json() response.json()
@ -431,6 +433,10 @@ const Results = (): JSX.Element => {
<li id={`link-${index}`}><a target="_blank" rel="noreferrer" href={resource}>{resource}</a></li> <li id={`link-${index}`}><a target="_blank" rel="noreferrer" href={resource}>{resource}</a></li>
))} ))}
</ul> </ul>
<details>
<summary><Heading as="h4" size="small">Example</Heading></summary>
<img width="300" src={doc.screenshot} alt="Screenshot" />
</details>
</JobDocsContainer>) </JobDocsContainer>)
: ( : (
<JobDocsContainer> <JobDocsContainer>

View File

@ -4,6 +4,7 @@ interface Doc {
description: string; description: string;
use: string; use: string;
resources: string[]; resources: string[];
screenshot?: string;
} }
const docs: Doc[] = [ const docs: Doc[] = [
@ -32,6 +33,7 @@ const docs: Doc[] = [
"https://letsencrypt.org/docs/", "https://letsencrypt.org/docs/",
"https://www.sslshopper.com/ssl-checker.html", "https://www.sslshopper.com/ssl-checker.html",
], ],
screenshot: 'https://i.ibb.co/kB7LsV1/wc-ssl.png',
}, },
{ {
id: "dns", id: "dns",
@ -45,6 +47,7 @@ const docs: Doc[] = [
"https://mxtoolbox.com/DNSLookup.aspx", "https://mxtoolbox.com/DNSLookup.aspx",
"https://www.dnswatch.info/", "https://www.dnswatch.info/",
], ],
screenshot: 'https://i.ibb.co/7Q1kMwM/wc-dns.png',
}, },
{ {
id: "cookies", id: "cookies",
@ -58,6 +61,7 @@ const docs: Doc[] = [
"https://owasp.org/www-community/controls/SecureFlag", "https://owasp.org/www-community/controls/SecureFlag",
"https://tools.ietf.org/html/rfc6265", "https://tools.ietf.org/html/rfc6265",
], ],
screenshot: 'https://i.ibb.co/TTQ6DtP/wc-cookies.png',
}, },
{ {
id: "robots-txt", id: "robots-txt",
@ -71,6 +75,7 @@ const docs: Doc[] = [
"https://moz.com/learn/seo/robotstxt", "https://moz.com/learn/seo/robotstxt",
"https://en.wikipedia.org/wiki/Robots_exclusion_standard", "https://en.wikipedia.org/wiki/Robots_exclusion_standard",
], ],
screenshot: 'https://i.ibb.co/KwQCjPf/wc-robots.png',
}, },
{ {
id: "headers", id: "headers",
@ -84,10 +89,11 @@ const docs: Doc[] = [
"https://www.w3schools.com/tags/ref_httpheaders.asp", "https://www.w3schools.com/tags/ref_httpheaders.asp",
"https://owasp.org/www-project-secure-headers/", "https://owasp.org/www-project-secure-headers/",
], ],
screenshot: 'https://i.ibb.co/t3xcwP1/wc-headers.png',
}, },
{ {
id: "lighthouse", id: "lighthouse",
title: "Headers", title: "Quality Report",
description: description:
"The Headers task involves extracting and interpreting the HTTP headers sent by the target website during the request-response cycle. HTTP headers are key-value pairs sent at the start of an HTTP response, or before the actual data. Headers contain important directives for how to handle the data being transferred, including cache policies, content types, encoding, server information, security policies, and more.", "The Headers task involves extracting and interpreting the HTTP headers sent by the target website during the request-response cycle. HTTP headers are key-value pairs sent at the start of an HTTP response, or before the actual data. Headers contain important directives for how to handle the data being transferred, including cache policies, content types, encoding, server information, security policies, and more.",
use: "Analyzing HTTP headers can provide significant insights in an OSINT investigation. Headers can reveal specific server configurations, chosen technologies, caching directives, and various security settings. This information can help to determine a website's underlying technology stack, server-side security measures, potential vulnerabilities, and general operational practices.", use: "Analyzing HTTP headers can provide significant insights in an OSINT investigation. Headers can reveal specific server configurations, chosen technologies, caching directives, and various security settings. This information can help to determine a website's underlying technology stack, server-side security measures, potential vulnerabilities, and general operational practices.",
@ -97,6 +103,7 @@ const docs: Doc[] = [
"https://www.w3schools.com/tags/ref_httpheaders.asp", "https://www.w3schools.com/tags/ref_httpheaders.asp",
"https://owasp.org/www-project-secure-headers/", "https://owasp.org/www-project-secure-headers/",
], ],
screenshot: 'https://i.ibb.co/Kqg8rx7/wc-quality.png',
}, },
{ {
id: "location", id: "location",
@ -110,6 +117,7 @@ const docs: Doc[] = [
"https://www.cloudflare.com/learning/cdn/glossary/geolocation/", "https://www.cloudflare.com/learning/cdn/glossary/geolocation/",
"https://developers.google.com/maps/documentation/geolocation/intro", "https://developers.google.com/maps/documentation/geolocation/intro",
], ],
screenshot: 'https://i.ibb.co/cXH2hfR/wc-location.png',
}, },
{ {
id: "hosts", id: "hosts",
@ -123,6 +131,7 @@ const docs: Doc[] = [
"https://subdomainfinder.c99.nl/", "https://subdomainfinder.c99.nl/",
"https://securitytrails.com/blog/top-dns-enumeration-tools", "https://securitytrails.com/blog/top-dns-enumeration-tools",
], ],
screenshot: 'https://i.ibb.co/25j1sT7/wc-hosts.png',
}, },
{ {
id: "redirects", id: "redirects",
@ -136,6 +145,7 @@ const docs: Doc[] = [
"https://www.screamingfrog.co.uk/server-response-codes/", "https://www.screamingfrog.co.uk/server-response-codes/",
"https://ahrefs.com/blog/301-redirects/", "https://ahrefs.com/blog/301-redirects/",
], ],
screenshot: 'https://i.ibb.co/hVVrmwh/wc-redirects.png',
}, },
{ {
id: "txt-records", id: "txt-records",
@ -149,10 +159,11 @@ const docs: Doc[] = [
"https://tools.ietf.org/html/rfc7208", "https://tools.ietf.org/html/rfc7208",
"https://dmarc.org/wiki/FAQ", "https://dmarc.org/wiki/FAQ",
], ],
screenshot: 'https://i.ibb.co/wyt21QN/wc-txt-records.png',
}, },
{ {
id: "status", id: "status",
title: "TXT Records", title: "Server Status",
description: description:
"TXT records are a type of Domain Name Service (DNS) record that provides text information to sources outside your domain. They can be used for a variety of purposes, such as verifying domain ownership, ensuring email security, and even preventing unauthorized changes to your website.", "TXT records are a type of Domain Name Service (DNS) record that provides text information to sources outside your domain. They can be used for a variety of purposes, such as verifying domain ownership, ensuring email security, and even preventing unauthorized changes to your website.",
use: "In the context of OSINT, TXT records can be a valuable source of information. They may reveal details about the domain's email configuration, the use of specific services like Google Workspace or Microsoft 365, or security measures in place such as SPF and DKIM. Understanding these details can give an insight into the technologies used by the organization, their email security practices, and potential vulnerabilities.", use: "In the context of OSINT, TXT records can be a valuable source of information. They may reveal details about the domain's email configuration, the use of specific services like Google Workspace or Microsoft 365, or security measures in place such as SPF and DKIM. Understanding these details can give an insight into the technologies used by the organization, their email security practices, and potential vulnerabilities.",
@ -162,6 +173,7 @@ const docs: Doc[] = [
"https://tools.ietf.org/html/rfc7208", "https://tools.ietf.org/html/rfc7208",
"https://dmarc.org/wiki/FAQ", "https://dmarc.org/wiki/FAQ",
], ],
screenshot: 'https://i.ibb.co/V9CNLBK/wc-status.png',
}, },
{ {
id: "ports", id: "ports",
@ -175,6 +187,7 @@ const docs: Doc[] = [
"https://www.cloudflare.com/learning/ddos/glossary/open-port/", "https://www.cloudflare.com/learning/ddos/glossary/open-port/",
"https://en.wikipedia.org/wiki/List_of_TCP_and_UDP_port_numbers", "https://en.wikipedia.org/wiki/List_of_TCP_and_UDP_port_numbers",
], ],
screenshot: 'https://i.ibb.co/F8D1hmf/wc-ports.png',
}, },
{ {
id: "trace-route", id: "trace-route",
@ -188,6 +201,7 @@ const docs: Doc[] = [
"https://en.wikipedia.org/wiki/Traceroute", "https://en.wikipedia.org/wiki/Traceroute",
"https://www.ripe.net/publications/docs/ripe-611", "https://www.ripe.net/publications/docs/ripe-611",
], ],
screenshot: 'https://i.ibb.co/M59qgxP/wc-trace-route.png',
}, },
{ {
id: "carbon", id: "carbon",
@ -201,6 +215,7 @@ const docs: Doc[] = [
"https://www.nature.com/articles/s41598-020-76164-y", "https://www.nature.com/articles/s41598-020-76164-y",
"https://www.sciencedirect.com/science/article/pii/S0959652620307817", "https://www.sciencedirect.com/science/article/pii/S0959652620307817",
], ],
screenshot: 'https://i.ibb.co/dmbFxjN/wc-carbon.png',
}, },
{ {
id: "server-info", id: "server-info",
@ -214,10 +229,11 @@ const docs: Doc[] = [
"https://tools.ietf.org/html/rfc7231#section-7.4.2", "https://tools.ietf.org/html/rfc7231#section-7.4.2",
"https://builtwith.com/", "https://builtwith.com/",
], ],
screenshot: 'https://i.ibb.co/Mk1jx32/wc-server.png',
}, },
{ {
id: "whois", id: "whois",
title: "Whois", title: "Domain Info",
description: description:
"This task retrieves Whois records for the target domain. Whois records are a rich source of information, including the name and contact information of the domain registrant, the domain's creation and expiration dates, the domain's nameservers, and more. The information is usually obtained through a query to a Whois database server.", "This task retrieves Whois records for the target domain. Whois records are a rich source of information, including the name and contact information of the domain registrant, the domain's creation and expiration dates, the domain's nameservers, and more. The information is usually obtained through a query to a Whois database server.",
use: "In an OSINT context, Whois records can provide valuable clues about the entity behind a website. They can show when the domain was first registered and when it's set to expire, which could provide insights into the operational timeline of the entity. The contact information, though often redacted or anonymized, can sometimes lead to additional avenues of investigation. The nameservers could also be used to link together multiple domains owned by the same entity.", use: "In an OSINT context, Whois records can provide valuable clues about the entity behind a website. They can show when the domain was first registered and when it's set to expire, which could provide insights into the operational timeline of the entity. The contact information, though often redacted or anonymized, can sometimes lead to additional avenues of investigation. The nameservers could also be used to link together multiple domains owned by the same entity.",
@ -226,6 +242,7 @@ const docs: Doc[] = [
"https://www.icann.org/resources/pages/whois-2018-01-17-en", "https://www.icann.org/resources/pages/whois-2018-01-17-en",
"https://whois.domaintools.com/", "https://whois.domaintools.com/",
], ],
screenshot: 'https://i.ibb.co/89WLp14/wc-domain.png',
}, },
{ {
id: "dnssec", id: "dnssec",
@ -241,6 +258,15 @@ const docs: Doc[] = [
"https://support.google.com/domains/answer/6147083", "https://support.google.com/domains/answer/6147083",
"https://www.internetsociety.org/resources/deploy360/2013/dnssec-test-sites/", "https://www.internetsociety.org/resources/deploy360/2013/dnssec-test-sites/",
], ],
screenshot: 'https://i.ibb.co/J54zVmQ/wc-dnssec.png',
},
{
id: "features",
title: "Features",
description: '',
use: "",
resources: [],
screenshot: 'https://i.ibb.co/gP4P6kp/wc-features.png',
}, },
]; ];