@socketsecurity/sdk
v1.3.0
Published
SDK for the Socket API client
Downloads
5,589
Readme
@socketsecurity/sdk
SDK for the Socket API client, generated by api
.
Usage
npm install @socketsecurity/sdk
ESM / TypeScript
import { SocketSdk } from '@socketsecurity/sdk'
const client = new SocketSdk('yourApiKeyHere')
const res = await client.getQuota()
if (res.success) {
// Will output { quota: 123 } if the quota you have left is 123
console.log(res.data)
}
CommonJS
const { SocketSdk } = require('@socketsecurity/sdk')
SocketSdk Methods
Package methods
getIssuesByNPMPackage(packageName, version)
packageName
: Astring
representing the name of the npm package you want the issues forversion
: Astring
representing the version of the npm package to return the issues for
getScoreByNPMPackage(packageName, version)
packageName
: Astring
representing the name of the npm package you want the score forversion
: Astring
representing the version of the npm package to return the score for
Report methods
createReportFromFilePaths(filePaths, pathsRelativeTo=., [issueRules])
filePaths
: Anarray
of absolute or relativestring
paths topackage.json
and any correspondingpackage-lock.json
filespathsRelativeTo
: Astring
path that the absolute pathsfilePaths
are relative to. This to calculate where in your project thepackage.json
/package-lock.json
files livesissueRules
: An object that follows the format of thesocket.yml
issue rules. Keys being issue names, values being a boolean that activates or deactivates it. Is applied on top of default config and organization config.
getReportList()
getReportSupportedFiles()
getReport(id)
id
: Astring
representing the id of a created report
Utility methods
getQuota()
getOrganizations()
postSettings(selectors)
selectors
: An array of settings selectors, e.g.[{ organization: 'id' }]
Additional exports
createUserAgentFromPkgJson(pkgJson)
pkgJson
: The content of thepackage.json
you want to create aUser-Agent
string for
Advanced
Specifying custom user agent
The SocketSdk
constructor accepts an options
object as its second argument and there a userAgent
key with a string value can be specified. If specified then that user agent will be prepended to the SDK user agent. See this example:
const client = new SocketSdk('yourApiKeyHere', {
userAgent: 'example/1.2.3 (http://example.com/)'
})
Which results in the HTTP User-Agent
header:
User-Agent: example/1.2.3 (http://example.com/) socketsecurity-sdk/0.5.2 (https://github.com/SocketDev/socket-sdk-js)
To easily create a user agent for your code you can use the additional export createUserAgentFromPkgJson()
like this, assuming pkgJson
contains your parsed package.json
:
const client = new SocketSdk('yourApiKeyHere', {
userAgent: createUserAgentFromPkgJson(pkgJson)
})
Specifying a custom user agent is good practice when shipping a piece of code that others can use to make requests. Eg. our CLI uses this option to identify requests coming from it + mentioning which version of it that is used.