From f8c7cd4c6b89d3d81f14cf7cc7877fd823e0424d Mon Sep 17 00:00:00 2001
From: Will Kahn-Greene
Use this parameter to get a large number of results instead of setting
- an arbitraty big _results_offset
_results_number
value. Run queries in a
+ an arbitrary big _results_number
value. Run queries in a
loop, incrementing this by the value of _results_number
,
and concatenate the content of the hits
key.
_aggs.*
run an aggregation on field_1
, then for each bucket of
that aggregation, it will aggregate on field_2
, and then
for each bucket of that sub-aggregation, it will aggregate on
- field_3
. Theoratically, we could have any number of
+ field_3
. Theoretically, we could have any number of
levels of aggregations, but in practice we only allow all "level 1"
aggregations, and a few "level 2" and "level 3".
OOM | small
")
)
+
+ def test_get_fields(self, db, user_helper):
+ # Create anonymous user and get fields
+ user = AnonymousUser()
+ fields = get_fields(user)
+ len_public_fields = len(fields)
+ assert len(fields) > 0
+
+ # Create user with protected data access, get fields, and make sure there are
+ # more of them than if the user didn't have protected data access
+ user = user_helper.create_protected_user()
+ fields = get_fields(user)
+ assert len(fields) > len_public_fields
diff --git a/webapp/crashstats/signature/views.py b/webapp/crashstats/signature/views.py
index 30a7c2f686..5454f32f15 100644
--- a/webapp/crashstats/signature/views.py
+++ b/webapp/crashstats/signature/views.py
@@ -71,6 +71,27 @@ def inner(request, *args, **kwargs):
return inner
+def get_fields(user):
+ """Retrieve super search fields this user has access to
+
+ :arg user: a Django User instance
+
+ :returns: a list of dicts with "id" and "text" keys
+
+ """
+ print(repr(user), user)
+ fields = sorted(
+ x["name"]
+ for x in SuperSearchFields().get().values()
+ if x["is_exposed"]
+ and x["is_returned"]
+ and user.has_perms(x["webapp_permissions_needed"])
+ and x["name"] != "signature" # exclude the signature field
+ )
+
+ return [{"id": field, "text": field.replace("_", " ")} for field in fields]
+
+
@track_view
@csp_update(CONNECT_SRC="analysis-output.telemetry.mozilla.org")
@pass_validated_params
@@ -84,17 +105,8 @@ def signature_report(request, params, default_context=None):
context["signature"] = signature
- fields = sorted(
- x["name"]
- for x in SuperSearchFields().get().values()
- if x["is_exposed"]
- and x["is_returned"]
- and request.user.has_perms(x["permissions_needed"])
- and x["name"] != "signature" # exclude the signature field
- )
- context["fields"] = [
- {"id": field, "text": field.replace("_", " ")} for field in fields
- ]
+ fields = get_fields(request.user)
+ context["fields"] = fields
columns = request.GET.getlist("_columns")
columns = [x for x in columns if x in fields]
From 3e1f10b8ca844fc584e0f5be46f9b912fc5d4330 Mon Sep 17 00:00:00 2001
From: Will Kahn-Greene