forked from cyfinoid/sbomplay
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsettings.html
More file actions
303 lines (290 loc) · 14.6 KB
/
settings.html
File metadata and controls
303 lines (290 loc) · 14.6 KB
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
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>SBOM Play - Settings</title>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet">
<link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css" rel="stylesheet">
<link href="css/style.css" rel="stylesheet">
<script defer data-domain="cyfinoid.github.io" src="https://plausible.io/js/script.outbound-links.js"></script>
<script>window.plausible = window.plausible || function() { (window.plausible.q = window.plausible.q || []).push(arguments) }</script>
</head>
<body>
<!-- Navigation -->
<nav class="navbar navbar-expand-lg navbar-dark bg-primary">
<div class="container">
<a class="navbar-brand" href="index.html">
<i class="fas fa-cubes me-2"></i>SBOM Play
</a>
<div class="navbar-nav ms-auto">
<a class="nav-link" href="index.html">Analysis</a>
<a class="nav-link" href="stats.html">Stats</a>
<a class="nav-link" href="license-compliance.html">License</a>
<a class="nav-link" href="vuln.html">Vulnerabilities</a>
<a class="nav-link" href="deps.html">Dependencies</a>
<a class="nav-link active" href="settings.html">
<i class="fas fa-cog"></i>
</a>
</div>
</div>
</nav>
<!-- Main Content -->
<div class="container mt-4">
<!-- Header -->
<div class="row mb-4">
<div class="col-12">
<div class="d-flex justify-content-between align-items-center">
<div>
<h1><i class="fas fa-cog me-2"></i>Settings</h1>
<p class="text-muted">Manage your SBOM Play configuration and storage</p>
</div>
<div>
<a href="index.html" class="btn btn-outline-primary">
<i class="fas fa-arrow-left me-2"></i>Back to Analysis
</a>
</div>
</div>
</div>
</div>
<!-- Storage Management -->
<div class="card mb-4">
<div class="card-header">
<h5 class="mb-0">
<i class="fas fa-hdd me-2"></i>Storage Management
</h5>
</div>
<div class="card-body">
<div id="storageStatus" class="mb-3">
<!-- Storage status will be populated by JavaScript -->
</div>
<div class="row">
<div class="col-md-6">
<button class="btn btn-outline-primary btn-sm" onclick="settingsApp.showStorageStatus()">
<i class="fas fa-info-circle me-2"></i>Check Storage Status
</button>
<button class="btn btn-outline-success btn-sm" onclick="settingsApp.exportAllData()">
<i class="fas fa-download me-2"></i>Export All Data
</button>
<button class="btn btn-outline-info btn-sm" onclick="settingsApp.testStorageQuota()">
<i class="fas fa-vial me-2"></i>Test Storage
</button>
<button class="btn btn-outline-secondary btn-sm" onclick="settingsApp.migrateOldData()">
<i class="fas fa-sync me-2"></i>Migrate Data
</button>
</div>
<div class="col-md-6 text-end">
<button class="btn btn-outline-warning btn-sm" onclick="settingsApp.clearOldData()">
<i class="fas fa-broom me-2"></i>Clear Old Data
</button>
<button class="btn btn-outline-danger btn-sm" onclick="settingsApp.clearAllData()">
<i class="fas fa-trash me-2"></i>Clear All Data
</button>
</div>
</div>
</div>
</div>
<!-- GitHub Token Input -->
<div class="card mb-4">
<div class="card-header" style="cursor: pointer;" onclick="settingsApp.toggleTokenSection()">
<h5 class="mb-0 d-flex justify-content-between align-items-center">
<span>
<i class="fab fa-github me-2"></i>GitHub Authentication (Optional)
</span>
<i class="fas fa-chevron-down" id="tokenToggleIcon"></i>
</h5>
</div>
<div class="card-body" id="tokenSectionBody" style="display: none;">
<div class="alert alert-warning alert-sm mb-3">
<i class="fas fa-exclamation-triangle me-2"></i>
<strong>Note:</strong> GitHub tokens are not saved or persisted. You will need to provide your token each time you use the application.
</div>
<div class="row">
<div class="col-md-8">
<label for="githubToken" class="form-label">GitHub Personal Access Token (Optional: Provides higher rate limits)<sup>*</sup> <a href="https://github.com/settings/tokens" target="_blank">Create token here</a></label>
<input type="password" class="form-control" id="githubToken"
placeholder="ghp_xxxxxxxxxxxxxxxxxxxx (optional)">
</div>
<div class="col-md-4">
<div class="d-flex align-items-end h-100">
<button class="btn btn-outline-primary" onclick="settingsApp.saveToken()">
<i class="fas fa-check me-2"></i>Set Token
</button>
</div>
</div>
</div>
<div id="tokenStatus" class="mt-2"></div>
</div>
</div>
<!-- Stored Analyses Section -->
<div id="organizationsSection" class="card mb-4">
<div class="card-header">
<h5 class="mb-0">
<i class="fas fa-database me-2"></i>Stored Analyses
</h5>
</div>
<div class="card-body">
<div id="organizationsContent">
<div class="text-center text-muted">
<i class="fas fa-spinner fa-spin fa-2x mb-3"></i>
<p>Loading stored analyses...</p>
</div>
</div>
</div>
</div>
<!-- No Data Section -->
<div id="noDataSection" class="card mb-4" style="display: none;">
<div class="card-header">
<h5 class="mb-0">
<i class="fas fa-info-circle me-2"></i>No Data Available
</h5>
</div>
<div class="card-body text-center">
<i class="fas fa-database fa-3x text-muted mb-3"></i>
<h5>No Stored Analyses Found</h5>
<p class="text-muted">
You haven't analyzed any organizations yet, or all data has been cleared.
</p>
<a href="index.html" class="btn btn-primary">
<i class="fas fa-play me-2"></i>Start Your First Analysis
</a>
</div>
</div>
<!-- Rate Limit Information -->
<div class="card mb-4">
<div class="card-header">
<h5 class="mb-0">
<i class="fas fa-clock me-2"></i>Rate Limit Information
</h5>
</div>
<div class="card-body">
<div class="row">
<div class="col-md-6">
<h6>Current Status</h6>
<div id="rateLimitStatus">
<p class="text-muted">Loading rate limit information...</p>
</div>
</div>
<div class="col-md-6">
<h6>Rate Limits</h6>
<ul class="list-unstyled">
<li><strong>Without token:</strong> 60 requests/hour</li>
<li><strong>With token:</strong> 5,000 requests/hour</li>
<li>The tool automatically handles rate limiting</li>
</ul>
</div>
</div>
</div>
</div>
<!-- Application Information -->
<div class="card mb-4">
<div class="card-header">
<h5 class="mb-0">
<i class="fas fa-info-circle me-2"></i>Application Information
</h5>
</div>
<div class="card-body">
<div class="row">
<div class="col-md-6">
<h6>About SBOM Play</h6>
<p class="text-muted small">
SBOM Play is a client-side tool for analyzing Software Bill of Materials (SBOM)
from GitHub organizations and users. It processes dependency data locally in your browser
and stores results in your browser's local storage.
</p>
<h6>Key Features:</h6>
<ul class="small">
<li><strong>Privacy-First:</strong> All processing happens in your browser</li>
<li><strong>No Server Required:</strong> Works entirely client-side</li>
<li><strong>Persistent Storage:</strong> Results saved in browser storage</li>
<li><strong>Rate Limit Aware:</strong> Handles GitHub API limits intelligently</li>
</ul>
</div>
<div class="col-md-6">
<h6>Browser Compatibility</h6>
<ul class="small">
<li>Modern browsers with ES6+ support</li>
<li>Requires localStorage support</li>
<li>No external dependencies</li>
</ul>
<h6>Data Storage</h6>
<ul class="small">
<li>All data stored in browser localStorage</li>
<li>Data persists between browser sessions</li>
<li>Maximum 4.5MB storage limit</li>
<li>Automatic compression for large datasets</li>
</ul>
</div>
</div>
</div>
</div>
</div>
<!-- Footer -->
<footer class="bg-light mt-5 py-4">
<div class="container">
<div class="row">
<!-- First Column: SBOM Play Tool -->
<div class="col-md-4">
<h6 class="text-primary">SBOM Play</h6>
<p class="text-muted small mb-3">
A client-side tool for analyzing Software Bill of Materials from GitHub organizations and users.
All processing happens in your browser for maximum privacy and security.
</p>
<p class="text-muted small mb-0">
<strong>Privacy-First:</strong> All processing happens in your browser<br>
<strong>No Server Required:</strong> Works entirely client-side<br>
<strong>Persistent Storage:</strong> Results saved in browser storage<br>
<strong>Rate Limit Aware:</strong> Handles GitHub API limits intelligently
</p>
</div>
<!-- Second Column: Links -->
<div class="col-md-4">
<h6 class="text-primary">Resources</h6>
<div class="d-flex flex-column gap-2">
<a href="https://cyfinoid.com/" target="_blank" class="btn btn-outline-primary btn-sm">
<i class="fas fa-globe me-1"></i>Website
</a>
<a href="https://cyfinoid.com/blog/" target="_blank" class="btn btn-outline-primary btn-sm">
<i class="fas fa-blog me-1"></i>Blog
</a>
<a href="https://cyfinoid.com/trainings/#upcoming-trainings" target="_blank" class="btn btn-outline-primary btn-sm">
<i class="fas fa-graduation-cap me-1"></i>Upcoming Trainings
</a>
<a href="https://cyfinoid.com/opensource-by-cyfinoid/" target="_blank" class="btn btn-outline-primary btn-sm">
<i class="fab fa-github me-1"></i>Open Source by Cyfinoid
</a>
</div>
</div>
<!-- Third Column: Company Information -->
<div class="col-md-4">
<h6 class="text-primary">About Cyfinoid Research</h6>
<p class="text-muted small mb-3">
Leading cybersecurity research company specializing in software supply chain security,
Android security, and cloud security. Our expertise spans across comprehensive software
supply chain protection.
</p>
</div>
</div>
<hr class="my-3">
<div class="text-center">
<small class="text-muted">
© 2025 Cyfinoid Research. All rights reserved. |
<a href="https://github.com/cyfinoid/sbomplay" target="_blank" class="text-muted">
<i class="fab fa-github me-1"></i>View on GitHub
</a>
</small>
</div>
</div>
</footer>
<!-- Scripts -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.bundle.min.js"></script>
<script src="js/github-client.js"></script>
<script src="js/sbom-processor.js"></script>
<script src="js/license-processor.js"></script>
<script src="js/osv-service.js"></script>
<script src="js/storage-manager.js"></script>
<script src="js/view-manager.js"></script>
<script src="js/app.js"></script>
<script src="js/settings.js"></script>
</body>
</html>