Skip to content

Commit

Permalink
update codemod metadata
Browse files Browse the repository at this point in the history
  • Loading branch information
clavedeluna committed Oct 16, 2023
1 parent 9223fb5 commit 7cdd632
Show file tree
Hide file tree
Showing 12 changed files with 42 additions and 35 deletions.
6 changes: 5 additions & 1 deletion .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,11 @@ repos:
rev: 23.9.1
hooks:
- id: black
exclude: samples/
exclude: |
(?x)^(
samples/.*|
core_codemods/docs/.*
)$
- repo: https://github.com/pre-commit/mirrors-mypy
rev: v1.5.1
hooks:
Expand Down
2 changes: 1 addition & 1 deletion src/core_codemods/django_debug_flag_on.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ class DjangoDebugFlagOn(SemgrepCodemod, Codemod):
},
],
)
SUMMARY = CHANGE_DESCRIPTION = METADATA. DESCRIPTION
SUMMARY = CHANGE_DESCRIPTION = METADATA.DESCRIPTION
YAML_FILES = [
"django-debug-flag-on.yaml",
]
Expand Down
4 changes: 2 additions & 2 deletions src/core_codemods/django_session_cookie_secure_off.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ class DjangoSessionCookieSecureOff(SemgrepCodemod, Codemod):
METADATA = CodemodMetadata(
DESCRIPTION=("Sets Django's `SESSION_COOKIE_SECURE` Flag if Off or Missing."),
NAME="django-session-cookie-secure-off",
REVIEW_GUIDANCE=ReviewGuidance.MERGE_AFTER_REVIEW,
REVIEW_GUIDANCE=ReviewGuidance.MERGE_AFTER_CURSORY_REVIEW,
REFERENCES=[
{
"url": "https://owasp.org/www-community/controls/SecureCookieAttribute",
Expand All @@ -29,7 +29,7 @@ class DjangoSessionCookieSecureOff(SemgrepCodemod, Codemod):
},
],
)
SUMMARY = "Secure setting for Django `SESSION_COOKIE_SECURE` flag"
SUMMARY = "Secure Setting for Django `SESSION_COOKIE_SECURE` flag"
CHANGE_DESCRIPTION = METADATA.DESCRIPTION
YAML_FILES = [
"detect-django-settings.yaml",
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
This codemod enables autoescaping of HTML content in `jinja2`. Unfortunately, the jinja2
default behavior is to not autoescape when rendering templates, which makes your applications
vulnerable to Cross-Site Scripting (XSS) attacks.
potentially vulnerable to Cross-Site Scripting (XSS) attacks.

Our codemod checks if you forgot to enable autoescape or if you explicitly disabled it. The change looks as follows:

Expand All @@ -13,4 +13,3 @@ Our codemod checks if you forgot to enable autoescape or if you explicitly disab
+ env = Environment(autoescape=True, loader=some_loader)
...
```

8 changes: 3 additions & 5 deletions src/core_codemods/docs/pixee_python_jwt-decode-verify.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,8 @@ Our change looks as follows:
- decoded_payload = jwt.decode(encoded_jwt, SECRET_KEY, algorithms=["HS256"], verify=False)
+ decoded_payload = jwt.decode(encoded_jwt, SECRET_KEY, algorithms=["HS256"], verify=True)
...
- decoded_payload = jwt.decode(
encoded_jwt, SECRET_KEY, algorithms=["HS256"], options={"verify_signature": False, "verify_exp": False})
+ decoded_payload = jwt.decode(
encoded_jwt, SECRET_KEY, algorithms=["HS256"], options={"verify_signature": True, "verify_exp": True})
- decoded_payload = jwt.decode(encoded_jwt, SECRET_KEY, algorithms=["HS256"], options={"verify_signature": False, "verify_exp": False})
+ decoded_payload = jwt.decode(encoded_jwt, SECRET_KEY, algorithms=["HS256"], options={"verify_signature": True, "verify_exp": True})
```

Any `verify` parameter not listed relies on the secure `True` default value.
Any `verify` parameter not listed relies on the secure `True` default value.
2 changes: 0 additions & 2 deletions src/core_codemods/docs/pixee_python_unused-imports.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,3 @@ import b

b.function()
```

If you have feedback on this codemod, [please let us know](mailto:[email protected])!
2 changes: 1 addition & 1 deletion src/core_codemods/enable_jinja2_autoescape.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

class EnableJinja2Autoescape(SemgrepCodemod):
NAME = "enable-jinja2-autoescape"
REVIEW_GUIDANCE = ReviewGuidance.MERGE_AFTER_CURSORY_REVIEW
REVIEW_GUIDANCE = ReviewGuidance.MERGE_WITHOUT_REVIEW
SUMMARY = "Enable Jinja2 Autoescape"
DESCRIPTION = "Sets the `autoescape` parameter in jinja2.Environment to `True`."
REFERENCES = [
Expand Down
4 changes: 3 additions & 1 deletion src/core_codemods/https_connection.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,9 @@ class HTTPSConnection(BaseCodemod, Codemod):
],
)
CHANGE_DESCRIPTION = METADATA.DESCRIPTION
SUMMARY = "Changes HTTPConnectionPool to HTTPSConnectionPool to enforce secure connection."
SUMMARY = (
"Changes HTTPConnectionPool to HTTPSConnectionPool to Enforce Secure Connection"
)

METADATA_DEPENDENCIES = (PositionProvider,)

Expand Down
2 changes: 1 addition & 1 deletion src/core_codemods/process_creation_sandbox.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

class ProcessSandbox(SemgrepCodemod):
NAME = "sandbox-process-creation"
REVIEW_GUIDANCE = ReviewGuidance.MERGE_AFTER_CURSORY_REVIEW
REVIEW_GUIDANCE = ReviewGuidance.MERGE_WITHOUT_REVIEW
SUMMARY = "Sandbox Process Creation"
DESCRIPTION = (
"Replaces subprocess.{func} with more secure safe_command library functions."
Expand Down
2 changes: 1 addition & 1 deletion src/core_codemods/secure_random.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

class SecureRandom(SemgrepCodemod):
NAME = "secure-random"
REVIEW_GUIDANCE = ReviewGuidance.MERGE_WITHOUT_REVIEW
REVIEW_GUIDANCE = ReviewGuidance.MERGE_AFTER_CURSORY_REVIEW
SUMMARY = "Secure Source of Randomness"
DESCRIPTION = "Replaces random.{func} with more secure secrets library functions."
REFERENCES = [
Expand Down
4 changes: 3 additions & 1 deletion src/core_codemods/with_threading_lock.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,9 @@
class WithThreadingLock(SemgrepCodemod):
NAME = "bad-lock-with-statement"
SUMMARY = "Separate Lock Instantiation from `with` Call"
DESCRIPTION = "Replace deprecated usage of threading lock classes as context managers."
DESCRIPTION = (
"Replace deprecated usage of threading lock classes as context managers."
)
REVIEW_GUIDANCE = ReviewGuidance.MERGE_AFTER_CURSORY_REVIEW
REFERENCES = [
{
Expand Down
38 changes: 21 additions & 17 deletions src/scripts/generate_docs.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,8 @@ class DocMetadata:
guidance_explained="Support for HTTPS is widespread which, save in some legacy applications, makes this change safe.",
),
"jwt-decode-verify": DocMetadata(
importance="SOMETHING", guidance_explained="SOMETHING"
importance="High",
guidance_explained="This codemod ensures your code uses all available validations when calling `jwt.decode`. We believe this replacement is safe and should not result in any issues.",
),
"limit-readline": DocMetadata(
importance="Medium",
Expand All @@ -58,10 +59,10 @@ class DocMetadata:
importance="High",
guidance_explained="We believe this change is safe, effective, and protects your code against very serious security attacks.",
),
# "order-imports": DocMetadata(
# importance="Low",
# guidance_explained="",
# ),
"order-imports": DocMetadata(
importance="Low",
guidance_explained="TODO SKIP FOR NOW",
),
"sandbox-process-creation": DocMetadata(
importance="High",
guidance_explained="We believe this change is safe and effective. The behavior of sandboxing `subprocess.run` and `subprocess.call` calls will only throw `SecurityException` if they see behavior involved in malicious code execution, which is extremely unlikely to happen in normal operation.",
Expand All @@ -87,7 +88,8 @@ class DocMetadata:
guidance_explained="We believe this codemod is safe and will cause no unexpected errors.",
),
"upgrade-sslcontext-minimum-version": DocMetadata(
importance="SOMETHING", guidance_explained="SOMETHING"
importance="High",
guidance_explained="This codemod updates the minimum supported version of TLS. Since this is an important security fix and since all modern servers offer TLSv1.2, we believe this change can be safely merged without review.",
),
"upgrade-sslcontext-tls": DocMetadata(
importance="High",
Expand All @@ -112,9 +114,9 @@ class DocMetadata:
importance="Low",
guidance_explained="We believe that using the walrus operator is an improvement in terms of clarity and readability. However, this change is only compatible with codebases that support Python 3.8 and later, so it requires quick validation before merging.",
),
# "bad-lock-with-statement": DocMetadata(
# importance="Low", guidance_explained="TODO AFTER PR MERGE"
# ),
"bad-lock-with-statement": DocMetadata(
importance="Low", guidance_explained="TODO AFTER PR MERGE"
),
}


Expand All @@ -124,19 +126,23 @@ def generate_docs(codemod):
except KeyError as exc:
raise KeyError(f"Must add {codemod.name} to METADATA") from exc

formatted_references = [
f"* [{ref['description']}]({ref['url']})" for ref in codemod.references
]
markdown_references = "\n".join(formatted_references) or "N/A"

output = f"""---
title: {codemod.summary}
sidebar_position: 1
---
## {codemod.id}
| Importance | Review Guidance | Requires SARIF Tool |
|------------|----------------------|---------------------|
| {codemod_data.importance} | {codemod.review_guidance} | {codemod_data.need_sarif} |
| Importance | Review Guidance | Requires SARIF Tool |
|------------|----------------------------|---------------------|
| {codemod_data.importance} | {codemod.review_guidance} | {codemod_data.need_sarif} |
{codemod.description}
If you have feedback on this codemod, [please let us know](mailto:[email protected])!
## F.A.Q.
Expand All @@ -150,10 +156,8 @@ def generate_docs(codemod):
N/A
## References
* [https://lxml.de/apidoc/lxml.etree.html#lxml.etree.XMLParser](https://lxml.de/apidoc/lxml.etree.html#lxml.etree.XMLParser)
* [https://owasp.org/www-community/vulnerabilities/XML_External_Entity_(XXE)_Processing](https://owasp.org/www-community/vulnerabilities/XML_External_Entity_(XXE)_Processing)
* [https://cheatsheetseries.owasp.org/cheatsheets/XML_External_Entity_Prevention_Cheat_Sheet.html](https://cheatsheetseries.owasp.org/cheatsheets/XML_External_Entity_Prevention_Cheat_Sheet.html)
#codemod.references
{markdown_references}
"""
return output

Expand Down

0 comments on commit 7cdd632

Please sign in to comment.