Skip to content

Commit

Permalink
refactor
Browse files Browse the repository at this point in the history
  • Loading branch information
clavedeluna committed Nov 20, 2023
1 parent dfa33f8 commit 9054ace
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 23 deletions.
11 changes: 7 additions & 4 deletions src/codemodder/codemods/base_codemod.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,14 +75,17 @@ def node_position(self, node):
# See https://github.com/Instagram/LibCST/blob/main/libcst/_metadata_dependent.py#L112
return self.get_metadata(self.METADATA_DEPENDENCIES[0], node)

def add_change(self, node, description):
def add_change(self, node, description: str, start: bool = True):
position = self.node_position(node)
self.add_change_from_position(position, description)
self.add_change_from_position(position, description, start)

def add_change_from_position(self, position: CodeRange, description):
def add_change_from_position(
self, position: CodeRange, description: str, start: bool = True
):
lineno = position.start.line if start else position.end.line
self.file_context.codemod_changes.append(
Change(
lineNumber=position.start.line,
lineNumber=lineno,
description=description,
)
)
Expand Down
7 changes: 7 additions & 0 deletions src/codemodder/codemods/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -132,3 +132,10 @@ def get_function_name_node(call: cst.Call) -> Optional[cst.Name]:
case cst.Attribute():
return call.func.attr
return None


def is_assigned_to_True(original_node: cst.Assign):
return (
isinstance(original_node.value, cst.Name)
and original_node.value.value == "True"
)
21 changes: 2 additions & 19 deletions src/core_codemods/django_session_cookie_secure_off.py
Original file line number Diff line number Diff line change
@@ -1,12 +1,7 @@
from typing import List
import libcst as cst
from libcst.codemod import Codemod, CodemodContext
from codemodder.change import Change
from codemodder.codemods.base_visitor import BaseTransformer
from codemodder.codemods.api import SemgrepCodemod
from codemodder.codemods.base_codemod import ReviewGuidance
from codemodder.codemods.utils import is_django_settings_file
from codemodder.file_context import FileContext
from codemodder.codemods.utils import is_django_settings_file, is_assigned_to_True


class DjangoSessionCookieSecureOff(SemgrepCodemod):
Expand Down Expand Up @@ -65,12 +60,7 @@ def leave_Module(
# something else and we changed it in `leave_Assign`.
return updated_node

# line_number is the end of the module where we will insert the new flag.
pos_to_match = self.node_position(original_node)
line_number = pos_to_match.end.line
self.file_context.codemod_changes.append(
Change(line_number, self.CHANGE_DESCRIPTION)
)
self.add_change(original_node, self.CHANGE_DESCRIPTION, start=False)
final_line = cst.parse_statement("SESSION_COOKIE_SECURE = True")
new_body = updated_node.body + (final_line,)
return updated_node.with_changes(body=new_body)
Expand Down Expand Up @@ -103,10 +93,3 @@ def is_session_cookie_secure(original_node: cst.Assign):
return (
isinstance(target_var, cst.Name) and target_var.value == "SESSION_COOKIE_SECURE"
)


def is_assigned_to_True(original_node: cst.Assign):
return (
isinstance(original_node.value, cst.Name)
and original_node.value.value == "True"
)

0 comments on commit 9054ace

Please sign in to comment.