-
-
Notifications
You must be signed in to change notification settings - Fork 733
Expand file tree
/
Copy pathbower.py
More file actions
109 lines (92 loc) · 3.78 KB
/
bower.py
File metadata and controls
109 lines (92 loc) · 3.78 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
#
# Copyright (c) nexB Inc. and others. All rights reserved.
# ScanCode is a trademark of nexB Inc.
# SPDX-License-Identifier: Apache-2.0
# See http://www.apache.org/licenses/LICENSE-2.0 for the license text.
# See https://github.com/nexB/scancode-toolkit for support or download.
# See https://aboutcode.org for more information about nexB OSS projects.
#
import io
import json
from packageurl import PackageURL
from packagedcode import models
# TODO: handle complex cases of npms and bower combined
class BowerJsonHandler(models.DatafileHandler):
datasource_id = 'bower_json'
path_patterns = ('*/bower.json', '*/.bower.json',)
default_package_type = 'bower'
default_primary_language = 'JavaScript'
description = 'Bower package'
documentation_url = 'https://bower.io'
@classmethod
def parse(cls, location, purl_only=False):
with io.open(location, encoding='utf-8') as loc:
package_data = json.load(loc)
# note: having no name is not a problem for private packages. See #1514
name = package_data.get('name')
version = package_data.get('version')
deps = package_data.get('dependencies') or {}
dependencies = []
for dep_name, requirement in deps.items():
dependencies.append(
models.DependentPackage(
purl=PackageURL(type='bower', name=dep_name).to_string(),
scope='dependencies',
extracted_requirement=requirement,
is_runtime=True,
is_optional=False,
)
)
dev_dependencies = package_data.get('devDependencies') or {}
for dep_name, requirement in dev_dependencies.items():
dependencies.append(
models.DependentPackage(
purl=PackageURL(type='bower', name=dep_name).to_string(),
scope='devDependencies',
extracted_requirement=requirement,
is_runtime=False,
is_optional=True,
)
)
pkg = models.PackageData(
datasource_id=cls.datasource_id,
type=cls.default_package_type,
name=name,
version=version,
dependencies=dependencies,
)
if purl_only:
yield pkg
return
description = package_data.get('description')
extracted_license_statement = package_data.get('license')
keywords = package_data.get('keywords') or []
parties = []
authors = package_data.get('authors') or []
for author in authors:
if isinstance(author, dict):
name = author.get('name')
email = author.get('email')
url = author.get('homepage')
party = models.Party(name=name, role='author', email=email, url=url)
parties.append(party)
elif isinstance(author, str):
parties.append(models.Party(name=author, role='author'))
else:
parties.append(models.Party(name=repr(author), role='author'))
homepage_url = package_data.get('homepage')
repository = package_data.get('repository') or {}
repo_type = repository.get('type')
repo_url = repository.get('url')
vcs_url = None
if repo_type and repo_url:
vcs_url = f'{repo_type}+{repo_url}'
pkg.description = description
pkg.primary_language = BowerJsonHandler.default_primary_language
pkg.extracted_license_statement = extracted_license_statement
pkg.keywords = keywords
pkg.parties = parties
pkg.homepage_url = homepage_url
pkg.vcs_url = vcs_url
pkg.populate_license_fields()
yield pkg