Manifest File Detection in Socket
Socket's file detection system is designed to identify and analyze key manifest files and specific patterns across various programming languages and package managers. These manifest files are crucial for dependency management and security auditing, allowing Socket to provide comprehensive security insights and alerts. Here’s how Socket detects and recognizes these files:
Supported Manifest Files
Socket automatically scans for a variety of manifest file types. The primary file types it looks for include:
-
Python (PyPI):
requirements.txt
requirements/default.txt
(when placed in arequirements
folder)pipfile
pyproject.toml
setup.py
poetry.lock
-
JavaScript (NPM, Yarn, PNPM):
package.json
package-lock.json
npm-shrinkwrap.json
yarn.lock
pnpm-lock.yaml
pnpm-workspace.yaml
-
Java (Maven, Gradle):
pom.xml
*.gradle
*.gradle.kts
-
Go (GoLang):
go.mod
go.sum
-
Ruby (Gem):
Gemfile
Gemfile.lock
Rakefile
*.gemspec
-
C/C++ (SPDX):
*spdx.json
-
General Purpose Files:
README.md
LICENSE
orCOPYING
Custom Path Detection
Socket is also capable of detecting manifest files that may not follow standard naming conventions. For example, if you have a manifest file named default.txt
, it won’t be detected unless it's placed in a folder specifically named requirements
. This allows for more flexible organization of project files while ensuring that critical files are still identified and scanned.
Additional Supported Files
-
CycloneDX (CDX) Files:
- JSON:
{bom, *-{, .}{c, cyclone}dx}.json
- XML:
{bom, *-{, .}{c, cyclone}dx}.xml
- JSON:
-
SBT (Scala Build Tool):
build.sbt
-
Ivy (Apache Ivy):
ivy.xml
-
Leiningen (Clojure):
project.clj
-
Buildr (Apache Buildr):
Buildfile
Malicious Package Alerts
If you have included known malicious packages in your project but are not receiving alerts, it may be due to the folder structure or the naming conventions of your manifest files. Ensuring that your manifest files follow the supported patterns should resolve these issues. Additionally, make sure that the malicious packages are correctly installed or referenced within these recognized manifest files.
Ensuring Effective Detection
To ensure that Socket can properly detect and analyze all relevant files:
- Follow the recommended file naming conventions.
- Place custom manifest files within expected directories.
- Regularly update your manifest files to reflect any changes in dependencies.
This will help maximize the effectiveness of Socket’s security features and ensure that your project is fully protected against vulnerabilities and malicious dependencies.
For more detailed information on supported files and patterns, you can refer to the Socket API documentation.
Updated 20 days ago