You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@atlas.apache.org by ni...@apache.org on 2017/08/09 08:50:36 UTC

[1/2] atlas git commit: ATLAS-2027 : UI : Add type-name with attribute name in query-builder

Repository: atlas
Updated Branches:
  refs/heads/master 3f2d19150 -> fb28760a3


ATLAS-2027 : UI : Add type-name with attribute name in query-builder

Signed-off-by: nixonrodrigues <ni...@apache.org>


Project: http://git-wip-us.apache.org/repos/asf/atlas/repo
Commit: http://git-wip-us.apache.org/repos/asf/atlas/commit/1298c83d
Tree: http://git-wip-us.apache.org/repos/asf/atlas/tree/1298c83d
Diff: http://git-wip-us.apache.org/repos/asf/atlas/diff/1298c83d

Branch: refs/heads/master
Commit: 1298c83deba4269d4cf9fb9c525d4987f10d7fa3
Parents: 3f2d191
Author: kevalbhatt <kb...@apache.org>
Authored: Tue Aug 8 16:57:52 2017 +0530
Committer: nixonrodrigues <ni...@apache.org>
Committed: Wed Aug 9 13:55:26 2017 +0530

----------------------------------------------------------------------
 dashboardv2/public/js/views/search/QueryBuilderView.js | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/atlas/blob/1298c83d/dashboardv2/public/js/views/search/QueryBuilderView.js
