-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathindex.js
199 lines (183 loc) · 7.42 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
import React, {useEffect, useState} from 'react';
import useDocusaurusContext from '@docusaurus/useDocusaurusContext';
import Layout from '@theme/Layout';
import styles from './styles.module.css';
import {
HomepageCard as Card,
HomepageSection as Section,
ProductCard,
RunaCapitalBadge,
SocialCard,
SwagCard
} from '../components/HomepageComponents';
// import ReactPlayer from 'react-player';
function HeroBanner() {
const fetchData = () => {
fetch(`https://community.deepfence.io/gh-cache/orgs/deepfence/repos`)
.then((response) => response.json())
.then((data) => setGitHubData(data));
fetch(`https://community.deepfence.io/dh-cache/v2/repositories/deepfenceio/deepfence_agent_ce`)
.then((response) => response.json())
.then((data) => setDockerHubData(data));
}
useEffect(() => {
fetchData();
}, []);
const [githubData, setGitHubData] = useState([]);
const [dockerhubData, setDockerHubData] = useState([]);
function getStars(data) {
/* If this GET has failed, check browser console messages and community.deepfence.io/gh-cache/ configuration.
We try to route all GitHub api calls through https://community.deepfence.io/gh-cache/ ; see also the patch to
github-buttons. The gh-cache will cache GitHub API requests to reduce the load on GitHub and reduce the
likelihood of exceeding their rate limits and getting a 403 response */
const repos = ['ThreatMapper', 'SecretScanner', 'YaraHunter', 'PacketStreamer', 'FlowMeter', 'ebpfguard', 'community', 'package-scanner', 'CI-CD-Integrations', 'secretscanner-docker-extension', 'yarahunter-docker-extension'];
if (Array.isArray(data)) {
var stars = data.reduce((acc, curr) => {
return repos.includes(curr.name) ? acc + curr.stargazers_count : acc;
}, 0);
if (stars > 0) return `${stars.toLocaleString()} GitHub Stars`;
}
return "Be Part of the Wave";
}
function getPulls(data) {
/* If this GET has failed, check browser console messages and community.deepfence.io/dh-proxy configuration.*/
var pulls = data.pull_count;
if (pulls > 0) return `${pulls.toLocaleString()} ThreatMapper Pulls`;
return "Multi Cloud, Multi Modality";
}
return (
<div className={styles.hero} id="hero">
<div className={styles.heroInner}>
<h1>
Deepfence Community
</h1>
<Section title="Featured as one of the fastest-growing open-source startups" HeadingTag="h3">
<RunaCapitalBadge/>
</Section>
<Section title="Open Source is at the core of what we do, trusted by 1,000's of community users."
HeadingTag="h3">
<Card
title="100% Open Source"
description="Deepfence open source projects are completely open source. No phone-home, no limits, no hidden features."
/>
<Card
title={getPulls(dockerhubData)}
description="Deepfence ThreatMapper finds threats hidden in thousands of production platforms - Cloud, Serverless, Containers."
/>
<Card
title={getStars(githubData)}
description="Across multiple repos, Deepfence projects are amongst the fastest adopted security solutions for cloud-native apps."
/>
</Section>
</div>
</div>
);
}
function OpenSourceProducts() {
return (
<div>
<Section>
<ProductCard
title="Deepfence ThreatMapper"
description="Hunt for threats in production platforms, and rank them based on their risk-of-exploit."
icon="/img/products/threatmapper.svg"
gh="deepfence/ThreatMapper"
docs="/threatmapper/docs"
readmore="https://deepfence.io/threatmapper"
/>
{/*<div className="homepage-card card-content" id="video">*/}
{/* <ReactPlayer controls url='/img/threatmapper-intro.mp4' width="100%" height="100%"/>*/}
{/*</div>*/}
<ProductCard
title="Deepfence SecretScanner"
description="Find unprotected secrets, tokens and authentication keys in containers and file systems."
icon="/img/products/secretscanner.svg"
gh="deepfence/SecretScanner"
docs="/docs/secretscanner"
/>
<ProductCard
title="Deepfence YaraHunter"
description="Use YARA rules to scan builds, containers and filesystems to find indicators of malware."
icon="/img/products/yarahunter.svg"
gh="deepfence/YaraHunter"
docs="/docs/yarahunter"
/>
<ProductCard
title="Deepfence PacketStreamer"
description="A lightweight packet collector, supporting distributed hosts, clouds and kubernetes."
icon="/img/products/packetstreamer.svg"
gh="deepfence/PacketStreamer"
docs="/docs/packetstreamer"
/>
<ProductCard
title="Deepfence FlowMeter"
description="Employ machine learning techniques to classify network flows based on packet headers."
icon="/img/products/flowmeter.svg"
gh="deepfence/FlowMeter"
docs="/docs/flowmeter"
/>
<ProductCard
title="Aya"
description="Aya is an eBPF library built with a focus on operability and developer experience. It does not rely on libbpf nor bcc - it's built from the ground up purely in Rust, using only the libc crate to execute syscalls."
icon="https://aya-rs.dev/assets/images/crabby.svg"
gh="aya-rs/aya"
docs="https://aya-rs.dev/book"
/>
<ProductCard
title="Ebpfguard"
description="Ebpfguard is an Aya based library for seamless utilization of LSM BPF hooks"
// icon="/img/products/ebpfguard.svg"
gh="deepfence/ebpfguard"
docs="/docs/ebpfguard"
/>
</Section>
</div>
);
}
function EnterpriseProducts() {
return (
<div>
<Section title="Deepfence Enterprise Products" className="two-cols">
<ProductCard
title="Deepfence ThreatStryker"
description="Observe, correlate, learn, and act to protect your cloud-native applications, across clouds and on-prem locations. Built on ThreatMapper, ThreatStryker adds runtime telemetry, attack storyboarding, and targetted protection."
icon="/img/products/threatstryker.svg"
docs="/threatstryker/docs/"
readmore="https://deepfence.io/threatstryker"
/>
<ProductCard
title="Deepfence Cloud"
description="A self-service portal where you can deploy dedicated, fully-managed ThreatStryker instances. Empower your teams to secure and protect their cloud-native applications, at scale and across clouds and on-prem locations."
icon="/img/products/cloud.svg"
docs="/threatstryker/docs/cloud/"
readmore="https://deepfence.io/cloud/"
/>
</Section>
</div>
);
}
function Community() {
return (
<div>
<Section title="Join in the Open-Source Community" className="two-cols">
<SocialCard/>
<SwagCard/>
</Section>
</div>
);
}
export default function HomePage() {
const {siteConfig, siteMetadata} = useDocusaurusContext();
return (
<Layout title={siteConfig.title} description={siteConfig.tagline}>
<main>
<HeroBanner/>
<div className={styles.maincontent}>
<OpenSourceProducts/>
<EnterpriseProducts/>
<Community/>
</div>
</main>
</Layout>
);
}