swh.loader.package.npm.loader module#

class swh.loader.package.npm.loader.NpmPackageInfo(url: str, filename: str | None, version: str, raw_info: Dict[str, Any], package_name: str, date: str | None, shasum: str, *, directory_extrinsic_metadata: List[RawExtrinsicMetadataCore] = [], checksums: Dict[str, str] = {})[source]#

Bases: BasePackageInfo

Method generated by attrs for class NpmPackageInfo.

shasum#

sha1 checksum

MANIFEST_FORMAT: Template | None = <string.Template object>#

If not None, used by the default extid() implementation to format a manifest, before hashing it to produce an ExtID.

EXTID_TYPE: str = 'npm-manifest-sha256'#
EXTID_VERSION: int = 0#
classmethod from_metadata(project_metadata: Dict[str, Any], version: str) NpmPackageInfo[source]#
class swh.loader.package.npm.loader.NpmLoader(storage: StorageInterface, url: str, **kwargs: Any)[source]#

Bases: PackageLoader[NpmPackageInfo]

Load npm origin’s artifact releases into swh archive.

Constructor

Args

str: origin url (e.g. https://www.npmjs.com/package/<package-name>)

visit_type: str = 'npm'#
info() Dict[source]#

Return the project metadata information (fetched from npm registry)

get_versions() Sequence[str][source]#

Return the list of all published package versions.

There is no need to sort that list, it is handled by get_sorted_versions().

Raises:

classswh.loader.exception.NotFound error when failing to read the published package versions.

Returns:

Sequence of published versions

get_default_version() str[source]#

Retrieve the latest release version if any.

Default implementation returns the last element from the list returned by get_sorted_versions().

Returns:

Latest version

get_metadata_authority()[source]#

For package loaders that get extrinsic metadata, returns the authority the metadata are coming from.

get_package_info(version: str) Iterator[Tuple[str, NpmPackageInfo]][source]#
Given a release version of a package, retrieve the associated

package information for such version.

Parameters:

version – Package version

Returns:

(branch name, package metadata)

build_release(p_info: NpmPackageInfo, uncompressed_path: str, directory: bytes) Release | None[source]#

Build the release from the archive metadata (extrinsic artifact metadata) and the intrinsic metadata.

Parameters:
  • p_info – Package information

  • uncompressed_path – Artifact uncompressed path on disk

swh.loader.package.npm.loader.extract_npm_package_author(package_json: Dict[str, Any]) Person[source]#

Extract package author from a package.json file content and return it in swh format.

Parameters:

package_json – Dict holding the content of parsed package.json file

Returns:

Person

swh.loader.package.npm.loader.load_json(json_bytes)[source]#

Try to load JSON from bytes and return a dictionary.

First try to decode from utf-8. If the decoding failed, try to detect the encoding and decode again with replace error handling.

If JSON is malformed, an empty dictionary will be returned.

Parameters:

json_bytes (bytes) – binary content of a JSON file

Returns:

JSON data loaded in a dictionary

Return type:

dict

swh.loader.package.npm.loader.extract_intrinsic_metadata(dir_path: str) Dict[source]#
Given an uncompressed path holding the pkginfo file, returns a

pkginfo parsed structure as a dict.

The release artifact contains at their root one folder. For example: $ tar tvf zprint-0.0.6.tar.gz drwxr-xr-x root/root 0 2018-08-22 11:01 zprint-0.0.6/ …

Parameters:

dir_path (str) – Path to the uncompressed directory representing a release artifact from npm.

Returns:

the pkginfo parsed structure as a dict if any or None if none was present.