----------------------------------------------------------------------
diff --git a/dashboardv2/public/js/views/search/QueryBuilderView.js b/dashboardv2/public/js/views/search/QueryBuilderView.js
index 6cdbeb3..ebef684 100644
--- a/dashboardv2/public/js/views/search/QueryBuilderView.js
+++ b/dashboardv2/public/js/views/search/QueryBuilderView.js
@@ -81,7 +81,7 @@ define(['require',
             getObjDef: function(attrObj, rules) {
                 var obj = {
                     id: attrObj.name,
-                    label: attrObj.name.capitalize(),
+                    label: attrObj.name.capitalize() + " (" + attrObj.typeName + ")",
                     type: attrObj.typeName
                 };
                 if (obj.type === "date") {
@@ -104,17 +104,17 @@ define(['require',
                     return obj;
                 }
                 if (this.isPrimitive(obj.type)) {
+                    if (obj.type === "boolean") {
+                        obj['input'] = 'select';
+                        obj['values'] = ['true', 'false'];
+                    }
+                    _.extend(obj, this.getOperator(obj.type));
                     if (obj.type === "long" || obj.type === "float") {
                         obj.type = "double";
                     }
                     if (obj.type === "int" || obj.type === "byte" || obj.type === "short") {
                         obj.type = "integer";
                     }
-                    if (obj.type === "boolean") {
-                        obj['input'] = 'select';
-                        obj['values'] = ['true', 'false'];
-                    }
-                    _.extend(obj, this.getOperator(obj.type));
                     return obj;
                 }
                 var enumObj = this.enumDefCollection.fullCollection.find({ name: obj.type });


[2/2] atlas git commit: ATLAS-2024: Updated Atlas TWiki for basic search functionality (ATLAS-1880)

Posted by ni...@apache.org.
ATLAS-2024: Updated Atlas TWiki for basic search functionality (ATLAS-1880)

Signed-off-by: nixonrodrigues <ni...@apache.org>


Project: http://git-wip-us.apache.org/repos/asf/atlas/repo
Commit: http://git-wip-us.apache.org/repos/asf/atlas/commit/fb28760a
Tree: http://git-wip-us.apache.org/repos/asf/atlas/tree/fb28760a
Diff: http://git-wip-us.apache.org/repos/asf/atlas/diff/fb28760a

Branch: refs/heads/master
Commit: fb28760a37aaec81df69b05936cc4234e20380ec
Parents: 1298c83
Author: apoorvnaik <ap...@apache.org>
Authored: Fri Aug 4 09:29:12 2017 -0700
Committer: nixonrodrigues <ni...@apache.org>
Committed: Wed Aug 9 13:57:21 2017 +0530

----------------------------------------------------------------------
 docs/src/site/twiki/Search.twiki | 211 ++++++++++++++++++++++++++++++----
 1 file changed, 188 insertions(+), 23 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/atlas/blob/fb28760a/docs/src/site/twiki/Search.twiki
----------------------------------------------------------------------
diff --git a/docs/src/site/twiki/Search.twiki b/docs/src/site/twiki/Search.twiki
index 173b053..6d17408 100644
--- a/docs/src/site/twiki/Search.twiki
+++ b/docs/src/site/twiki/Search.twiki
@@ -1,10 +1,175 @@
 ---+ Search
 
 Atlas exposes search over the metadata in two ways:
-   * Search using DSL
-   * Full-text search
+   * Basic Search
+   * Advanced Search (DSL or Full-Text)
 
----++ Search DSL Grammar
+---++ Basic search
+The basic search allows you to query using typename of an entity, associated classification/tag
+and has support for filtering on the entity attribute(s) as well as the classification/tag attributes.
+
+The entire query structure can be represented using the following JSON structure (called !SearchParameters)
+
+<verbatim>
+{
+  "typeName": "hive_table",
+  "excludeDeletedEntities": true,
+  "classification" : "",
+  "query": "",
+  "limit": 25,
+  "offset": 0,
+  "entityFilters": {
+   "attributeName": "name",
+   "operator": "contains",
+   "attributeValue": "testtable"
+  },
+  "tagFilters": null,
+  "attributes": [""]
+}
+</verbatim>
+
+__Field description__
+
+   * typeName: The type of entity to look for
+   * excludeDeletedEntities: Should the search include deleted entities too (default: true)
+   * classification: Only include entities with given Classification/tag
+   * query: Any free text occurrence that the entity should have (generic/wildcard queries might be slow)
+   * limit: Max number of results to fetch
+   * offset: Starting offset of the result set (useful for pagination)
+   * entityFilters: Entity Attribute filter(s)
+   * tagFilters: Classification/tag Attribute filter(s)
+   * attributes: Attributes to include in the search result (default: include any attribute present in the filter)
+
+   Attribute based filtering can be done on multiple attributes with AND/OR condition.
+
+    *NOTE: The tagFilters and entityFilters field have same JSON structure.*
+
+__Examples of filtering (for hive_table attributes)__
+   * Single attribute
+   <verbatim>
+   {
+     "typeName": "hive_table",
+     "excludeDeletedEntities": true,
+     "classification" : "",
+     "query": "",
+     "limit": 50,
+     "offset": 0,
+     "entityFilters": {
+        "attributeName": "name",
+        "operator": "contains",
+        "attributeValue": "testtable"
+     },
+     "tagFilters": null,
+     "attributes": [""]
+   }
+   </verbatim>
+   * Multi-attribute with OR
+   <verbatim>
+   {
+     "typeName": "hive_table",
+     "excludeDeletedEntities": true,
+     "classification" : "",
+     "query": "",
+     "limit": 50,
+     "offset": 0,
+     "entityFilters": {
+        "condition": "OR",
+        "criterion": [
+           {
+              "attributeName": "name",
+              "operator": "contains",
+              "attributeValue": "testtable"
+           },
+           {
+              "attributeName": "owner",
+              "operator": "eq",
+              "attributeValue": "admin"
+           }
+        ]
+     },
+     "tagFilters": null,
+     "attributes": [""]
+   }
+   </verbatim>
+   * Multi-attribute with AND
+   <verbatim>
+   {
+     "typeName": "hive_table",
+     "excludeDeletedEntities": true,
+     "classification" : "",
+     "query": "",
+     "limit": 50,
+     "offset": 0,
+     "entityFilters": {
+        "condition": "AND",
+        "criterion": [
+           {
+              "attributeName": "name",
+              "operator": "contains",
+              "attributeValue": "testtable"
+           },
+           {
+              "attributeName": "owner",
+              "operator": "eq",
+              "attributeValue": "admin"
+           }
+        ]
+     },
+     "tagFilters": null,
+     "attributes": [""]
+   }
+   </verbatim>
+
+__Supported operators for filtering__
+
+   * LT (symbols: <, lt) works with Numeric, Date attributes
+   * GT (symbols: >, gt) works with Numeric, Date attributes
+   * LTE (symbols: <=, lte) works with Numeric, Date attributes
+   * GTE (symbols: >=, gte) works with Numeric, Date attributes
+   * EQ (symbols: eq, =) works with Numeric, Date, String attributes
+   * NEQ (symbols: neq, !=) works with Numeric, Date, String attributes
+   * LIKE (symbols: like, LIKE) works with String attributes
+   * STARTS_WITH (symbols: startsWith, STARTSWITH) works with String attributes
+   * ENDS_WITH (symbols: endsWith, ENDSWITH) works with String attributes
+   * CONTAINS (symbols: contains, CONTAINS) works with String attributes
+
+__CURL Samples__
+
+<verbatim>
+    curl -sivk -g
+    -u <user>:<password>
+    -X POST
+    -d '{
+            "typeName": "hive_table",
+            "excludeDeletedEntities": true,
+            "classification" : "",
+            "query": "",
+            "limit": 50,
+            "offset": 0,
+            "entityFilters": {
+               "condition": "AND",
+               "criterion": [
+                  {
+                     "attributeName": "name",
+                     "operator": "contains",
+                     "attributeValue": "testtable"
+                  },
+                  {
+                     "attributeName": "owner",
+                     "operator": "eq",
+                     "attributeValue": "admin"
+                  }
+               ]
+            },
+            "tagFilters": null,
+            "attributes": [""]
+          }'
+    <protocol>://<atlas_host>:<atlas_port>/api/atlas/v2/search/basic
+</verbatim>
+
+---++ Advanced Search
+
+---+++ Search DSL Grammar
 The DSL exposes an SQL like query language for searching the metadata based on the type system.
 The grammar for the DSL is below.
 
@@ -16,9 +181,9 @@ query: querySrc ~ opt(loopExpression) ~ opt(groupByExpr) ~ opt(selectClause) ~ o
 querySrc: rep1sep(singleQrySrc, opt(COMMA))
 
 singleQrySrc = FROM ~ fromSrc ~ opt(WHERE) ~ opt(expr ^? notIdExpression) |
-        WHERE ~ (expr ^? notIdExpression) |
-        expr ^? notIdExpression |
-        fromSrc ~ opt(WHERE) ~ opt(expr ^? notIdExpression)
+      WHERE ~ (expr ^? notIdExpression) |
+      expr ^? notIdExpression |
+      fromSrc ~ opt(WHERE) ~ opt(expr ^? notIdExpression)
 
 fromSrc: identifier ~ AS ~ alias | identifier
 
@@ -51,10 +216,10 @@ expr:  compE ~ opt(rep(exprRight))
 exprRight: (AND | OR) ~ compE
 
 compE:
-        arithE ~ (LT | LTE | EQ | NEQ | GT | GTE) ~ arithE |
-            arithE ~ (ISA | IS) ~ ident  |
-            arithE ~ HAS ~ ident  |
-            arithE | countClause | maxClause | minClause | sumClause
+      arithE ~ (LT | LTE | EQ | NEQ | GT | GTE) ~ arithE |
+         arithE ~ (ISA | IS) ~ ident  |
+         arithE ~ HAS ~ ident  |
+         arithE | countClause | maxClause | minClause | sumClause
 
 arithE: multiE ~ opt(rep(arithERight))
 
@@ -71,18 +236,18 @@ identifier: rep1sep(ident, DOT)
 alias: ident | stringLit
 
 literal: booleanConstant |
-        intConstant  |
-        longConstant  |
-        floatConstant |
-        doubleConstant  |
-        stringLit
+      intConstant  |
+      longConstant  |
+      floatConstant |
+      doubleConstant  |
+      stringLit
 </verbatim>
 
 Grammar language:
 {noformat}
-opt(a)     => a is optional
-~            => a combinator. 'a ~ b' means a followed by b
-rep         => zero or more
+opt(a)    => a is optional
+~         => a combinator. 'a ~ b' means a followed by b
+rep       => zero or more
 rep1sep => one or more, separated by second arg.
 {noformat}
 
@@ -99,14 +264,14 @@ Language Notes:
   see scaladoc for 'org.apache.atlas.query.ClosureQuery')
    * GROUPBY is optional. Group by can be specified with aggregate methods like max, min, sum and count. When group by is specified aggregated results are returned based on the method specified in select clause. Select expression is mandatory with group by expression.
    * ORDERBY is optional. When order by clause is specified, case insensitive sorting is done based on the column specified.
-    For sorting in descending order specify 'DESC' after order by clause. If no order by is specified, then no default sorting is applied.
+   For sorting in descending order specify 'DESC' after order by clause. If no order by is specified, then no default sorting is applied.
    * LIMIT is optional. It limits the maximum number of objects to be fetched starting from specified optional offset. If no offset is specified count starts from beginning.
    * There are couple of Predicate functions different from SQL:
-      * _is_ or _isa_can be used to filter Entities that have a particular Trait.
-      * _has_ can be used to filter Entities that have a value for a particular Attribute.
+     * _is_ or _isa_can be used to filter Entities that have a particular Trait.
+     * _has_ can be used to filter Entities that have a value for a particular Attribute.
    * Any identifiers or constants with special characters(space,$,",{,}) should be enclosed within backquote (`)
 
----+++ DSL Examples
+---++++ DSL Examples
 For the model,
 Asset - attributes name, owner, description
 DB - supertype Asset - attributes clusterName, parameters, comment
@@ -133,6 +298,6 @@ DSL queries:
    * from Person select count() as 'count', max(Person.age) as 'max', min(Person.age)
    * `Log Data`
 
----++ Full-text Search
+---+++ Full-text Search
 
 Atlas also exposes a lucene style full-text search capability.
\ No newline at end of file