Socket Security Python SDK
Reason this release was yanked:
Broken version
Project description
Purpose
The Socket.dev Python SDK provides a wrapper around the Socket.dev REST API to simplify making calls to the API from Python.
Socket API v0 - https://docs.socket.dev/reference/introduction-to-socket-api
Initializing the module
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME", timeout=30)
PARAMETERS:
token (str) - The Socket API Key for your Organization
Timeout (int) - The number of seconds to wait before failing the connection
Supported Functions
npm.issues(package, version)
Retrieve the Issues associated with a package and version.
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.npm.issues("hardhat-gas-report", "1.1.25"))
PARAMETERS:
package (str) - The name of the NPM package.
version (str) - The version of the NPM Package.
npm.score(package, version)
Retrieve the Issues associated with a package and version.
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.npm.score("hardhat-gas-report", "1.1.25"))
PARAMETERS:
package (str) - The name of the NPM package.
version (str) - The version of the NPM Package.
dependencies.get(limit, offset)
Retrieve the dependencies for the organization associated with the API Key
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.dependencies.get(10, 0))
PARAMETERS:
limit (int) - The maximum number of dependencies to return
offset (int) - The index to start from for pulling the dependencies
dependencies.post(files, params)
Retrieve the dependencies for the organization associated with the API Key
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
file_names = [
"path/to/package.json"
]
params = {
"repository": "username/repo-name",
"branch": "dependency-branch
}
print(socket.dependencies.post(file_names, params))
PARAMETERS:
files (list) - The file paths of the manifest files to import into the Dependency API.
params (dict) - A dictionary of the repository and branch options for the API
org.get()
Retrieve the Socket.dev org information
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.org.get())
quota.get()
Retrieve the the current quota available for your API Key
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.quota.get())
report.list()
Retrieve the list of all reports for the organization
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.report.list(from_time=1726183485))
PARAMETERS:
from_time (int) - The Unix Timestamp in Seconds to limit the reports pulled
report.delete(report_id)
Delete the specified report
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.report.delete("report-id"))
PARAMETERS:
report_id (str) - The report ID of the report to delete
report.view(report_id)
Retrieve the information for a Project Health Report
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.report.view("report_id"))
PARAMETERS:
report_id (str) - The report ID of the report to view
report.supported()
Retrieve the supported types of manifest files for creating a report
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.report.supported())
report.create(files)
Create a new project health report with the provided files
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
files = [
"/path/to/manifest/package.json"
]
print(socket.report.create(files))
PARAMETERS:
files (list) - List of file paths of manifest files
repositories.get()
Get a list of information about the tracked repositores
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.repositories.get())
settings.get()
Retrieve the Socket Organization Settings
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.settings.get())
sbom.view(report_id)
Retrieve the information for a SBOM Report
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.sbom.view("report_id"))
PARAMETERS:
report_id (str) - The report ID of the report to view
purl.post(license, components)
Retrieve the package information for a purl post
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
license = "true"
components = [
{
"purl": "pkg:pypi/pyonepassword@5.0.0"
},
{
"purl": "pkg:pypi/socketsecurity"
}
]
print(socket.purl.post(license, components))
PARAMETERS:
license (str) - The license parameter if enabled will show alerts and license information. If disabled will only show the basic package metadata and scores. Default is true
components (array{dict}) - The components list of packages urls
fullscans.get(org_slug)
Retrieve the Fullscans information for around Organization
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.fullscans.get("org_slug"))
PARAMETERS:
org_slug (str) - The organization name
fullscans.post(files, params)
Create a full scan from a set of package manifest files. Returns a full scan including all SBOM artifacts.
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
files = [
"/path/to/manifest/package.json"
]
params = {
"org_slug": "org_name",
"repo": "TestRepo",
"branch": "main",
"commit_message": "Test Commit Message",
"commit_hash": "",
"pull_request": "",
"committers": "commiter",
"make_default_branch": False,
"set_as_pending_head": False,
"tmp": ""
}
print(socket.fullscans.post(files, params))
PARAMETERS:
files (list) - List of file paths of manifest files
params (dict) - List of parameters to create a fullscan
Parameter |
Required |
Description |
---|---|---|
org_slug |
True |
The string name in a git approved name for organization. |
repo |
True |
The string name in a git approved name for repositories. |
branch |
False |
The string name in a git approved name for branches. |
committers |
False |
The string name of the person doing the commit or running the CLI. Can be specified multiple times to have more than one committer. |
pull_request |
False |
The integer for the PR or MR number. |
commit_message |
False |
The string for a commit message if there is one. |
make_default_branch |
False |
If the flag is specified this will signal that this is the default branch. |
commit_hash |
False |
Optional git commit hash |
set_as_pending_head |
False |
|
tmp |
False |
fullscans.delete(org_slug, full_scan_id)
Delete an existing full scan.
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.fullscans.delete(org_slug, full_scan_id))
PARAMETERS:
org_slug (str) - The organization name
full_scan_id (str) - The ID of the full scan
fullscans.stream(org_slug, full_scan_id)
Stream all SBOM artifacts for a full scan.
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.fullscans.stream(org_slug, full_scan_id))
PARAMETERS:
org_slug (str) - The organization name
full_scan_id (str) - The ID of the full scan
fullscans.metadata(org_slug, full_scan_id)
Get metadata for a single full scan
Usage:
from socketdev import socketdev
socket = socketdev(token="REPLACE_ME")
print(socket.fullscans.metadata(org_slug, full_scan_id))
PARAMETERS:
org_slug (str) - The organization name
full_scan_id (str) - The ID of the full scan
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file socket_sdk_python-1.0.6.tar.gz
.
File metadata
- Download URL: socket_sdk_python-1.0.6.tar.gz
- Upload date:
- Size: 25.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 096f08ce4045895066406d8abcb734df2f9fc5a4a026321b52a9dc2a9b291d25 |
|
MD5 | 72b323abcb3e2e412c881e7ad3d3af56 |
|
BLAKE2b-256 | 860c16fa062a993c480a53ac8d9fb58d1d59503d0134ef08d3cc6ced05c2028d |
File details
Details for the file socket_sdk_python-1.0.6-py3-none-any.whl
.
File metadata
- Download URL: socket_sdk_python-1.0.6-py3-none-any.whl
- Upload date:
- Size: 27.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 92d2c1d0454ce08405df66ee7476ee98823ef33916a151a25adb8905aee52e02 |
|
MD5 | 668324e911bcff6cee075e92689239f9 |
|
BLAKE2b-256 | 0f2ef01dd9285aeeb6b3fac033cb960cf13605569d1d6eed1334e5ef2f4fb0de |