mirror of
https://github.com/Noratrieb/node-package-manager.git
synced 2026-01-14 15:45:03 +01:00
things
This commit is contained in:
parent
c5e1b8011c
commit
b6224e7252
4 changed files with 90 additions and 51 deletions
34
Cargo.lock
generated
34
Cargo.lock
generated
|
|
@ -17,6 +17,15 @@ version = "1.0.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe"
|
checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "aho-corasick"
|
||||||
|
version = "0.7.18"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "1e37cfd5e7657ada45f742d6e99ca5788580b5c529dc78faf11ece6dc702656f"
|
||||||
|
dependencies = [
|
||||||
|
"memchr",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ansi_term"
|
name = "ansi_term"
|
||||||
version = "0.12.1"
|
version = "0.12.1"
|
||||||
|
|
@ -566,6 +575,7 @@ dependencies = [
|
||||||
"color-eyre",
|
"color-eyre",
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"reqwest",
|
"reqwest",
|
||||||
|
"semver_rs",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"tracing",
|
"tracing",
|
||||||
|
|
@ -737,6 +747,8 @@ version = "1.5.5"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "1a11647b6b25ff05a515cb92c365cec08801e83423a235b51e231e1808747286"
|
checksum = "1a11647b6b25ff05a515cb92c365cec08801e83423a235b51e231e1808747286"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
|
"aho-corasick",
|
||||||
|
"memchr",
|
||||||
"regex-syntax",
|
"regex-syntax",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
@ -896,6 +908,19 @@ dependencies = [
|
||||||
"libc",
|
"libc",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "semver_rs"
|
||||||
|
version = "0.2.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "9594e1aab972e5b5ecbb330754bef51c7ba0dc12644b6bae9e09a4e19d472586"
|
||||||
|
dependencies = [
|
||||||
|
"lazy_static",
|
||||||
|
"regex",
|
||||||
|
"serde",
|
||||||
|
"thiserror",
|
||||||
|
"unicase",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "serde"
|
name = "serde"
|
||||||
version = "1.0.137"
|
version = "1.0.137"
|
||||||
|
|
@ -1227,6 +1252,15 @@ version = "0.2.3"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "59547bce71d9c38b83d9c0e92b6066c4253371f15005def0c30d9657f50c7642"
|
checksum = "59547bce71d9c38b83d9c0e92b6066c4253371f15005def0c30d9657f50c7642"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "unicase"
|
||||||
|
version = "2.6.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "50f37be617794602aabbeee0be4f259dc1778fabe05e2d67ee8f79326d5cb4f6"
|
||||||
|
dependencies = [
|
||||||
|
"version_check",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "unicode-bidi"
|
name = "unicode-bidi"
|
||||||
version = "0.3.8"
|
version = "0.3.8"
|
||||||
|
|
|
||||||
|
|
@ -10,6 +10,7 @@ clap = { version = "3.1.18", features = ["derive"] }
|
||||||
color-eyre = "0.6.1"
|
color-eyre = "0.6.1"
|
||||||
indexmap = { version = "1.8.1", features = ["serde"] }
|
indexmap = { version = "1.8.1", features = ["serde"] }
|
||||||
reqwest = { version = "0.11.10", features = ["blocking", "rustls-tls", "json"] }
|
reqwest = { version = "0.11.10", features = ["blocking", "rustls-tls", "json"] }
|
||||||
|
semver_rs = { version = "0.2.0", features = ["serde"] }
|
||||||
serde = { version = "1.0.137", features = ["derive"] }
|
serde = { version = "1.0.137", features = ["derive"] }
|
||||||
serde_json = "1.0.81"
|
serde_json = "1.0.81"
|
||||||
tracing = "0.1.34"
|
tracing = "0.1.34"
|
||||||
|
|
|
||||||
|
|
@ -4,7 +4,7 @@ use color_eyre::Result;
|
||||||
use indexmap::IndexMap;
|
use indexmap::IndexMap;
|
||||||
use reqwest::blocking::Client;
|
use reqwest::blocking::Client;
|
||||||
use serde::Deserialize;
|
use serde::Deserialize;
|
||||||
use tracing::info;
|
use tracing::debug;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
manifest::{Bugs, Human, Person, Repository},
|
manifest::{Bugs, Human, Person, Repository},
|
||||||
|
|
@ -12,61 +12,61 @@ use crate::{
|
||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Debug, Deserialize)]
|
#[derive(Debug, Deserialize)]
|
||||||
struct Dist {
|
pub struct Dist {
|
||||||
shasum: String,
|
pub shasum: String,
|
||||||
tarball: String,
|
pub tarball: String,
|
||||||
integrity: Option<String>,
|
pub integrity: Option<String>,
|
||||||
#[serde(rename = "fileCount")]
|
#[serde(rename = "fileCount")]
|
||||||
file_count: Option<u32>,
|
pub file_count: Option<u32>,
|
||||||
#[serde(rename = "unpackedSize")]
|
#[serde(rename = "unpackedSize")]
|
||||||
unpacked_size: Option<u32>,
|
pub unpacked_size: Option<u32>,
|
||||||
#[serde(rename = "npm-signature")]
|
#[serde(rename = "npm-signature")]
|
||||||
npm_signature: Option<String>,
|
pub npm_signature: Option<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Deserialize)]
|
#[derive(Debug, Deserialize)]
|
||||||
struct VersionMeta {
|
pub struct VersionMeta {
|
||||||
_from: Option<String>,
|
pub _from: Option<String>,
|
||||||
_id: String,
|
pub _id: String,
|
||||||
#[serde(rename = "_nodeVersion")]
|
#[serde(rename = "_nodeVersion")]
|
||||||
_node_version: String,
|
pub _node_version: String,
|
||||||
#[serde(rename = "_npmUser")]
|
#[serde(rename = "_npmUser")]
|
||||||
_npm_user: Person,
|
pub _npm_user: Person,
|
||||||
#[serde(rename = "_npmVersion")]
|
#[serde(rename = "_npmVersion")]
|
||||||
_npm_version: String,
|
pub _npm_version: String,
|
||||||
_shasum: Option<String>,
|
pub _shasum: Option<String>,
|
||||||
#[serde(rename = "_hasShrinkwrap")]
|
#[serde(rename = "_hasShrinkwrap")]
|
||||||
_has_shrinkwrap: Option<bool>,
|
pub _has_shrinkwrap: Option<bool>,
|
||||||
dist: Dist,
|
pub dist: Dist,
|
||||||
files: Vec<String>,
|
pub files: Vec<String>,
|
||||||
|
|
||||||
#[serde(flatten)]
|
#[serde(flatten)]
|
||||||
package_json: PackageJson,
|
pub package_json: PackageJson,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Deserialize)]
|
#[derive(Debug, Deserialize)]
|
||||||
struct PackageMeta {
|
pub struct PackageMeta {
|
||||||
_id: String,
|
pub _id: String,
|
||||||
_rev: String,
|
pub _rev: String,
|
||||||
#[serde(rename = "dist-tags")]
|
#[serde(rename = "dist-tags")]
|
||||||
dist_tags: IndexMap<String, String>,
|
pub dist_tags: IndexMap<String, String>,
|
||||||
name: String,
|
pub name: String,
|
||||||
time: IndexMap<String, String>,
|
pub time: IndexMap<String, String>,
|
||||||
users: IndexMap<String, bool>,
|
pub users: IndexMap<String, bool>,
|
||||||
versions: IndexMap<String, VersionMeta>,
|
pub versions: IndexMap<String, VersionMeta>,
|
||||||
|
|
||||||
author: Human,
|
pub author: Human,
|
||||||
bugs: Option<Bugs>,
|
pub bugs: Option<Bugs>,
|
||||||
contributors: Option<Vec<Human>>,
|
pub contributors: Option<Vec<Human>>,
|
||||||
description: Option<String>,
|
pub description: Option<String>,
|
||||||
homepage: Option<String>,
|
pub homepage: Option<String>,
|
||||||
keywords: Option<Vec<String>>,
|
pub keywords: Option<Vec<String>>,
|
||||||
license: Option<String>,
|
pub license: Option<String>,
|
||||||
maintainers: Option<Vec<Human>>,
|
pub maintainers: Option<Vec<Human>>,
|
||||||
readme: Option<String>,
|
pub readme: Option<String>,
|
||||||
#[serde(rename = "readmeFilename")]
|
#[serde(rename = "readmeFilename")]
|
||||||
readme_filename: Option<String>,
|
pub readme_filename: Option<String>,
|
||||||
repository: Option<Repository>,
|
pub repository: Option<Repository>,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct NpmClient {
|
pub struct NpmClient {
|
||||||
|
|
@ -82,20 +82,13 @@ impl NpmClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tracing::instrument(skip(self))]
|
#[tracing::instrument(skip(self))]
|
||||||
pub fn inspect_package(&self, name: &str) -> Result<()> {
|
pub fn inspect_package(&self, name: &str) -> Result<PackageMeta> {
|
||||||
let res = self.reqwest.get(format!("{BASE_URL}/{name}")).send()?;
|
let res = self.reqwest.get(format!("{BASE_URL}/{name}")).send()?;
|
||||||
let code = res.status();
|
let code = res.status();
|
||||||
let body = res.text()?;
|
let body = res.text()?;
|
||||||
let meta = serde_json::from_str::<PackageMeta>(&body);
|
let meta = serde_json::from_str::<PackageMeta>(&body)?;
|
||||||
if let Err(err) = &meta {
|
|
||||||
tracing::error!(?err, "error");
|
|
||||||
let col = err.column();
|
|
||||||
let after = &body[col..][..10];
|
|
||||||
let before = &body[col - 100..col];
|
|
||||||
tracing::error!(%before, %after, "err");
|
|
||||||
}
|
|
||||||
|
|
||||||
info!(?code, ?meta, "Received response");
|
debug!(?code, ?meta, "Received response");
|
||||||
Ok(())
|
Ok(meta)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
15
src/main.rs
15
src/main.rs
|
|
@ -1,7 +1,7 @@
|
||||||
use std::fs;
|
use std::fs;
|
||||||
|
|
||||||
use color_eyre::{eyre::WrapErr, Result};
|
use color_eyre::{eyre::WrapErr, Result};
|
||||||
use tracing::{debug, metadata::LevelFilter};
|
use tracing::{debug, info, metadata::LevelFilter};
|
||||||
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt, EnvFilter, Registry};
|
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt, EnvFilter, Registry};
|
||||||
|
|
||||||
use crate::{download::NpmClient, manifest::PackageJson};
|
use crate::{download::NpmClient, manifest::PackageJson};
|
||||||
|
|
@ -23,7 +23,18 @@ fn main() -> Result<()> {
|
||||||
let client = NpmClient::new();
|
let client = NpmClient::new();
|
||||||
|
|
||||||
for (name, _) in &manifest.dependencies.unwrap() {
|
for (name, _) in &manifest.dependencies.unwrap() {
|
||||||
client.inspect_package(name)?;
|
look_at_package(name, &client)?;
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[tracing::instrument(skip(client))]
|
||||||
|
fn look_at_package(name: &str, client: &NpmClient) -> Result<()> {
|
||||||
|
let meta = client.inspect_package(name)?;
|
||||||
|
|
||||||
|
for version in meta.versions.keys() {
|
||||||
|
info!(%version);
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue