Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v0.1.3 (Alpha) #498

Open
wants to merge 5 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions app/models/activity_log.py
Original file line number Diff line number Diff line change
Expand Up @@ -83,10 +83,10 @@ def get_state_change(target, artifact):
o_state = Cfg_states.query.filter(Cfg_states.state == state_history.deleted[0]).first()
n_state = Cfg_states.query.filter(Cfg_states.state == state_history.added[0]).first()

if o_state.is_release_state > 0 or o_state.is_retired_state > 0 or o_state.is_staging_state > 0\
if o_state is None or o_state.is_release_state > 0 or o_state.is_retired_state > 0 or o_state.is_staging_state > 0\
or n_state.is_release_state > 0 or n_state.is_retired_state > 0 or n_state.is_staging_state > 0:
activity_text = "State for '%s' was toggled from '%s' to '%s'" \
% (artifact, o_state.state, n_state.state)
% (artifact, o_state.state if o_state is not None else 'None', n_state.state)

return activity_text

Expand Down
7 changes: 6 additions & 1 deletion app/routes/cfg_category_range_mapping.py
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ def update_cfg_category_range_mapping(id):


def update_cfg_category_range_mapping_current(id, current):
db.session.rollback()
entity = cfg_category_range_mapping.CfgCategoryRangeMapping.query.get(id)
if not entity:
return
Expand All @@ -86,7 +87,11 @@ def update_cfg_category_range_mapping_current(id, current):
id=id
)
db.session.merge(entity)
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise
return


Expand Down
95 changes: 74 additions & 21 deletions app/routes/yara_rules.py
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,11 @@ def merge_signatures():
yr.description = description.strip('"')
yr.revision = 1
db.session.add(yr)
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise
return jsonify(yr.to_dict()), 201


Expand All @@ -139,7 +143,11 @@ def merge_signatures_by_id():
merged_state = "Merged"
if not cfg_states.Cfg_states.query.filter_by(state=merged_state).first():
db.session.add(cfg_states.Cfg_states(state=merged_state))
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise

merge_from_yr.state = merged_state
db.session.add(merge_from_yr)
Expand All @@ -154,7 +162,11 @@ def merge_signatures_by_id():
db.session.add(
comments.Comments(comment=merged_from_comment, entity_type=ENTITY_MAPPING["SIGNATURE"],
entity_id=merge_to_yr.id, user_id=current_user.id))
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise

delete_bookmarks(ENTITY_MAPPING["SIGNATURE"], merge_from_id, current_user.id)

Expand Down Expand Up @@ -200,7 +212,6 @@ def get_all_yara_rules():
include_tags = bool(distutils.util.strtobool(request.args.get('include_tags', "true")))
include_comments = bool(distutils.util.strtobool(request.args.get('include_comments', "true")))


if include_yara_string:
include_yara_string = True

Expand Down Expand Up @@ -340,6 +351,8 @@ def create_yara_rule():
rule_state = request.json.get("state", None).get("state", None)
except:
rule_state = request.json.get("state", None)
if rule_state is None:
raise Exception("State is mandatory.")

unique_rule_name_enforcement = Cfg_settings.get_setting("ENFORCE_UNIQUE_YARA_RULE_NAMES")
if unique_rule_name_enforcement and distutils.util.strtobool(unique_rule_name_enforcement):
Expand Down Expand Up @@ -391,7 +404,11 @@ def create_yara_rule():
entity.state = draft_state.state

db.session.add(entity)
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise

entity.tags = create_tags_mapping(entity.__tablename__, entity.id, request.json['tags'])

Expand Down Expand Up @@ -424,15 +441,23 @@ def create_yara_rule():
dirty = True

if dirty:
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise

db.session.add(yara_rule.Yara_rule_history(date_created=datetime.datetime.now(),
revision=entity.revision,
rule_json=json.dumps(entity.to_revision_dict()),
user_id=current_user.id,
yara_rule_id=entity.id,
state=entity.state))
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise
return jsonify(entity.to_dict()), 201


Expand All @@ -443,7 +468,11 @@ def activate_yara_rule(id):
entity = yara_rule.Yara_rule.query.get(id)
entity.active = 1
db.session.merge(entity)
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise
return jsonify(entity.to_dict()), 201

@app.route('/ThreatKB/yara_rules/<int:id>', methods=['PUT'])
Expand All @@ -470,6 +499,8 @@ def update_yara_rule(id):
rule_state = request.json.get("state", None).get("state", None)
except:
rule_state = request.json.get("state", None)
if rule_state is None:
raise Exception("State is mandatory.")

unique_rule_name_enforcement = Cfg_settings.get_setting("ENFORCE_UNIQUE_YARA_RULE_NAMES")
if unique_rule_name_enforcement and distutils.util.strtobool(unique_rule_name_enforcement):
Expand Down Expand Up @@ -514,7 +545,7 @@ def update_yara_rule(id):
description=request.json.get("description", None),
references=request.json.get("references", None),
category=request.json['category']['category'] if request.json['category'] and 'category' in request
.json['category'] else request.json['category'],
.json['category'] else request.json['category'],
condition=yara_rule.Yara_rule.make_yara_sane(request.json["condition"], "condition:"),
strings=yara_rule.Yara_rule.make_yara_sane(request.json["strings"], "strings:"),
eventid=temp_sig_id,
Expand All @@ -524,7 +555,7 @@ def update_yara_rule(id):
modified_user_id=current_user.id,
last_revision_date=datetime.datetime.now(),
owner_user_id=request.json['owner_user']['id'] if request.json.get("owner_user", None) and request
.json["owner_user"].get("id", None) else None,
.json["owner_user"].get("id", None) else None,
revision=entity.revision if do_not_bump_revision else entity.revision + 1,
imports=yara_rule.Yara_rule.get_imports_from_string(request.json.get("imports", None)),
active=request.json.get("active", entity.active)
Expand All @@ -551,15 +582,23 @@ def update_yara_rule(id):
if old_state == release_state.state and entity.state == release_state.state and not do_not_bump_revision:
entity.state = draft_state.state

if get_new_sig_id:
update_cfg_category_range_mapping_current(request.json['category']['id'], temp_sig_id)

db.session.merge(entity)
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise

dirty = False
for name, value_dict in request.json.get("metadata_values", {}).items():
if not name or not value_dict:
continue

