scanoss 0.8.2 → 0.8.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,1181 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+
4
+ <head>
5
+ <meta charset="UTF-8">
6
+ <meta http-equiv="X-UA-Compatible" content="IE=edge">
7
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
8
+ <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet"
9
+ integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3" crossorigin="anonymous">
10
+ <title>SCANOSS Detected Report</title>
11
+ </head>
12
+
13
+ <style>
14
+ @import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap');
15
+
16
+ :root {
17
+ --primary: #6366F1;
18
+ --dark: #18181B;
19
+ --bg-color: rgba(241, 245, 249, 1);
20
+ }
21
+
22
+ body {
23
+ max-width: 1200px;
24
+ margin: 0 auto;
25
+ background: var(--bg-color);
26
+ color: var(--dark);
27
+ font-family: 'Space Grotesk', sans-serif;
28
+ }
29
+
30
+
31
+ .nav-link {
32
+ display: none;
33
+ }
34
+
35
+ .nav-link.visible {
36
+ display: inline-block;
37
+ }
38
+
39
+ header {
40
+ display: flex;
41
+ flex-direction: column;
42
+ }
43
+
44
+ footer {
45
+ font-size: 12px;
46
+ color: gray;
47
+ }
48
+
49
+ .header-title {
50
+ display: flex;
51
+ flex-direction: row;
52
+ justify-content: space-between;
53
+ width: 100%;
54
+ margin-top: 15px;
55
+ margin-bottom: 16px;
56
+ }
57
+
58
+ .project-name-container {
59
+ display: flex;
60
+ justify-content: center;
61
+ align-items: center;
62
+ font-size: 48px;
63
+ }
64
+
65
+ .header-title img {
66
+ height: 55px;
67
+ }
68
+
69
+ h1,
70
+ h2,
71
+ h3,
72
+ h4,
73
+ h5 {
74
+ color: #656df1;
75
+ font-weight: 400;
76
+ }
77
+
78
+ .primary {
79
+ color: var(--primary) !important;
80
+ }
81
+
82
+ #date {
83
+ margin-top: 0;
84
+ color: darkgray;
85
+ font-size: 14px;
86
+ }
87
+
88
+ .divider {
89
+ border-bottom: 1px solid rgba(228, 228, 231, 1);
90
+ margin: 10px 0;
91
+ }
92
+
93
+ .divider.big {
94
+ margin: 25px 0;
95
+ }
96
+
97
+ .text-center {
98
+ text-align: center;
99
+ }
100
+
101
+ .main-container {
102
+ width: 100%;
103
+ }
104
+
105
+ .scan-summary {
106
+ display: flex;
107
+ justify-content: center;
108
+ gap: 15px;
109
+ }
110
+
111
+ .license-table-container {
112
+ width: 100%;
113
+ height: 700px;
114
+ display: flex;
115
+ flex-direction: row;
116
+ justify-content: center;
117
+ align-items: flex-start;
118
+ padding-left: 4%;
119
+ padding-right: 7%;
120
+ }
121
+
122
+ .pie-chart-container {
123
+ margin: 0 auto;
124
+ }
125
+
126
+
127
+ .incompatible-license-table td:first-child {
128
+ text-align: left;
129
+ font-size: 14px;
130
+ font-weight: 500;
131
+ line-height: 20px;
132
+ letter-spacing: 0em;
133
+ text-align: left;
134
+ color: var(--dark);
135
+ }
136
+
137
+ .incompatible-license-table th {
138
+ font-size: 18px;
139
+ font-weight: 400;
140
+ line-height: 23px;
141
+ color: #A1A1AA;
142
+ border-color: #E4E4E7;
143
+ }
144
+
145
+ .incompatible-license-table th:first-child {
146
+ text-align: left;
147
+ }
148
+
149
+ .table td,
150
+ .table th {
151
+ padding: 0.15rem;
152
+ text-align: center;
153
+ vertical-align: middle;
154
+ }
155
+
156
+ table {
157
+ width: 100%;
158
+ }
159
+
160
+ th {
161
+ font-size: 13px;
162
+ font-weight: bold;
163
+ }
164
+
165
+ tr {
166
+ font-size: 11px;
167
+ }
168
+
169
+ .color-reference {
170
+ width: 15px;
171
+ height: 15px;
172
+ display: block;
173
+ border-radius: 2px;
174
+ }
175
+
176
+
177
+ .table-striped tbody tr:nth-of-type(odd) {
178
+ background-color: rgb(105 101 101 / 5%);
179
+ }
180
+
181
+
182
+
183
+ .button-solid {
184
+ border: none;
185
+ background-color: transparent;
186
+ margin-right: 0;
187
+ padding: 10px 0 10px 10px;
188
+ color: #656df1;
189
+ font-size: 12px;
190
+ font-weight: 600;
191
+ line-height: 15px;
192
+ letter-spacing: 0em;
193
+ text-align: right;
194
+ }
195
+
196
+
197
+ .button-solid:focus,
198
+ #drop-down-license-detail-btn:focus {
199
+ border: none;
200
+ outline: none;
201
+ }
202
+
203
+ .hide {
204
+ display: none;
205
+ }
206
+
207
+
208
+ .label {
209
+ display: flex;
210
+ justify-content: left;
211
+ align-items: center;
212
+ width: 100%;
213
+ color: rgb(0 0 0 / 51%);
214
+ }
215
+
216
+ p {
217
+ margin-top: 0;
218
+ margin-bottom: 0;
219
+ text-align: left;
220
+ }
221
+
222
+ .drop-down-license-detail-container button {
223
+ display: flex;
224
+ justify-content: center;
225
+ width: 100%;
226
+ }
227
+
228
+ .license-info-detail {
229
+ display: flex;
230
+ justify-content: space-around;
231
+ width: 100%;
232
+ padding: 6px 0;
233
+ }
234
+
235
+ .license-ref {
236
+ width: 90%;
237
+ display: flex;
238
+ }
239
+
240
+ .license-component-button-container {
241
+ width: 40%;
242
+ display: flex;
243
+ align-items: center;
244
+ justify-content: flex-end;
245
+ }
246
+
247
+ .license-info-container {
248
+ display: flex;
249
+ width: 85%;
250
+ }
251
+
252
+ .color-reference-container {
253
+ width: 14%;
254
+ align-items: center;
255
+ justify-content: center;
256
+ display: flex;
257
+ }
258
+
259
+ .info-container {
260
+ display: flex;
261
+ justify-content: center;
262
+ align-items: center;
263
+ width: 85%;
264
+ height: 30px;
265
+ }
266
+
267
+ .info {
268
+ display: flex;
269
+ flex-direction: column;
270
+ width: 100%;
271
+ }
272
+
273
+ .info.big {
274
+ width: auto;
275
+ margin: 0 15px;
276
+ }
277
+
278
+ .info.big .label {
279
+ font-weight: 400;
280
+ font-size: 20px;
281
+ color: rgb(113, 113, 122);
282
+ justify-content: center;
283
+ }
284
+
285
+ .info.big .value {
286
+ font-weight: 600;
287
+ font-size: 64px;
288
+ line-height: 64px;
289
+ justify-content: center;
290
+ }
291
+
292
+ .info .label {
293
+ display: flex;
294
+ justify-content: flex-start;
295
+ width: 100%;
296
+ }
297
+
298
+ .info .value {
299
+ display: flex;
300
+ justify-content: flex-start;
301
+ text-align: left;
302
+ width: 100%;
303
+ color: rgb(24, 24, 27);
304
+ font-size: 16px;
305
+ font-weight: 500;
306
+ line-height: 26px;
307
+
308
+ }
309
+
310
+ .info .value.small {
311
+ font-size: 16px;
312
+ font-weight: 400;
313
+ line-height: 20px;
314
+ color: rgb(24, 24, 27)
315
+ }
316
+
317
+ .row-license-info-container {
318
+ display: flex;
319
+ width: 100%;
320
+ }
321
+
322
+ td.cell-info-container {
323
+ width: 30%;
324
+ display: flex;
325
+ }
326
+
327
+ td.cell-info-container:last-child {
328
+ justify-content: right;
329
+ }
330
+
331
+ td.cell-info-container:last-child {
332
+ justify-content: right;
333
+ }
334
+
335
+ td.cell-info-container.index {
336
+ width: 10%;
337
+
338
+ }
339
+
340
+ .row-info-container {
341
+ display: flex;
342
+ justify-content: center;
343
+ align-items: center;
344
+ }
345
+
346
+ .detected-license-report-table-container,
347
+ .incompatibilities-table-container {
348
+ margin: 0px;
349
+ }
350
+
351
+ .incompatible-license-container {
352
+ margin: 10px 0;
353
+ min-height: 20px;
354
+ align-items: center;
355
+ }
356
+
357
+ .license-block {
358
+ margin: 2px;
359
+ font-size: 12px;
360
+ background-color: #dfdedd;
361
+ display: flex;
362
+ flex-flow: wrap;
363
+ justify-content: center;
364
+ align-items: center;
365
+ padding: 5px;
366
+ border-radius: 3px;
367
+ font-weight: bold;
368
+
369
+ -webkit-print-color-adjust: exact !important;
370
+
371
+ }
372
+
373
+ .incompatible-license-container {
374
+ display: flex;
375
+ flex-flow: wrap;
376
+ flex-direction: row;
377
+ }
378
+
379
+ #incompatible-license {
380
+ vertical-align: baseline;
381
+ border-top: 1px solid #fafafa;
382
+ }
383
+
384
+ .incompatible-ref {
385
+ background-color: #dc3545;
386
+ color: white;
387
+ -webkit-print-color-adjust: exact !important;
388
+ }
389
+
390
+ table.main-table>thead {
391
+ position: sticky;
392
+ top: 0;
393
+ background: var(--bg-color);
394
+ }
395
+
396
+ table.main-table td,
397
+ table.main-table th {
398
+ text-align: left;
399
+ }
400
+
401
+ .table.main-table>:not(:first-child) {
402
+ border-top: 0 !important;
403
+ }
404
+
405
+ table.main-table th {
406
+ padding: .5rem;
407
+ font-size: 18px;
408
+ font-weight: 400;
409
+ line-height: 23px;
410
+ color: #A1A1AA;
411
+ border-color: #E4E4E7;
412
+ }
413
+
414
+
415
+ table.main-table td {
416
+ padding: .5rem;
417
+ vertical-align: top;
418
+ font-size: 14px;
419
+ font-weight: 400;
420
+ line-height: 20px;
421
+ letter-spacing: 0em;
422
+ text-align: left;
423
+ color: var(--dark);
424
+ }
425
+
426
+ table.main-table tr.subheader {
427
+ position: sticky;
428
+ top: 36px;
429
+ }
430
+
431
+ table.main-table tr.subheader td {
432
+ background-color: #efeff5;
433
+ font-size: 12px;
434
+ font-weight: 600;
435
+ color: rgb(40, 40, 43)
436
+ }
437
+
438
+ table.main-table td:first-child {
439
+ font-weight: 600;
440
+ }
441
+ </style>
442
+
443
+ <body>
444
+ <header>
445
+ <div class="header-title">
446
+ <img
447
+ src="">
448
+ <div>
449
+ <h5>Detected Report</h5>
450
+ <h5 id="date"></h5>
451
+ </div>
452
+ </div>
453
+ <section class="project-name-container">
454
+ <h1 id='project-name'></h1>
455
+ </section>
456
+ <div class="divider mt-3 mb-5"></div>
457
+
458
+ <div class="scan-summary"></div>
459
+
460
+ <div class="divider mt-5"></div>
461
+ </header>
462
+
463
+
464
+ <nav>
465
+ <div class="nav nav-pills d-flex justify-content-center mb-5" id="nav-tab" role="tablist">
466
+ <button class="nav-link active" id="nav-licenses-tab" data-bs-toggle="tab" data-bs-target="#nav-licenses"
467
+ type="button" role="tab" aria-controls="nav-licenses" aria-selected="true">Licenses</button>
468
+ <button class="nav-link" id="nav-components-tab" data-bs-toggle="tab" data-bs-target="#nav-components"
469
+ type="button" role="tab" aria-controls="nav-components" aria-selected="false">Components</button>
470
+ <button class="nav-link" id="nav-vulnerabilities-tab" data-bs-toggle="tab" data-bs-target="#nav-vulnerabilities"
471
+ type="button" role="tab" aria-controls="nav-vulnerabilities" aria-selected="false">Vulnerabilities</button>
472
+ <button class="nav-link" id="nav-dependencies-tab" data-bs-toggle="tab" data-bs-target="#nav-dependencies"
473
+ type="button" role="tab" aria-controls="nav-dependencies" aria-selected="false">Dependencies</button>
474
+ <button class="nav-link" id="nav-copyrights-tab" data-bs-toggle="tab" data-bs-target="#nav-copyrights"
475
+ type="button" role="tab" aria-controls="nav-copyrights" aria-selected="false">Copyrights</button>
476
+ <button class="nav-link" id="nav-cryptography-tab" data-bs-toggle="tab" data-bs-target="#nav-cryptography"
477
+ type="button" role="tab" aria-controls="nav-cryptography" aria-selected="false">Cryptography</button>
478
+ <button class="nav-link" id="nav-quality-tab" data-bs-toggle="tab" data-bs-target="#nav-quality"
479
+ type="button" role="tab" aria-controls="nav-quality" aria-selected="false">Quality</button>
480
+ <button class="nav-link" id="nav-health-tab" data-bs-toggle="tab" data-bs-target="#nav-health"
481
+ type="button" role="tab" aria-controls="nav-health" aria-selected="false">Health</button>
482
+ <button class="nav-link" id="nav-summary-tab" data-bs-toggle="tab" data-bs-target="#nav-summary" type="button"
483
+ role="tab" aria-controls="nav-summary" aria-selected="false">Summary</button>
484
+ </div>
485
+ </nav>
486
+
487
+
488
+ <main class="main-container">
489
+
490
+ <div class="tab-content" id="nav-tabContent">
491
+
492
+ <!-- licenses -->
493
+ <div class="tab-pane fade show active" id="nav-licenses" role="tabpanel" aria-labelledby="nav-licenses-tab"
494
+ tabindex="0">
495
+ <section class="mt-5">
496
+ <div class="pie-chart-container">
497
+ <div>
498
+ <canvas id="myChart"></canvas>
499
+ </div>
500
+ </div>
501
+ </section>
502
+ <section class="mt-5">
503
+ <div class="detected-license-report-table-container">
504
+ <table class="table">
505
+ <tbody id="body-license-detail-table">
506
+ </tbody>
507
+ </table>
508
+ </div>
509
+ </section>
510
+ <section class="mt-5">
511
+ <h4>License obligations</h4>
512
+ <div class="incompatibilities-table-container">
513
+ <table class="table incompatible-license-table main-table">
514
+ <thead>
515
+ <tr>
516
+ <th>License</th>
517
+ <th>Copyleft</th>
518
+ <th>Incompatible Licenses</th>
519
+ </tr>
520
+ </thead>
521
+ <tbody id="incompatible-license">
522
+ </tbody>
523
+ </table>
524
+ </div>
525
+ </section>
526
+ </div>
527
+
528
+ <!-- components -->
529
+ <section class="tab-pane fade" id="nav-components" role="tabpanel" aria-labelledby="nav-components-tab"
530
+ tabindex="0">
531
+ <table id="table-components" class="table main-table">
532
+ <thead>
533
+ <tr>
534
+ <th>Component</th>
535
+ <th>PURL</th>
536
+ <th>Detected Versions</th>
537
+ <th>URL</th>
538
+ </tr>
539
+ </thead>
540
+ <tbody>
541
+ </tbody>
542
+ </table>
543
+
544
+ <template id="tpl-component-row">
545
+ <tr>
546
+ <td></td>
547
+ <td></td>
548
+ <td></td>
549
+ <td></td>
550
+ </tr>
551
+ </template>
552
+ </section>
553
+
554
+ <!-- vulnerabilities -->
555
+ <section class="tab-pane fade" id="nav-vulnerabilities" role="tabpanel" aria-labelledby="nav-vulnerabilities-tab"
556
+ tabindex="0">
557
+ <table id="table-vulnerabilities" class="table main-table">
558
+ <thead>
559
+ <tr>
560
+ <th>Component</th>
561
+ <th>Version</th>
562
+ <th>CVE</th>
563
+ <th>Severity</th>
564
+ <th>Published</th>
565
+ <th>Patched</th>
566
+ <th>Summary</th>
567
+ </tr>
568
+ </thead>
569
+ <tbody>
570
+ </tbody>
571
+ </table>
572
+
573
+ <template id="tpl-vulnerabilities-row">
574
+ <tr>
575
+ <td></td>
576
+ <td></td>
577
+ <td></td>
578
+ <td></td>
579
+ <td></td>
580
+ <td></td>
581
+ <td></td>
582
+ </tr>
583
+ </template>
584
+ </section>
585
+
586
+ <!-- dependencies -->
587
+ <section class="tab-pane fade" id="nav-dependencies" role="tabpanel" aria-labelledby="nav-dependencies-tab"
588
+ tabindex="0">
589
+ <table id="table-dependencies" class="table main-table">
590
+ <thead>
591
+ <tr>
592
+ <th>Dependency</th>
593
+ <th>PURL</th>
594
+ <th>Version</th>
595
+ <th>License</th>
596
+ </tr>
597
+ </thead>
598
+ <tbody>
599
+ </tbody>
600
+ </table>
601
+
602
+ <template id="tpl-dependencies-row">
603
+ <tr>
604
+ <td></td>
605
+ <td></td>
606
+ <td></td>
607
+ <td></td>
608
+ </tr>
609
+ </template>
610
+ </section>
611
+
612
+ <!-- copyright -->
613
+ <section class="tab-pane fade" id="nav-copyrights" role="tabpanel" aria-labelledby="nav-copyrights-tab"
614
+ tabindex="0">
615
+ <table id="table-copyrights" class="table main-table">
616
+ <thead>
617
+ <tr>
618
+ <th>Component</th>
619
+ <th>Version</th>
620
+ <th>Copyright</th>
621
+ </tr>
622
+ </thead>
623
+ <tbody>
624
+ </tbody>
625
+ </table>
626
+
627
+ <template id="tpl-copyrights-row">
628
+ <tr>
629
+ <td></td>
630
+ <td></td>
631
+ <td></td>
632
+ </tr>
633
+ </template>
634
+ </section>
635
+
636
+ <!-- cryptography -->
637
+ <section class="tab-pane fade" id="nav-cryptography" role="tabpanel" aria-labelledby="nav-cryptography-tab"
638
+ tabindex="0">
639
+ <table id="table-cryptography" class="table main-table">
640
+ <thead>
641
+ <tr>
642
+ <th>Component</th>
643
+ <th>Version</th>
644
+ <th>Cryptography</th>
645
+ </tr>
646
+ </thead>
647
+ <tbody>
648
+ </tbody>
649
+ </table>
650
+
651
+ <template id="tpl-cryptography-row">
652
+ <tr>
653
+ <td></td>
654
+ <td></td>
655
+ <td></td>
656
+ </tr>
657
+ </template>
658
+ </section>
659
+
660
+ <!-- quality -->
661
+ <section class="tab-pane fade" id="nav-quality" role="tabpanel" aria-labelledby="nav-quality-tab"
662
+ tabindex="0">
663
+ <table id="table-quality" class="table main-table">
664
+ <thead>
665
+ <tr>
666
+ <th>Component</th>
667
+ <th>Version</th>
668
+ <th>Quality</th>
669
+ </tr>
670
+ </thead>
671
+ <tbody>
672
+ </tbody>
673
+ </table>
674
+
675
+ <template id="tpl-quality-row">
676
+ <tr>
677
+ <td></td>
678
+ <td></td>
679
+ <td></td>
680
+ </tr>
681
+ </template>
682
+ </section>
683
+
684
+ <!-- health -->
685
+ <section class="tab-pane fade" id="nav-health" role="tabpanel" aria-labelledby="nav-health-tab"
686
+ tabindex="0">
687
+ <table id="table-health" class="table main-table">
688
+ <thead>
689
+ <tr>
690
+ <th>Component</th>
691
+ <th>PURL</th>
692
+ <th>Creation Date</th>
693
+ <th>Issues</th>
694
+ <th>Last Push</th>
695
+ <th>Last Update</th>
696
+ <th>Watchers</th>
697
+ <th>Country</th>
698
+ <th>Forks</th>
699
+ </tr>
700
+ </thead>
701
+ <tbody>
702
+ </tbody>
703
+ </table>
704
+
705
+ <template id="tpl-health-row">
706
+ <tr>
707
+ <td></td>
708
+ <td></td>
709
+ <td></td>
710
+ <td></td>
711
+ <td></td>
712
+ <td></td>
713
+ <td></td>
714
+ <td></td>
715
+ <td></td>
716
+ </tr>
717
+ </template>
718
+ </section>
719
+
720
+ <!-- summary -->
721
+ <div class="tab-pane fade" id="nav-summary" role="tabpanel" aria-labelledby="nav-summary-tab" tabindex="0">
722
+ SUMMARY
723
+ </div>
724
+ </div>
725
+ </main>
726
+
727
+ <div class="divider mt-5"></div>
728
+
729
+ <footer class="mb-2 text-center">
730
+ <p class="text-center">Reported generated by <a href="https://github.com/scanoss/scanoss.js"
731
+ target="_blank">scanoss.js</a></p>
732
+ <p class="text-center"><a href="https://www.scanoss.com" target="_blank">www.scanoss.com</a></p>
733
+ </footer>
734
+
735
+ <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.1/dist/js/bootstrap.bundle.min.js"
736
+ integrity="sha384-u1OknCvxWvY5kfmNBILK2hRnQC3Pr17a+RTT6rIHI7NnikvbZlHgTPOOmMi466C8"
737
+ crossorigin="anonymous"></script>
738
+ <script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
739
+ <script>
740
+ addEventListener('DOMContentLoaded', (event) => {
741
+ const entryData = '#DATA';
742
+ const data = JSON.parse(entryData);
743
+ let pieChartDataEntry = {
744
+ labels: [],
745
+ components: []
746
+ };
747
+
748
+ data.licenses.forEach((l) => {
749
+ pieChartDataEntry.labels.push(l.label);
750
+ pieChartDataEntry.components.push(l.value);
751
+ });
752
+
753
+ const color = [
754
+ '#E8B34B',
755
+ '#E22C2C',
756
+ '#5754D0',
757
+ '#9F69C0',
758
+ '#FE7F10',
759
+ '#E56399',
760
+ '#E637BF',
761
+ '#474647',
762
+ '#153243',
763
+ '#2DE1C2',
764
+ '#F05365',
765
+ '#A2D729',
766
+ '#3C91E6',
767
+ '#FA824C',
768
+ '#C94277',
769
+ '#E56B6F',
770
+ '#F71735',
771
+ '#011627',
772
+ '#724E91',
773
+ '#7D451B',
774
+ '#9BE564',
775
+ ];
776
+
777
+ function init() {
778
+
779
+ setupNavigation();
780
+
781
+ renderHeader();
782
+ renderLicensesTable();
783
+ renderComponentTable();
784
+ renderDependenciesTable();
785
+ renderVulnerabilitiesTable();
786
+ renderCopyrightTable();
787
+ renderCryptographyTable();
788
+ renderQualityTable();
789
+ renderHealthTable();
790
+ }
791
+
792
+ init();
793
+
794
+ function setupNavigation(componentList) {
795
+ const showTab = (id) => document.querySelector('.nav-link#' + id).classList.add('visible');
796
+
797
+ const existVersionKey = (key, componentList) => {
798
+ for (const component of componentList) {
799
+ for (const version of component.versions) {
800
+ if (version && version[key]) return true;
801
+ }
802
+ }
803
+ return false;
804
+ };
805
+
806
+
807
+ const existComponentKey = (key, componentList) => {
808
+ for (const component of componentList) {
809
+ if (component[key]) return true;
810
+ }
811
+ return false;
812
+ };
813
+
814
+
815
+ if (data.licenses) showTab('nav-licenses-tab');
816
+ if (data.component) showTab('nav-components-tab');
817
+ if (data.dependencies) showTab('nav-dependencies-tab');
818
+ if (data.vulnerabilities) showTab('nav-vulnerabilities-tab');
819
+ if (existVersionKey('copyrights', data.component)) showTab('nav-copyrights-tab');
820
+ if (existVersionKey('cryptography', data.component)) showTab('nav-cryptography-tab');
821
+ if (existVersionKey('quality', data.component)) showTab('nav-quality-tab');
822
+ if (existComponentKey('health', data.component)) showTab('nav-health-tab');
823
+ }
824
+
825
+ function renderHeader() {
826
+
827
+ // date
828
+ const d = document.querySelector('#date');
829
+ d.innerHTML += new Date(data.summary.timestamp).toLocaleDateString();
830
+
831
+ // project name
832
+ const p = document.querySelector('#project-name');
833
+ p.innerHTML += data.summary.projectName ? data.summary.projectName : '-';
834
+
835
+
836
+ // summary
837
+ const s = document.querySelector('.scan-summary');
838
+ s.innerHTML += `
839
+ <div class="info big">
840
+ <div class="value primary">${data.summary.totalFiles}</div>
841
+ <div class="label">Files Scanned</div>
842
+ </div>
843
+ <div class="info big">
844
+ <div class="value">${data.summary.matchedFiles}</div>
845
+ <div class="label">Matched</div>
846
+ </div>
847
+ <div class="info big">
848
+ <div class="value">${data.summary.noMatchFiles}</div>
849
+ <div class="label">No Matches</div>
850
+ </div>
851
+ `;
852
+ }
853
+
854
+ function renderLicensesTable() {
855
+
856
+ function dropDown(id) {
857
+ const nodes = document.getElementsByClassName(id);
858
+ for (let i = 0; i < nodes.length; i += 1) {
859
+ if (nodes[i].classList.contains('hide')) {
860
+ nodes[i].classList.remove('hide');
861
+ nodes[i].classList.add('show');
862
+ } else {
863
+ nodes[i].classList.remove('show');
864
+ nodes[i].classList.add('hide');
865
+ }
866
+ }
867
+ }
868
+
869
+ function addButtonListener() {
870
+ const btn = document.querySelectorAll('.button-solid');
871
+ btn.forEach((button) => {
872
+ button.addEventListener('click', (event) => {
873
+ dropDown(event.target.id);
874
+ });
875
+ });
876
+ }
877
+
878
+ function pieChart() {
879
+ const data = {
880
+ labels: pieChartDataEntry.labels,
881
+ datasets: [
882
+ {
883
+ backgroundColor: color,
884
+ borderColor: 'rgb(255, 255, 255)',
885
+ data: pieChartDataEntry.components,
886
+ },
887
+ ],
888
+ };
889
+ const config = {
890
+ type: 'doughnut',
891
+ data,
892
+ options: {
893
+ responsive: true,
894
+ maintainAspectRatio: false,
895
+ elements: {
896
+ arc: {
897
+ borderWidth: 1,
898
+ },
899
+ },
900
+ plugins: {
901
+ legend: {
902
+ display: true,
903
+ position: 'right',
904
+ },
905
+ },
906
+ },
907
+ };
908
+ const myChart = new Chart(document.getElementById('myChart'), config);
909
+ }
910
+
911
+ function licenseDetail() {
912
+ const body = document.querySelector('#body-license-detail-table');
913
+ data.licenses.forEach((l, index) => {
914
+ body.innerHTML += `
915
+ <tr>
916
+ <td>
917
+ <div class="license-info-detail">
918
+ <div class="license-ref">
919
+ <div class="license-info-container">
920
+ <div class="info-container">
921
+ <div class="info">
922
+ <div class="label">
923
+ License
924
+ </div>
925
+ <div class="value">
926
+ ${l.label}
927
+ </div>
928
+ </div>
929
+ </div>
930
+ </div>
931
+ </div>
932
+ <div class="license-component-button-container">
933
+ <button class="button-solid" id="${l.label}"> ${l.value} component found &#x25BC</button>
934
+ </div>
935
+ </div>
936
+ </td>
937
+ </tr>`;
938
+
939
+ body.innerHTML += `<tr class="${l.label} hide">
940
+ <td colspan="2">
941
+ <table>
942
+ ${l.components.map((c, index) => {
943
+ return `<tr class="row-license-info-container">
944
+ <td class="cell-info-container index">
945
+ <div class="row-info-container">
946
+ <div class="info">
947
+ <div class="value small">
948
+ ${index + 1}
949
+ </div>
950
+ </div>
951
+ </div>
952
+ </td>
953
+ <td class="cell-info-container">
954
+ <div class="row-info-container">
955
+ <div class="info">
956
+ <div class="label">
957
+ Component
958
+ </div>
959
+ <div class="value small">
960
+ ${c.name}
961
+ </div>
962
+ </div>
963
+ </div>
964
+ </td>
965
+ <td class="cell-info-container">
966
+ <div class="row-info-container">
967
+ <div class="info">
968
+ <div class="label">
969
+ Purl
970
+ </div>
971
+ <div class="value small">
972
+ ${decodeURIComponent(c.purl)}
973
+ </div>
974
+ </div>
975
+ </div>
976
+ </td>
977
+ <td class="cell-info-container">
978
+ <div class="row-info-container">
979
+ <div class="info">
980
+ <div class="label">
981
+ ${c.versions.length > 1 ? 'Versions' : 'Version'}
982
+ </div>
983
+ <div class="value small">
984
+ ${c.versions.toString()}
985
+ </div>
986
+ </div>
987
+ </div>
988
+ </td>
989
+ </tr>`
990
+ }).join(' ')}
991
+ </table>
992
+ </td>
993
+ </tr>`;
994
+ });
995
+
996
+ addButtonListener();
997
+ }
998
+
999
+ function incompatibleLicenses() {
1000
+ const licenseMapper = new Set();
1001
+ data.licenses.forEach((l) => licenseMapper.add(l.label));
1002
+ const body = document.querySelector('#incompatible-license');
1003
+ data.licenses.forEach((l) => {
1004
+ body.innerHTML += `
1005
+ <tr>
1006
+ <td>${l.label}</td>
1007
+ <td>${l.copyleft === true ? '&#10004' : '&#10006'}</td>
1008
+ <td><div class="incompatible-license-container">${l.incompatibleWith.map((i) => {
1009
+ return `<div class="license-block ${licenseMapper.has(i) === true ? 'incompatible-ref' : ''}">
1010
+ <p>${i}</p>
1011
+ </div>`;
1012
+ }).join(' ')}</div></td>
1013
+ </tr>`;
1014
+ });
1015
+ }
1016
+
1017
+ pieChart();
1018
+ licenseDetail();
1019
+ incompatibleLicenses()
1020
+
1021
+ }
1022
+
1023
+ function renderComponentTable() {
1024
+ const template = document.querySelector("#tpl-component-row");
1025
+ const table = document.querySelector("#table-components tbody");
1026
+
1027
+ const { component: componentData } = data;
1028
+
1029
+ if (!componentData) return false;
1030
+
1031
+ for (const component of componentData) {
1032
+ const clon = template.content.cloneNode(true);
1033
+ clon.querySelector('td:nth-child(1)').innerHTML = component.name;
1034
+ clon.querySelector('td:nth-child(2)').innerHTML = decodeURIComponent(component.key);
1035
+ clon.querySelector('td:nth-child(3)').innerHTML = component.versions?.map(item => item.version).join(', ');
1036
+ clon.querySelector('td:nth-child(4)').innerHTML = component.url ? `<a href="${component.url}" target="_blank">${decodeURIComponent(component.url)}</a>` : '-';
1037
+ table.appendChild(clon);
1038
+ }
1039
+ }
1040
+
1041
+ function renderDependenciesTable() {
1042
+ const template = document.querySelector("#tpl-dependencies-row");
1043
+ const table = document.querySelector("#table-dependencies tbody");
1044
+
1045
+ const { dependencies: dependencyData } = data;
1046
+
1047
+ if (!dependencyData) return false;
1048
+
1049
+ for (const depData of dependencyData) {
1050
+ table.innerHTML += `<tr class="subheader"> <td colspan='4'> ${depData.dependencies?.length} ${depData.dependencies?.length == 1 ? 'dependency' : 'dependencies'} found in <span class="primary">${depData.file}</span> </td> </tr>`;
1051
+ for (const dependency of depData.dependencies) {
1052
+ const clon = template.content.cloneNode(true);
1053
+ clon.querySelector('td:nth-child(1)').innerHTML = dependency.component || '-';
1054
+ clon.querySelector('td:nth-child(2)').innerHTML = decodeURIComponent(dependency.purl);
1055
+ clon.querySelector('td:nth-child(3)').innerHTML = dependency.version;
1056
+ clon.querySelector('td:nth-child(4)').innerHTML = dependency.licenses?.map(item => item.name).join(', ');
1057
+ table.appendChild(clon);
1058
+ }
1059
+ }
1060
+ };
1061
+
1062
+ function renderVulnerabilitiesTable() {
1063
+ const template = document.querySelector("#tpl-vulnerabilities-row");
1064
+ const table = document.querySelector("#table-vulnerabilities tbody");
1065
+
1066
+ const { vulnerabilities: vulnerabilityData } = data;
1067
+
1068
+ if (!vulnerabilityData) return false;
1069
+
1070
+ for (const purlVulData of vulnerabilityData) {
1071
+ for (const vulnerabilty of purlVulData.vulnerability) {
1072
+ const clon = template.content.cloneNode(true);
1073
+ clon.querySelector('td:nth-child(1)').innerHTML = decodeURIComponent(purlVulData.purl);
1074
+ clon.querySelector('td:nth-child(2)').innerHTML = "-";
1075
+ clon.querySelector('td:nth-child(3)').innerHTML = vulnerabilty.cve;
1076
+ clon.querySelector('td:nth-child(4)').innerHTML = vulnerabilty.severity;
1077
+ clon.querySelector('td:nth-child(5)').innerHTML = vulnerabilty.published;
1078
+ clon.querySelector('td:nth-child(6)').innerHTML = vulnerabilty.modified;
1079
+ clon.querySelector('td:nth-child(7)').innerHTML = vulnerabilty.summary;
1080
+ table.appendChild(clon);
1081
+ }
1082
+
1083
+ }
1084
+ }
1085
+
1086
+
1087
+ function renderCopyrightTable() {
1088
+ const template = document.querySelector("#tpl-copyrights-row");
1089
+ const table = document.querySelector("#table-copyrights tbody");
1090
+
1091
+ const { component: componentData } = data;
1092
+
1093
+ if (!componentData) return false;
1094
+
1095
+ for (const compData of componentData) {
1096
+ for (const version of compData.versions) {
1097
+ if (!version.copyrights) continue
1098
+ const clon = template.content.cloneNode(true);
1099
+ clon.querySelector('td:nth-child(1)').innerHTML = compData.name;
1100
+ clon.querySelector('td:nth-child(2)').innerHTML = version.version;
1101
+ clon.querySelector('td:nth-child(3)').innerHTML = version.copyrights?.map(item => item.name).join(' - ');
1102
+
1103
+ table.appendChild(clon);
1104
+ }
1105
+ }
1106
+ }
1107
+
1108
+ function renderCryptographyTable() {
1109
+ const template = document.querySelector("#tpl-cryptography-row");
1110
+ const table = document.querySelector("#table-cryptography tbody");
1111
+
1112
+ const { component: componentData } = data;
1113
+
1114
+ if (!componentData) return false;
1115
+
1116
+ for (const compData of componentData) {
1117
+ for (const version of compData.versions) {
1118
+ if (!version.cryptography) continue
1119
+ const clon = template.content.cloneNode(true);
1120
+ clon.querySelector('td:nth-child(1)').innerHTML = compData.name;
1121
+ clon.querySelector('td:nth-child(2)').innerHTML = version.version;
1122
+ clon.querySelector('td:nth-child(3)').innerHTML = version.cryptography.map(e => `${e.algorithm} (${e.strength})`).join('');
1123
+
1124
+ table.appendChild(clon);
1125
+ }
1126
+ }
1127
+ }
1128
+
1129
+ function renderQualityTable() {
1130
+ const template = document.querySelector("#tpl-quality-row");
1131
+ const table = document.querySelector("#table-quality tbody");
1132
+
1133
+ const { component: componentData } = data;
1134
+
1135
+ if (!componentData) return false;
1136
+
1137
+ for (const compData of componentData) {
1138
+ for (const version of compData.versions) {
1139
+ if (!version.quality) continue
1140
+ const clon = template.content.cloneNode(true);
1141
+ clon.querySelector('td:nth-child(1)').innerHTML = compData.name;
1142
+ clon.querySelector('td:nth-child(2)').innerHTML = version.version;
1143
+ clon.querySelector('td:nth-child(3)').innerHTML = version.quality.scoreAvg + "/5";
1144
+
1145
+ table.appendChild(clon);
1146
+ }
1147
+ }
1148
+ }
1149
+
1150
+ function renderHealthTable() {
1151
+ const template = document.querySelector("#tpl-health-row");
1152
+ const table = document.querySelector("#table-health tbody");
1153
+
1154
+ const { component: componentData } = data;
1155
+
1156
+ if (!componentData) return false;
1157
+
1158
+ for (const compData of componentData) {
1159
+ if (!compData.health) continue
1160
+ const clon = template.content.cloneNode(true);
1161
+ clon.querySelector('td:nth-child(1)').innerHTML = compData.name;
1162
+ clon.querySelector('td:nth-child(2)').innerHTML = compData.key;
1163
+ clon.querySelector('td:nth-child(3)').innerHTML = compData.health.creation_date || '-';
1164
+ clon.querySelector('td:nth-child(4)').innerHTML = compData.health.issues || '-';
1165
+ clon.querySelector('td:nth-child(5)').innerHTML = compData.health.last_push || '-';
1166
+ clon.querySelector('td:nth-child(6)').innerHTML = compData.health.last_update || '-';
1167
+ clon.querySelector('td:nth-child(7)').innerHTML = compData.health.watchers || '-';
1168
+ clon.querySelector('td:nth-child(8)').innerHTML = compData.health.country || '-';
1169
+ clon.querySelector('td:nth-child(9)').innerHTML = compData.health.forks || '-';
1170
+
1171
+ table.appendChild(clon);
1172
+ }
1173
+ }
1174
+ });
1175
+ </script>
1176
+
1177
+
1178
+
1179
+ </body>
1180
+
1181
+ </html>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "scanoss",
3
- "version": "0.8.2",
3
+ "version": "0.8.3",
4
4
  "description": "The SCANOSS JS package provides a simple, easy to consume module for interacting with SCANOSS APIs/Engine.",
5
5
  "main": "build/main/index.js",
6
6
  "typings": "build/main/index.d.ts",
@@ -76,6 +76,7 @@
76
76
  "files": [
77
77
  "build/main",
78
78
  "build/module",
79
+ "assets/",
79
80
  "!**/*.spec.*",
80
81
  "!**/*.json",
81
82
  "CHANGELOG.md",