Netra-security
Source: Dev.to
๐ฑ Building Netra Security: Creating a Python-Based Static Application Security Testing (SAST) Tool
As a cybersecurity student, Iโve always been curious about how tools like SonarQube, Semgrep, and other Static Application Security Testing (SAST) platforms identify vulnerabilities before software reaches production.
Instead of just learning how to use these tools, I wanted to understand how they work internally. That curiosity led me to build Netra Security, a lightweight SAST platform developed using Python.
In this article, Iโll share the motivation behind the project, how it works, and what I learned while building it.
What is Netra Security?
Netra Security is a Python-based static code analysis tool designed to identify common security vulnerabilities directly from source code.
The name Netra is inspired by the concept of the โthird eye,โ representing the ability to detect hidden security issues before they become exploitable vulnerabilities.
The goal was not to create a replacement for enterprise security scanners but to learn the fundamentals of:
-
Static code analysis
-
Secure coding practices
-
Vulnerability detection
-
Abstract Syntax Tree (AST) analysis
-
Security tooling development
The Problem
Many security vulnerabilities are introduced during development.
Common examples include:
os.system(user_input)
eval(user_input)
exec(user_input)
pickle.loads(user_data)
subprocess.run(user_input, shell=True)
Enter fullscreen mode
Exit fullscreen mode
These patterns can lead to:
-
Command Injection
-
Code Injection
-
Arbitrary Code Execution
-
Insecure Deserialization
The idea behind Netra Security is simple:
Detect insecure coding patterns before they become security incidents.
Version 1: Rule-Based Detection
The first version of Netra Security relied on string matching and regular expressions.
Example rule:
{
"id": "NETRA-001",
"pattern": "os.system(",
"issue": "Command Injection",
"severity": "CRITICAL"
}
Enter fullscreen mode
Exit fullscreen mode
The scanner reads source code line by line and checks whether dangerous patterns appear.
This approach was easy to implement and worked surprisingly well for basic detection.
However, it had a major problem.
False Positives
Consider:
message = "Never use eval() in production"
Enter fullscreen mode
Exit fullscreen mode
A simple string scanner would incorrectly flag this as a vulnerability even though it is only text.
This limitation motivated the next step.
Introducing AST Analysis
Python provides a built-in module called ast (Abstract Syntax Tree).
AST converts source code into a tree structure that represents the actual logic of the program.
For example:
os.system(user)
Enter fullscreen mode
Exit fullscreen mode
becomes a function call node.
Instead of searching for text, we can inspect the code structure itself.
Example:
for node in ast.walk(tree):
if isinstance(node, ast.Call):
if isinstance(node.func, ast.Attribute):
if node.func.attr == "system":
print("Command Injection Risk")
Enter fullscreen mode
Exit fullscreen mode
This significantly reduces false positives and provides more reliable results.
Vulnerabilities Currently Detected
Netra Security currently detects:
ID Vulnerability Severity
NETRA-001 Command Injection Critical
NETRA-002 Code Injection Critical
NETRA-003 Hardcoded Password High
NETRA-004 Hardcoded API Key High
NETRA-005 Arbitrary Code Execution Critical
NETRA-006 Insecure Deserialization High
NETRA-007 Dangerous Subprocess Usage High
Each finding includes:
-
Rule ID
-
Severity
-
Line Number
-
Vulnerable Code
-
Remediation Recommendation
Sample Output
=== NETRA SECURITY REPORT ===
Total Findings: 5
ID : NETRA-001
Severity : CRITICAL
Issue : Command Injection
Line : 13
Code : os.system(user)
Fix : Use subprocess.run(..., shell=False)
Enter fullscreen mode
Exit fullscreen mode
Lessons Learned
Building Netra Security taught me several important concepts:
Static Analysis Is More Complex Than It Looks
Initially, I assumed security scanning was mostly pattern matching.
In reality, reducing false positives is one of the hardest challenges.
AST Is Extremely Powerful
AST enables analysis based on code behavior rather than raw text.
This is how many professional security tools achieve better accuracy.
Security and Development Are Closely Connected
Developers who understand security can prevent many vulnerabilities before they reach production.
Future Improvements
The project is still evolving.
Planned features include:
-
Additional OWASP Top 10 checks
-
Multi-file project scanning
-
Folder-level analysis
-
Web-based dashboard using Flask
-
JSON and CSV report exports
-
Risk scoring engine
-
CI/CD integration
-
GitHub repository scanning
Final Thoughts
Building Netra Security gave me a much deeper understanding of how static analysis tools work and how vulnerabilities can be detected before software is deployed.
The project started as a simple pattern-matching scanner and gradually evolved into an AST-powered security analysis engine.
There is still a long way to go, but thatโs what makes cybersecurity and software engineering excitingโthere is always something new to learn and improve.
If youโre learning Python, cybersecurity, or application security, I highly recommend building your own security tools. Youโll learn far more than simply using existing ones.
Thanks for reading!
GitHub Repository:
python #cybersecurity #appsec #security #sast #flask #beginners #opensource