Skip to main content

%DeepSee.REST.v1

Class %DeepSee.REST.v1 Extends %DeepSee.REST.REST

This class provides validation and dispatch for version 1 of the DeepSee REST services In general, required arguments are expected in the URL. The exceptions to this rule are /Data/MDXExecute and /Data/PivotExecute, which require an argument POSTed to the the body of the request. For some services, the client may POST additional parameters in the body of the request. The description for each service outlines the parameters accepted for that particular service. In all services, unknown parameters that are included in the request body are ignored.

Example: Execute an MDX query using an HTTP POST request, sent to a web application with Dispatch class %DeepSee.REST.v1. var request = {}; var mdx = 'SELECT ' + ' NON EMPTY [Product].[P1].[Product Category].Members ON 0,' + ' NON EMPTY [Outlet].[H1].[Region].Members ON 1 ' + 'FROM [HoleFoods]' request.method = 'POST'; request.user = 'user'; request.passwd = 'pass'; request.acceptType = 'JSON'; request.contentType = 'JSON'; request.body = '{"MDX":"' + mdx + '"}'; request.callback = custom.queryCallBack request.async = true; request.url = 'http://host/port/restApplication/v1/Data/MDX'; // run the query var xhr = new XMLHttpRequest(); xhr.open(request.method,request.url,request.async); // kick off the request xhr.send(contents); Requests may be sent to the following services:

  • /Data/TestConnection or /Info/TestConnection - get test info to confirm connection to the server.
  • /Data/MDXExecute - get result in JSON format for MDX query. POST the query in the required property "MDX". The server will assume the client wishes to wait for complete results before sending a response. The default timeout for this wait is 2 seconds less than the session's timeout setting. This can be set using the TIMEOUT property in the request.
    The client can optionally instruct the server to send partial results by POSTing "WAIT":0. request.body = '{ "MDX": "SELECT FROM PATIENTS",' + ' "FILTERS": [' + ' "[HomeD].[H1].[ZIP].&[32006]",' + ' "%OR({[PatGrpD].[H1].[Patient Group].&[Group A],[PatGrpD].[H1].[Patient Group].&[Group B]})"' + ' ]' + ' "WAIT":1' + ' "TIMEOUT":30' + '};'
  • /Data/PivotExecute - get result in JSON format for a stored pivot table. POST the full name (Folder/SubFolder/Name) of the table in the required property "PIVOT". Filters may be optionally be POSTed in the FILTERS property of the request. These filters take the identical form as described in /Data/MDXExecute. This service also supports the WAIT and TIMEOUT options. A pivot table that supports pivot variables may have those variables set using the VARIABLES array in the request. request.body = '{ "PIVOT":"Pivot Variables/Commission Calculator",' + ' "VARIABLES": [' + ' "name":"commissionpercentage",' + ' "value":15' + ' ]' + '};'
  • /Data/KPIExecute - execute a KPI. POST the logical name of KPI in "KPI". Filters may be added as an array of objects in "FILTER". Each of the filter objects must provide a "name" and a "value" property. request.body = '{ "KPI": "DemoMDX",' + ' "FILTERS": [ {' + ' "name" : "[aged].[h1].[age group]",' + ' "value" : "&[0 to 29]" }' + ' ]' + '};'
  • /Data/MDXDrillthrough - execute a detail listing on the cube's source class. POST the query in "MDX". DRILLTHROUGH requests will support a list of RETURN fields in the request, or a choice of LISTING. Attempting to post both will result in an error. request.body = '{ "MDX": "DRILLTHROUGH SELECT FROM [PATIENTS]",' + ' "LISTING":"Doctor details"' + '};' request.body = '{ "MDX": "DRILLTHROUGH SELECT FROM [PATIENTS]",' + ' "RETURN":"Age,BirthDate"' + '};'
  • /Data/MDXCancelQuery/:queryID - if a previous query has not completed, it can be canceled.
  • /Data/MDXUpdateResults/:queryID - given a previous query response with ResultsComplete = 0, the client can request an update to the results using the cubeKey and queryKey.
  • /Info/Filters/:dataSource - to get a list of filters available for a particular cube.
  • /Info/FilterMembers/:dataSource/:filterSpec/ - get a list of values for a particular filter. Supported dataSources are cubes and KPIs. Values can be limited by POSTing values of other filters or a search key in the request.
    request.body = '{ "RELATED": [' + ' {' + ' "spec": "[DateOfSale].[Actual].[YearSold]",' + ' "value": "&[2013]:&[2016]"' + ' }' + ' ],' + ' "SEARCHKEY":"Jan"' + '}';
  • /Info/Cubes/ - get a list of cubes available in the namespace.
  • /Info/Pivots/ - get a list of pivots available. The listing can be limited to pivots based on a particular cube by POST to the BASECUBE property in the request. request.body = '{"BASECUBE":"HOLEFOODS"}'
  • /Info/Dashboards/ - get a list of available dashboards.
  • /Info/Listings/:cube - get a list of available listings for a particular cube.
  • /Info/Measures/:cube - get a list of measures available for a particular cube.
  • /Info/ListingFields/:cube - get the list of listing fields defined for a particular cube, for user-defined custom listings.
  • /Info/NamedFilters/:cube - get a list of named filters defined for a cube.
  • /Info/PivotVariables/:cube - get a list of pivot variables defined a cube.
  • /Info/PivotVariableDetails/:cube/:variable - get the details for a single pivot variable.
  • /Info/QualityMeasures/:cube - get a list of quality measures available fo rthe cube.

XDatas

UrlMap

XData UrlMap

Methods

%ValidateRequest

ClassMethod %ValidateRequest(pUrl As %String, pMethod As %String) As %Status

Verfies required Converts request body