Add more error handling

This commit is contained in:
Justin Hutchings
2024-03-03 01:34:03 +00:00
parent b2ddac1749
commit 72d5b06a68
3 changed files with 44 additions and 31 deletions

31
dist/index.js generated vendored
View File

@@ -1002,17 +1002,22 @@ function getScorecardLevels(changes) {
return __awaiter(this, void 0, void 0, function* () {
const data = { dependencies: [] };
for (const change of changes) {
const purl = packageurl_js_1.PackageURL.fromString(change.package_url);
const ecosystem = purl.type;
const packageName = purl.name;
const version = purl.version;
data.dependencies.push({
purl: purl,
ecosystem: ecosystem,
packageName: packageName,
version: version,
depsDevData: yield getDepsDevData(ecosystem, packageName, version)
});
try {
const purl = packageurl_js_1.PackageURL.fromString(change.package_url);
const ecosystem = purl.type;
const packageName = purl.name;
const version = purl.version;
data.dependencies.push({
purl: purl,
ecosystem: ecosystem,
packageName: packageName,
version: version,
depsDevData: yield getDepsDevData(ecosystem, packageName, version)
});
}
catch (error) {
core.debug(`Error parsing package url: ${error.message}`);
}
}
return data;
});
@@ -1037,7 +1042,7 @@ function getDepsDevData(ecosystem, packageName, version) {
}
}
catch (error) {
core.error(`Error fetching data: ${error.message}`);
core.debug(`Error fetching data: ${error.message}`);
}
return {};
});
@@ -1057,7 +1062,7 @@ function getDepsDevProjectData(projectKeyId) {
}
}
catch (error) {
core.error(`Error fetching project data: ${error.message}`);
core.debug(`Error fetching project data: ${error.message}`);
}
return {};
});

2
dist/index.js.map generated vendored

File diff suppressed because one or more lines are too long

View File

@@ -6,20 +6,24 @@ import * as core from '@actions/core'
export async function getScorecardLevels(changes: Change[]): Promise<object> {
const data: any = {dependencies: []}
for (const change of changes) {
const purl = PackageURL.fromString(change.package_url)
const ecosystem = purl.type
const packageName = purl.name
const version = purl.version
try {
const purl = PackageURL.fromString(change.package_url)
const ecosystem = purl.type
const packageName = purl.name
const version = purl.version
data.dependencies.push({
purl: purl,
ecosystem: ecosystem,
packageName: packageName,
version: version,
depsDevData: await getDepsDevData(ecosystem, packageName, version)
})
data.dependencies.push({
purl: purl,
ecosystem: ecosystem,
packageName: packageName,
version: version,
depsDevData: await getDepsDevData(ecosystem, packageName, version)
})
} catch (error: any) {
core.debug(`Error parsing package url: ${error.message}`)
}
}
return data;
return data
}
const depsDevAPIRoot = 'https://api.deps.dev'
@@ -40,10 +44,12 @@ async function getDepsDevData(
return await getDepsDevProjectData(project.projectKey.id)
}
} else {
throw new Error(`Failed to fetch data with status code: ${response.status}`)
throw new Error(
`Failed to fetch data with status code: ${response.status}`
)
}
} catch (error: any) {
core.error(`Error fetching data: ${error.message}`)
core.debug(`Error fetching data: ${error.message}`)
}
return {}
}
@@ -57,10 +63,12 @@ async function getDepsDevProjectData(projectKeyId: string): Promise<object> {
const data = await response.json()
return data
} else {
throw new Error(`Failed to fetch project data with status code: ${response.status}`)
throw new Error(
`Failed to fetch project data with status code: ${response.status}`
)
}
} catch (error: any) {
core.error(`Error fetching project data: ${error.message}`)
core.debug(`Error fetching project data: ${error.message}`)
}
return {}
}
}