m = db.session.query(MetadataMapping, Metadata).join(Metadata, Metadata.id == MetadataMapping.metadata_id).filter(
m = db.session.query(MetadataMapping, Metadata).join(Metadata,
Metadata.id == MetadataMapping.metadata_id).filter(
Metadata.key == name).filter(Metadata.artifact_type == ENTITY_MAPPING["SIGNATURE"]).filter(
MetadataMapping.artifact_id == entity.id).first()
if m and m[0]:
Expand All @@ -569,12 +608,17 @@ def update_yara_rule(id):
else:
m = db.session.query(Metadata).filter(Metadata.key == name).filter(
Metadata.artifact_type == ENTITY_MAPPING["SIGNATURE"]).first()
db.session.add(MetadataMapping(value=value_dict["value"] if m.required else value_dict.get("value", None), metadata_id=m.id, artifact_id=entity.id,
db.session.add(MetadataMapping(value=value_dict["value"] if m.required else value_dict.get("value", None),
metadata_id=m.id, artifact_id=entity.id,
created_user_id=current_user.id))
dirty = True

if dirty:
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise

# THIS IS UGLY. FIGURE OUT WHY MERGE ISN'T WORKING
entity = yara_rule.Yara_rule.query.get(entity.id)
Expand All @@ -586,9 +630,6 @@ def update_yara_rule(id):
yara_rule_id=entity.id,
state=entity.state))

if get_new_sig_id:
update_cfg_category_range_mapping_current(request.json['category']['id'], temp_sig_id)

current_tags = get_tags_for_source(entity.__tablename__, entity.id)
new_tags = request.json['tags']
tags_to_delete, tags_to_create = [c_tag for c_tag in current_tags if c_tag not in new_tags], [n_tag for n_tag in
Expand Down Expand Up @@ -639,7 +680,11 @@ def delete_yara_rule(id):
abort(403)

db.session.merge(entity)
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise

# delete_tags_mapping(entity.__tablename__, entity.id)
delete_bookmarks(ENTITY_MAPPING["SIGNATURE"], id, current_user.id)
Expand All @@ -650,7 +695,11 @@ def delete_yara_rule(id):
db.session.query(yara_rule.Yara_rule_history).filter(
yara_rule.Yara_rule_history.yara_rule_id.in_([entity.id])).delete(synchronize_session='fetch')
db.session.delete(entity)
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise

delete_bookmarks(ENTITY_MAPPING["SIGNATURE"], id, current_user.id)

Expand Down Expand Up @@ -684,7 +733,7 @@ def copy_yara_rules():
Return: yara strings for copy"""

signatures = []
if 'copy' in request.json and request.json['copy']\
if 'copy' in request.json and request.json['copy'] \
and 'ids' in request.json['copy'] and request.json['copy']['ids']:
for sig_id in request.json['copy']['ids']:
sig = yara_rule.Yara_rule.query.get(sig_id)
Expand All @@ -709,5 +758,9 @@ def delete_all_inactive_yara_rules():
db.session.query(yara_rule.Yara_rule_history).filter(
yara_rule.Yara_rule_history.yara_rule_id.in_(rules_to_delete_ids)).delete(synchronize_session='fetch')
db.session.query(yara_rule.Yara_rule).filter(yara_rule.Yara_rule.active == 0).delete()
db.session.commit()
try:
db.session.commit()
except:
db.session.rollback()
raise
return jsonify(''), 200
7 changes: 6 additions & 1 deletion app/static/js/c2dns/c2dns-controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,10 @@ angular.module('ThreatKB')
sort_dir: null
};

$scope.customTooltip = function (row,col,value) {
return value.map(u => u.text).join(', ');
}

$scope.gridOptions = {
paginationPageSizes: [25, 50, 75, 100],
paginationPageSize: 25,
Expand Down Expand Up @@ -255,7 +259,8 @@ angular.module('ThreatKB')
displayName: 'Tags',
width: '180',
enableSorting: false,
cellTemplate: '<ul class="gridTags" append-to-body="true" ng-model="row.entity.tags">'
cellTemplate: '<div class="gridTags" title="{{grid.appScope.customTooltip(row,col,COL_FIELD)}}">'
+ '<ul class="gridTags" append-to-body="true" ng-model="row.entity.tags">'
+ '<li ng-repeat="tag in (row.entity.tags | filter: $select.search) track by tag.id">'
+ '<small>{{tag.text}}</small>'
+ '</li>'
Expand Down
6 changes: 5 additions & 1 deletion app/static/js/c2ip/c2ip-controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,9 @@ angular.module('ThreatKB')
sort_dir: null
};

$scope.customTooltip = function (row,col,value) {
return value.map(u => u.text).join(', ');
}
$scope.gridOptions = {
paginationPageSizes: [25, 50, 75, 100],
paginationPageSize: 25,
Expand Down Expand Up @@ -257,7 +260,8 @@ angular.module('ThreatKB')
displayName: 'Tags',
width: '180',
enableSorting: false,
cellTemplate: '<ul class="gridTags" append-to-body="true" ng-model="row.entity.tags">'
cellTemplate: '<div class="gridTags" title="{{grid.appScope.customTooltip(row,col,COL_FIELD)}}">'
+ '<ul class="gridTags" append-to-body="true" ng-model="row.entity.tags">'
+ '<li ng-repeat="tag in (row.entity.tags | filter: $select.search) track by tag.id">'
+ '<small>{{tag.text}}</small>'
+ '</li>'
Expand Down
Loading