UNPKG

appcenter-cli

Version:

Command line tool for Visual Studio App Center

1,247 lines (1,216 loc) 371 kB
/* * Copyright (c) Microsoft Corporation. All rights reserved. * Licensed under the MIT License. See License.txt in the project root for * license information. * * Code generated by Microsoft (R) AutoRest Code Generator. * Changes may cause incorrect behavior and will be lost if the code is * regenerated. */ 'use strict'; const msRest = require('ms-rest'); const WebResource = msRest.WebResource; /** * Count of active versions in the time range ordered by version. * * @param {date} start Start date time in data in ISO 8601 date time format * * @param {string} ownerName The name of the owner * * @param {string} appName The name of the application * * @param {object} [options] Optional Parameters. * * @param {date} [options.end] Last date time in data in ISO 8601 date time * format * * @param {number} [options.top] The maximum number of results to return. (0 * will fetch all results) * * @param {array} [options.versions] * * @param {object} [options.customHeaders] Headers that will be added to the * request * * @param {function} callback - The callback. * * @returns {function} callback(err, result, request, response) * * {Error} err - The Error object if an error occurred, null otherwise. * * {object} [result] - The deserialized result object if an error did not occur. * See {@link Versions} for more information. * * {object} [request] - The HTTP Request object if an error did not occur. * * {stream} [response] - The HTTP Response stream if an error did not occur. */ function _versionsMethod(start, ownerName, appName, options, callback) { /* jshint validthis: true */ let client = this.client; if(!callback && typeof options === 'function') { callback = options; options = null; } if (!callback) { throw new Error('callback cannot be null.'); } let end = (options && options.end !== undefined) ? options.end : undefined; let top = (options && options.top !== undefined) ? options.top : 30; let versions = (options && options.versions !== undefined) ? options.versions : undefined; // Validate try { if(!start || !(start instanceof Date || (typeof start.valueOf() === 'string' && !isNaN(Date.parse(start))))) { throw new Error('start cannot be null or undefined and it must be of type date.'); } if (end && !(end instanceof Date || (typeof end.valueOf() === 'string' && !isNaN(Date.parse(end))))) { throw new Error('end must be of type date.'); } if (top !== null && top !== undefined && typeof top !== 'number') { throw new Error('top must be of type number.'); } if (top !== null && top !== undefined) { if (top > 2000) { throw new Error('"top" should satisfy the constraint - "InclusiveMaximum": 2000'); } if (top < 0) { throw new Error('"top" should satisfy the constraint - "InclusiveMinimum": 0'); } } if (Array.isArray(versions)) { for (let i = 0; i < versions.length; i++) { if (versions[i] !== null && versions[i] !== undefined && typeof versions[i].valueOf() !== 'string') { throw new Error('versions[i] must be of type string.'); } } } if (ownerName === null || ownerName === undefined || typeof ownerName.valueOf() !== 'string') { throw new Error('ownerName cannot be null or undefined and it must be of type string.'); } if (appName === null || appName === undefined || typeof appName.valueOf() !== 'string') { throw new Error('appName cannot be null or undefined and it must be of type string.'); } } catch (error) { return callback(error); } // Construct URL let baseUrl = this.client.baseUri; let requestUrl = baseUrl + (baseUrl.endsWith('/') ? '' : '/') + 'v0.1/apps/{owner_name}/{app_name}/analytics/versions'; requestUrl = requestUrl.replace('{owner_name}', encodeURIComponent(ownerName)); requestUrl = requestUrl.replace('{app_name}', encodeURIComponent(appName)); let queryParameters = []; queryParameters.push('start=' + encodeURIComponent(client.serializeObject(start))); if (end !== null && end !== undefined) { queryParameters.push('end=' + encodeURIComponent(client.serializeObject(end))); } if (top !== null && top !== undefined) { queryParameters.push('$top=' + encodeURIComponent(top.toString())); } if (versions !== null && versions !== undefined) { queryParameters.push('versions=' + encodeURIComponent(versions.join('|'))); } if (queryParameters.length > 0) { requestUrl += '?' + queryParameters.join('&'); } // Create HTTP transport objects let httpRequest = new WebResource(); httpRequest.method = 'GET'; httpRequest.url = requestUrl; httpRequest.headers = {}; // Set Headers httpRequest.headers['Content-Type'] = 'application/json; charset=utf-8'; if(options) { for(let headerName in options['customHeaders']) { if (options['customHeaders'].hasOwnProperty(headerName)) { httpRequest.headers[headerName] = options['customHeaders'][headerName]; } } } httpRequest.body = null; // Send Request return client.pipeline(httpRequest, (err, response, responseBody) => { if (err) { return callback(err); } let statusCode = response.statusCode; if (statusCode !== 200) { let error = new Error(responseBody); error.statusCode = response.statusCode; error.request = msRest.stripRequest(httpRequest); error.response = msRest.stripResponse(response); if (responseBody === '') responseBody = null; let parsedErrorResponse; try { parsedErrorResponse = JSON.parse(responseBody); if (parsedErrorResponse) { let internalError = null; if (parsedErrorResponse.error) internalError = parsedErrorResponse.error; error.code = internalError ? internalError.code : parsedErrorResponse.code; error.message = internalError ? internalError.message : parsedErrorResponse.message; } if (parsedErrorResponse !== null && parsedErrorResponse !== undefined) { let resultMapper = new client.models['ErrorModel']().mapper(); error.body = client.deserialize(resultMapper, parsedErrorResponse, 'error.body'); } } catch (defaultError) { error.message = `Error "${defaultError.message}" occurred in deserializing the responseBody ` + `- "${responseBody}" for the default response.`; return callback(error); } return callback(error); } // Create Result let result = null; if (responseBody === '') responseBody = null; // Deserialize Response if (statusCode === 200) { let parsedResponse = null; try { parsedResponse = JSON.parse(responseBody); result = JSON.parse(responseBody); if (parsedResponse !== null && parsedResponse !== undefined) { let resultMapper = new client.models['Versions']().mapper(); result = client.deserialize(resultMapper, parsedResponse, 'result'); } } catch (error) { let deserializationError = new Error(`Error ${error} occurred in deserializing the responseBody - ${responseBody}`); deserializationError.request = msRest.stripRequest(httpRequest); deserializationError.response = msRest.stripResponse(response); return callback(deserializationError); } } return callback(null, result, httpRequest, response); }); } /** * Count of sessions per device in the time range * * @param {date} start Start date time in data in ISO 8601 date time format * * @param {string} interval Size of interval in ISO 8601 duration format. * (PnYnMnDTnHnMnS|PnW|P<date>T<time>). The valid durations are 1 day (P1D), 1 * week (P1W), and 30 days (P30D). * * @param {string} ownerName The name of the owner * * @param {string} appName The name of the application * * @param {object} [options] Optional Parameters. * * @param {date} [options.end] Last date time in data in ISO 8601 date time * format * * @param {array} [options.versions] * * @param {object} [options.customHeaders] Headers that will be added to the * request * * @param {function} callback - The callback. * * @returns {function} callback(err, result, request, response) * * {Error} err - The Error object if an error occurred, null otherwise. * * {object} [result] - The deserialized result object if an error did not occur. * See {@link SessionsPerDevice} for more information. * * {object} [request] - The HTTP Request object if an error did not occur. * * {stream} [response] - The HTTP Response stream if an error did not occur. */ function _perDeviceCounts(start, interval, ownerName, appName, options, callback) { /* jshint validthis: true */ let client = this.client; if(!callback && typeof options === 'function') { callback = options; options = null; } if (!callback) { throw new Error('callback cannot be null.'); } let end = (options && options.end !== undefined) ? options.end : undefined; let versions = (options && options.versions !== undefined) ? options.versions : undefined; // Validate try { if(!start || !(start instanceof Date || (typeof start.valueOf() === 'string' && !isNaN(Date.parse(start))))) { throw new Error('start cannot be null or undefined and it must be of type date.'); } if (end && !(end instanceof Date || (typeof end.valueOf() === 'string' && !isNaN(Date.parse(end))))) { throw new Error('end must be of type date.'); } if (interval === null || interval === undefined || typeof interval.valueOf() !== 'string') { throw new Error('interval cannot be null or undefined and it must be of type string.'); } if (Array.isArray(versions)) { for (let i = 0; i < versions.length; i++) { if (versions[i] !== null && versions[i] !== undefined && typeof versions[i].valueOf() !== 'string') { throw new Error('versions[i] must be of type string.'); } } } if (ownerName === null || ownerName === undefined || typeof ownerName.valueOf() !== 'string') { throw new Error('ownerName cannot be null or undefined and it must be of type string.'); } if (appName === null || appName === undefined || typeof appName.valueOf() !== 'string') { throw new Error('appName cannot be null or undefined and it must be of type string.'); } } catch (error) { return callback(error); } // Construct URL let baseUrl = this.client.baseUri; let requestUrl = baseUrl + (baseUrl.endsWith('/') ? '' : '/') + 'v0.1/apps/{owner_name}/{app_name}/analytics/sessions_per_device'; requestUrl = requestUrl.replace('{owner_name}', encodeURIComponent(ownerName)); requestUrl = requestUrl.replace('{app_name}', encodeURIComponent(appName)); let queryParameters = []; queryParameters.push('start=' + encodeURIComponent(client.serializeObject(start))); if (end !== null && end !== undefined) { queryParameters.push('end=' + encodeURIComponent(client.serializeObject(end))); } queryParameters.push('interval=' + encodeURIComponent(interval)); if (versions !== null && versions !== undefined) { queryParameters.push('versions=' + encodeURIComponent(versions.join('|'))); } if (queryParameters.length > 0) { requestUrl += '?' + queryParameters.join('&'); } // Create HTTP transport objects let httpRequest = new WebResource(); httpRequest.method = 'GET'; httpRequest.url = requestUrl; httpRequest.headers = {}; // Set Headers httpRequest.headers['Content-Type'] = 'application/json; charset=utf-8'; if(options) { for(let headerName in options['customHeaders']) { if (options['customHeaders'].hasOwnProperty(headerName)) { httpRequest.headers[headerName] = options['customHeaders'][headerName]; } } } httpRequest.body = null; // Send Request return client.pipeline(httpRequest, (err, response, responseBody) => { if (err) { return callback(err); } let statusCode = response.statusCode; if (statusCode !== 200) { let error = new Error(responseBody); error.statusCode = response.statusCode; error.request = msRest.stripRequest(httpRequest); error.response = msRest.stripResponse(response); if (responseBody === '') responseBody = null; let parsedErrorResponse; try { parsedErrorResponse = JSON.parse(responseBody); if (parsedErrorResponse) { let internalError = null; if (parsedErrorResponse.error) internalError = parsedErrorResponse.error; error.code = internalError ? internalError.code : parsedErrorResponse.code; error.message = internalError ? internalError.message : parsedErrorResponse.message; } if (parsedErrorResponse !== null && parsedErrorResponse !== undefined) { let resultMapper = new client.models['ErrorModel']().mapper(); error.body = client.deserialize(resultMapper, parsedErrorResponse, 'error.body'); } } catch (defaultError) { error.message = `Error "${defaultError.message}" occurred in deserializing the responseBody ` + `- "${responseBody}" for the default response.`; return callback(error); } return callback(error); } // Create Result let result = null; if (responseBody === '') responseBody = null; // Deserialize Response if (statusCode === 200) { let parsedResponse = null; try { parsedResponse = JSON.parse(responseBody); result = JSON.parse(responseBody); if (parsedResponse !== null && parsedResponse !== undefined) { let resultMapper = new client.models['SessionsPerDevice']().mapper(); result = client.deserialize(resultMapper, parsedResponse, 'result'); } } catch (error) { let deserializationError = new Error(`Error ${error} occurred in deserializing the responseBody - ${responseBody}`); deserializationError.request = msRest.stripRequest(httpRequest); deserializationError.response = msRest.stripResponse(response); return callback(deserializationError); } } return callback(null, result, httpRequest, response); }); } /** * Gets session duration . * * @param {date} start Start date time in data in ISO 8601 date time format * * @param {string} ownerName The name of the owner * * @param {string} appName The name of the application * * @param {object} [options] Optional Parameters. * * @param {date} [options.end] Last date time in data in ISO 8601 date time * format * * @param {array} [options.versions] * * @param {object} [options.customHeaders] Headers that will be added to the * request * * @param {function} callback - The callback. * * @returns {function} callback(err, result, request, response) * * {Error} err - The Error object if an error occurred, null otherwise. * * {object} [result] - The deserialized result object if an error did not occur. * See {@link SessionDurationsDistribution} for more * information. * * {object} [request] - The HTTP Request object if an error did not occur. * * {stream} [response] - The HTTP Response stream if an error did not occur. */ function _sessionDurationsDistributionMethod(start, ownerName, appName, options, callback) { /* jshint validthis: true */ let client = this.client; if(!callback && typeof options === 'function') { callback = options; options = null; } if (!callback) { throw new Error('callback cannot be null.'); } let end = (options && options.end !== undefined) ? options.end : undefined; let versions = (options && options.versions !== undefined) ? options.versions : undefined; // Validate try { if(!start || !(start instanceof Date || (typeof start.valueOf() === 'string' && !isNaN(Date.parse(start))))) { throw new Error('start cannot be null or undefined and it must be of type date.'); } if (end && !(end instanceof Date || (typeof end.valueOf() === 'string' && !isNaN(Date.parse(end))))) { throw new Error('end must be of type date.'); } if (Array.isArray(versions)) { for (let i = 0; i < versions.length; i++) { if (versions[i] !== null && versions[i] !== undefined && typeof versions[i].valueOf() !== 'string') { throw new Error('versions[i] must be of type string.'); } } } if (ownerName === null || ownerName === undefined || typeof ownerName.valueOf() !== 'string') { throw new Error('ownerName cannot be null or undefined and it must be of type string.'); } if (appName === null || appName === undefined || typeof appName.valueOf() !== 'string') { throw new Error('appName cannot be null or undefined and it must be of type string.'); } } catch (error) { return callback(error); } // Construct URL let baseUrl = this.client.baseUri; let requestUrl = baseUrl + (baseUrl.endsWith('/') ? '' : '/') + 'v0.1/apps/{owner_name}/{app_name}/analytics/session_durations_distribution'; requestUrl = requestUrl.replace('{owner_name}', encodeURIComponent(ownerName)); requestUrl = requestUrl.replace('{app_name}', encodeURIComponent(appName)); let queryParameters = []; queryParameters.push('start=' + encodeURIComponent(client.serializeObject(start))); if (end !== null && end !== undefined) { queryParameters.push('end=' + encodeURIComponent(client.serializeObject(end))); } if (versions !== null && versions !== undefined) { queryParameters.push('versions=' + encodeURIComponent(versions.join('|'))); } if (queryParameters.length > 0) { requestUrl += '?' + queryParameters.join('&'); } // Create HTTP transport objects let httpRequest = new WebResource(); httpRequest.method = 'GET'; httpRequest.url = requestUrl; httpRequest.headers = {}; // Set Headers httpRequest.headers['Content-Type'] = 'application/json; charset=utf-8'; if(options) { for(let headerName in options['customHeaders']) { if (options['customHeaders'].hasOwnProperty(headerName)) { httpRequest.headers[headerName] = options['customHeaders'][headerName]; } } } httpRequest.body = null; // Send Request return client.pipeline(httpRequest, (err, response, responseBody) => { if (err) { return callback(err); } let statusCode = response.statusCode; if (statusCode !== 200) { let error = new Error(responseBody); error.statusCode = response.statusCode; error.request = msRest.stripRequest(httpRequest); error.response = msRest.stripResponse(response); if (responseBody === '') responseBody = null; let parsedErrorResponse; try { parsedErrorResponse = JSON.parse(responseBody); if (parsedErrorResponse) { let internalError = null; if (parsedErrorResponse.error) internalError = parsedErrorResponse.error; error.code = internalError ? internalError.code : parsedErrorResponse.code; error.message = internalError ? internalError.message : parsedErrorResponse.message; } if (parsedErrorResponse !== null && parsedErrorResponse !== undefined) { let resultMapper = new client.models['ErrorModel']().mapper(); error.body = client.deserialize(resultMapper, parsedErrorResponse, 'error.body'); } } catch (defaultError) { error.message = `Error "${defaultError.message}" occurred in deserializing the responseBody ` + `- "${responseBody}" for the default response.`; return callback(error); } return callback(error); } // Create Result let result = null; if (responseBody === '') responseBody = null; // Deserialize Response if (statusCode === 200) { let parsedResponse = null; try { parsedResponse = JSON.parse(responseBody); result = JSON.parse(responseBody); if (parsedResponse !== null && parsedResponse !== undefined) { let resultMapper = new client.models['SessionDurationsDistribution']().mapper(); result = client.deserialize(resultMapper, parsedResponse, 'result'); } } catch (error) { let deserializationError = new Error(`Error ${error} occurred in deserializing the responseBody - ${responseBody}`); deserializationError.request = msRest.stripRequest(httpRequest); deserializationError.response = msRest.stripResponse(response); return callback(deserializationError); } } return callback(null, result, httpRequest, response); }); } /** * Count of sessions in the time range. * * @param {date} start Start date time in data in ISO 8601 date time format * * @param {string} interval Size of interval in ISO 8601 duration format. * (PnYnMnDTnHnMnS|PnW|P<date>T<time>). The valid durations are 1 day (P1D), 1 * week (P1W), and 30 days (P30D). * * @param {string} ownerName The name of the owner * * @param {string} appName The name of the application * * @param {object} [options] Optional Parameters. * * @param {date} [options.end] Last date time in data in ISO 8601 date time * format * * @param {array} [options.versions] * * @param {object} [options.customHeaders] Headers that will be added to the * request * * @param {function} callback - The callback. * * @returns {function} callback(err, result, request, response) * * {Error} err - The Error object if an error occurred, null otherwise. * * {array} [result] - The deserialized result object if an error did not occur. * * {object} [request] - The HTTP Request object if an error did not occur. * * {stream} [response] - The HTTP Response stream if an error did not occur. */ function _sessionCounts(start, interval, ownerName, appName, options, callback) { /* jshint validthis: true */ let client = this.client; if(!callback && typeof options === 'function') { callback = options; options = null; } if (!callback) { throw new Error('callback cannot be null.'); } let end = (options && options.end !== undefined) ? options.end : undefined; let versions = (options && options.versions !== undefined) ? options.versions : undefined; // Validate try { if(!start || !(start instanceof Date || (typeof start.valueOf() === 'string' && !isNaN(Date.parse(start))))) { throw new Error('start cannot be null or undefined and it must be of type date.'); } if (end && !(end instanceof Date || (typeof end.valueOf() === 'string' && !isNaN(Date.parse(end))))) { throw new Error('end must be of type date.'); } if (interval === null || interval === undefined || typeof interval.valueOf() !== 'string') { throw new Error('interval cannot be null or undefined and it must be of type string.'); } if (Array.isArray(versions)) { for (let i = 0; i < versions.length; i++) { if (versions[i] !== null && versions[i] !== undefined && typeof versions[i].valueOf() !== 'string') { throw new Error('versions[i] must be of type string.'); } } } if (ownerName === null || ownerName === undefined || typeof ownerName.valueOf() !== 'string') { throw new Error('ownerName cannot be null or undefined and it must be of type string.'); } if (appName === null || appName === undefined || typeof appName.valueOf() !== 'string') { throw new Error('appName cannot be null or undefined and it must be of type string.'); } } catch (error) { return callback(error); } // Construct URL let baseUrl = this.client.baseUri; let requestUrl = baseUrl + (baseUrl.endsWith('/') ? '' : '/') + 'v0.1/apps/{owner_name}/{app_name}/analytics/session_counts'; requestUrl = requestUrl.replace('{owner_name}', encodeURIComponent(ownerName)); requestUrl = requestUrl.replace('{app_name}', encodeURIComponent(appName)); let queryParameters = []; queryParameters.push('start=' + encodeURIComponent(client.serializeObject(start))); if (end !== null && end !== undefined) { queryParameters.push('end=' + encodeURIComponent(client.serializeObject(end))); } queryParameters.push('interval=' + encodeURIComponent(interval)); if (versions !== null && versions !== undefined) { queryParameters.push('versions=' + encodeURIComponent(versions.join('|'))); } if (queryParameters.length > 0) { requestUrl += '?' + queryParameters.join('&'); } // Create HTTP transport objects let httpRequest = new WebResource(); httpRequest.method = 'GET'; httpRequest.url = requestUrl; httpRequest.headers = {}; // Set Headers httpRequest.headers['Content-Type'] = 'application/json; charset=utf-8'; if(options) { for(let headerName in options['customHeaders']) { if (options['customHeaders'].hasOwnProperty(headerName)) { httpRequest.headers[headerName] = options['customHeaders'][headerName]; } } } httpRequest.body = null; // Send Request return client.pipeline(httpRequest, (err, response, responseBody) => { if (err) { return callback(err); } let statusCode = response.statusCode; if (statusCode !== 200) { let error = new Error(responseBody); error.statusCode = response.statusCode; error.request = msRest.stripRequest(httpRequest); error.response = msRest.stripResponse(response); if (responseBody === '') responseBody = null; let parsedErrorResponse; try { parsedErrorResponse = JSON.parse(responseBody); if (parsedErrorResponse) { let internalError = null; if (parsedErrorResponse.error) internalError = parsedErrorResponse.error; error.code = internalError ? internalError.code : parsedErrorResponse.code; error.message = internalError ? internalError.message : parsedErrorResponse.message; } if (parsedErrorResponse !== null && parsedErrorResponse !== undefined) { let resultMapper = new client.models['ErrorResponse']().mapper(); error.body = client.deserialize(resultMapper, parsedErrorResponse, 'error.body'); } } catch (defaultError) { error.message = `Error "${defaultError.message}" occurred in deserializing the responseBody ` + `- "${responseBody}" for the default response.`; return callback(error); } return callback(error); } // Create Result let result = null; if (responseBody === '') responseBody = null; // Deserialize Response if (statusCode === 200) { let parsedResponse = null; try { parsedResponse = JSON.parse(responseBody); result = JSON.parse(responseBody); if (parsedResponse !== null && parsedResponse !== undefined) { let resultMapper = { required: false, serializedName: 'parsedResponse', type: { name: 'Sequence', element: { required: false, serializedName: 'DateTimeCountsElementType', type: { name: 'Composite', className: 'DateTimeCounts' } } } }; result = client.deserialize(resultMapper, parsedResponse, 'result'); } } catch (error) { let deserializationError = new Error(`Error ${error} occurred in deserializing the responseBody - ${responseBody}`); deserializationError.request = msRest.stripRequest(httpRequest); deserializationError.response = msRest.stripResponse(response); return callback(deserializationError); } } return callback(null, result, httpRequest, response); }); } /** * Places in the time range * * @param {date} start Start date time in data in ISO 8601 date time format * * @param {string} ownerName The name of the owner * * @param {string} appName The name of the application * * @param {object} [options] Optional Parameters. * * @param {date} [options.end] Last date time in data in ISO 8601 date time * format * * @param {number} [options.top] The maximum number of results to return. (0 * will fetch all results) * * @param {array} [options.versions] * * @param {object} [options.customHeaders] Headers that will be added to the * request * * @param {function} callback - The callback. * * @returns {function} callback(err, result, request, response) * * {Error} err - The Error object if an error occurred, null otherwise. * * {object} [result] - The deserialized result object if an error did not occur. * See {@link Places} for more information. * * {object} [request] - The HTTP Request object if an error did not occur. * * {stream} [response] - The HTTP Response stream if an error did not occur. */ function _placeCounts(start, ownerName, appName, options, callback) { /* jshint validthis: true */ let client = this.client; if(!callback && typeof options === 'function') { callback = options; options = null; } if (!callback) { throw new Error('callback cannot be null.'); } let end = (options && options.end !== undefined) ? options.end : undefined; let top = (options && options.top !== undefined) ? options.top : 30; let versions = (options && options.versions !== undefined) ? options.versions : undefined; // Validate try { if(!start || !(start instanceof Date || (typeof start.valueOf() === 'string' && !isNaN(Date.parse(start))))) { throw new Error('start cannot be null or undefined and it must be of type date.'); } if (end && !(end instanceof Date || (typeof end.valueOf() === 'string' && !isNaN(Date.parse(end))))) { throw new Error('end must be of type date.'); } if (top !== null && top !== undefined && typeof top !== 'number') { throw new Error('top must be of type number.'); } if (top !== null && top !== undefined) { if (top > 2000) { throw new Error('"top" should satisfy the constraint - "InclusiveMaximum": 2000'); } if (top < 0) { throw new Error('"top" should satisfy the constraint - "InclusiveMinimum": 0'); } } if (Array.isArray(versions)) { for (let i = 0; i < versions.length; i++) { if (versions[i] !== null && versions[i] !== undefined && typeof versions[i].valueOf() !== 'string') { throw new Error('versions[i] must be of type string.'); } } } if (ownerName === null || ownerName === undefined || typeof ownerName.valueOf() !== 'string') { throw new Error('ownerName cannot be null or undefined and it must be of type string.'); } if (appName === null || appName === undefined || typeof appName.valueOf() !== 'string') { throw new Error('appName cannot be null or undefined and it must be of type string.'); } } catch (error) { return callback(error); } // Construct URL let baseUrl = this.client.baseUri; let requestUrl = baseUrl + (baseUrl.endsWith('/') ? '' : '/') + 'v0.1/apps/{owner_name}/{app_name}/analytics/places'; requestUrl = requestUrl.replace('{owner_name}', encodeURIComponent(ownerName)); requestUrl = requestUrl.replace('{app_name}', encodeURIComponent(appName)); let queryParameters = []; queryParameters.push('start=' + encodeURIComponent(client.serializeObject(start))); if (end !== null && end !== undefined) { queryParameters.push('end=' + encodeURIComponent(client.serializeObject(end))); } if (top !== null && top !== undefined) { queryParameters.push('$top=' + encodeURIComponent(top.toString())); } if (versions !== null && versions !== undefined) { queryParameters.push('versions=' + encodeURIComponent(versions.join('|'))); } if (queryParameters.length > 0) { requestUrl += '?' + queryParameters.join('&'); } // Create HTTP transport objects let httpRequest = new WebResource(); httpRequest.method = 'GET'; httpRequest.url = requestUrl; httpRequest.headers = {}; // Set Headers httpRequest.headers['Content-Type'] = 'application/json; charset=utf-8'; if(options) { for(let headerName in options['customHeaders']) { if (options['customHeaders'].hasOwnProperty(headerName)) { httpRequest.headers[headerName] = options['customHeaders'][headerName]; } } } httpRequest.body = null; // Send Request return client.pipeline(httpRequest, (err, response, responseBody) => { if (err) { return callback(err); } let statusCode = response.statusCode; if (statusCode !== 200) { let error = new Error(responseBody); error.statusCode = response.statusCode; error.request = msRest.stripRequest(httpRequest); error.response = msRest.stripResponse(response); if (responseBody === '') responseBody = null; let parsedErrorResponse; try { parsedErrorResponse = JSON.parse(responseBody); if (parsedErrorResponse) { let internalError = null; if (parsedErrorResponse.error) internalError = parsedErrorResponse.error; error.code = internalError ? internalError.code : parsedErrorResponse.code; error.message = internalError ? internalError.message : parsedErrorResponse.message; } if (parsedErrorResponse !== null && parsedErrorResponse !== undefined) { let resultMapper = new client.models['ErrorModel']().mapper(); error.body = client.deserialize(resultMapper, parsedErrorResponse, 'error.body'); } } catch (defaultError) { error.message = `Error "${defaultError.message}" occurred in deserializing the responseBody ` + `- "${responseBody}" for the default response.`; return callback(error); } return callback(error); } // Create Result let result = null; if (responseBody === '') responseBody = null; // Deserialize Response if (statusCode === 200) { let parsedResponse = null; try { parsedResponse = JSON.parse(responseBody); result = JSON.parse(responseBody); if (parsedResponse !== null && parsedResponse !== undefined) { let resultMapper = new client.models['Places']().mapper(); result = client.deserialize(resultMapper, parsedResponse, 'result'); } } catch (error) { let deserializationError = new Error(`Error ${error} occurred in deserializing the responseBody - ${responseBody}`); deserializationError.request = msRest.stripRequest(httpRequest); deserializationError.response = msRest.stripResponse(response); return callback(deserializationError); } } return callback(null, result, httpRequest, response); }); } /** * OSes in the time range * * @param {date} start Start date time in data in ISO 8601 date time format * * @param {string} ownerName The name of the owner * * @param {string} appName The name of the application * * @param {object} [options] Optional Parameters. * * @param {date} [options.end] Last date time in data in ISO 8601 date time * format * * @param {number} [options.top] The maximum number of results to return. (0 * will fetch all results) * * @param {array} [options.versions] * * @param {object} [options.customHeaders] Headers that will be added to the * request * * @param {function} callback - The callback. * * @returns {function} callback(err, result, request, response) * * {Error} err - The Error object if an error occurred, null otherwise. * * {object} [result] - The deserialized result object if an error did not occur. * See {@link OSes} for more information. * * {object} [request] - The HTTP Request object if an error did not occur. * * {stream} [response] - The HTTP Response stream if an error did not occur. */ function _operatingSystemCounts(start, ownerName, appName, options, callback) { /* jshint validthis: true */ let client = this.client; if(!callback && typeof options === 'function') { callback = options; options = null; } if (!callback) { throw new Error('callback cannot be null.'); } let end = (options && options.end !== undefined) ? options.end : undefined; let top = (options && options.top !== undefined) ? options.top : 30; let versions = (options && options.versions !== undefined) ? options.versions : undefined; // Validate try { if(!start || !(start instanceof Date || (typeof start.valueOf() === 'string' && !isNaN(Date.parse(start))))) { throw new Error('start cannot be null or undefined and it must be of type date.'); } if (end && !(end instanceof Date || (typeof end.valueOf() === 'string' && !isNaN(Date.parse(end))))) { throw new Error('end must be of type date.'); } if (top !== null && top !== undefined && typeof top !== 'number') { throw new Error('top must be of type number.'); } if (top !== null && top !== undefined) { if (top > 2000) { throw new Error('"top" should satisfy the constraint - "InclusiveMaximum": 2000'); } if (top < 0) { throw new Error('"top" should satisfy the constraint - "InclusiveMinimum": 0'); } } if (Array.isArray(versions)) { for (let i = 0; i < versions.length; i++) { if (versions[i] !== null && versions[i] !== undefined && typeof versions[i].valueOf() !== 'string') { throw new Error('versions[i] must be of type string.'); } } } if (ownerName === null || ownerName === undefined || typeof ownerName.valueOf() !== 'string') { throw new Error('ownerName cannot be null or undefined and it must be of type string.'); } if (appName === null || appName === undefined || typeof appName.valueOf() !== 'string') { throw new Error('appName cannot be null or undefined and it must be of type string.'); } } catch (error) { return callback(error); } // Construct URL let baseUrl = this.client.baseUri; let requestUrl = baseUrl + (baseUrl.endsWith('/') ? '' : '/') + 'v0.1/apps/{owner_name}/{app_name}/analytics/oses'; requestUrl = requestUrl.replace('{owner_name}', encodeURIComponent(ownerName)); requestUrl = requestUrl.replace('{app_name}', encodeURIComponent(appName)); let queryParameters = []; queryParameters.push('start=' + encodeURIComponent(client.serializeObject(start))); if (end !== null && end !== undefined) { queryParameters.push('end=' + encodeURIComponent(client.serializeObject(end))); } if (top !== null && top !== undefined) { queryParameters.push('$top=' + encodeURIComponent(top.toString())); } if (versions !== null && versions !== undefined) { queryParameters.push('versions=' + encodeURIComponent(versions.join('|'))); } if (queryParameters.length > 0) { requestUrl += '?' + queryParameters.join('&'); } // Create HTTP transport objects let httpRequest = new WebResource(); httpRequest.method = 'GET'; httpRequest.url = requestUrl; httpRequest.headers = {}; // Set Headers httpRequest.headers['Content-Type'] = 'application/json; charset=utf-8'; if(options) { for(let headerName in options['customHeaders']) { if (options['customHeaders'].hasOwnProperty(headerName)) { httpRequest.headers[headerName] = options['customHeaders'][headerName]; } } } httpRequest.body = null; // Send Request return client.pipeline(httpRequest, (err, response, responseBody) => { if (err) { return callback(err); } let statusCode = response.statusCode; if (statusCode !== 200) { let error = new Error(responseBody); error.statusCode = response.statusCode; error.request = msRest.stripRequest(httpRequest); error.response = msRest.stripResponse(response); if (responseBody === '') responseBody = null; let parsedErrorResponse; try { parsedErrorResponse = JSON.parse(responseBody); if (parsedErrorResponse) { let internalError = null; if (parsedErrorResponse.error) internalError = parsedErrorResponse.error; error.code = internalError ? internalError.code : parsedErrorResponse.code; error.message = internalError ? internalError.message : parsedErrorResponse.message; } if (parsedErrorResponse !== null && parsedErrorResponse !== undefined) { let resultMapper = new client.models['ErrorModel']().mapper(); error.body = client.deserialize(resultMapper, parsedErrorResponse, 'error.body'); } } catch (defaultError) { error.message = `Error "${defaultError.message}" occurred in deserializing the responseBody ` + `- "${responseBody}" for the default response.`; return callback(error); } return callback(error); } // Create Result let result = null; if (responseBody === '') responseBody = null; // Deserialize Response if (statusCode === 200) { let parsedResponse = null; try { parsedResponse = JSON.parse(responseBody); result = JSON.parse(responseBody); if (parsedResponse !== null && parsedResponse !== undefined) { let resultMapper = new client.models['OSes']().mapper(); result = client.deserialize(resultMapper, parsedResponse, 'result'); } } catch (error) { let deserializationError = new Error(`Error ${error} occurred in deserializing the responseBody - ${responseBody}`); deserializationError.request = msRest.stripRequest(httpRequest); deserializationError.response = msRest.stripResponse(response); return callback(deserializationError); } } return callback(null, result, httpRequest, response); }); } /** * models in the time range * * @param {date} start Start date time in data in ISO 8601 date time format * * @param {string} ownerName The name of the owner * * @param {string} appName The name of the application * * @param {object} [options] Optional Parameters. * * @param {date} [options.end] Last date time in data in ISO 8601 date time * format * * @param {number} [options.top] The maximum number of results to return. (0 * will fetch all results) * * @param {array} [options.versions] * * @param {object} [options.customHeaders] Headers that will be added to the * request * * @param {function} callback - The callback. * * @returns {function} callback(err, result, request, response) * * {Error} err - The Error object if an error occurred, null otherwise. * * {object} [result] - The deserialized result object if an error did not occur. * See {@link AnalyticsModels} for more information. * * {object} [request] - The HTTP Request object if an error did not occur. * * {stream} [response] - The HTTP Response stream if an error did not occur. */ function _modelCounts(start, ownerName, appName, options, callback) { /* jshint validthis: true */ let client = this.client; if(!callback && typeof options === 'function') { callback = options; options = null; } if (!callback) { throw new Error('callback cannot be null.'); } let end = (options && options.end !== undefined) ? options.end : undefined; let top = (options && options.top !== undefined) ? options.top : 30; let versions = (options && options.versions !== undefined) ? options.versions : undefined; // Validate try { if(!start || !(start instanceof Date || (typeof start.valueOf() === 'string' && !isNaN(Date.parse(start))))) { throw new Error('start cannot be null or undefined and it must be of type date.'); } if (end && !(end instanceof Date || (typeof end.valueOf() === 'string' && !isNaN(Date.parse(end))))) { throw new Error('end must be of type date.'); } if (top !== null && top !== undefined && typeof top !== 'number') { throw new Error('top must be of type number.'); } if (top !== null && top !== undefined) { if (top > 2000) { throw new Error('"top" should satisfy the constraint - "InclusiveMaximum": 2000'); } if (top < 0) { throw new Error('"top" should satisfy the constraint - "InclusiveMinimum": 0'); } } if (Array.isArray(versions)) { for (let i = 0; i < versions.length; i++) { if (versions[i] !== null && versions[i] !== undefined && typeof versions[i].valueOf() !== 'string') { throw new Error('versions[i] must be of type string.'); } } } if (ownerName === null || ownerName === undefined || typeof ownerName.valueOf() !== 'string') { throw new Error('ownerName cannot be null or undefined and it must be of type string.'); } if (appName === null || appName === undefined || typeof appName.valueOf() !== 'string') { throw new Error('appName cannot be null or undefined and it must be of type string.'); } } catch (error) { return callback(error); } // Construct URL let baseUrl = this.client.baseUri; let requestUrl = baseUrl + (baseUrl.endsWith('/') ? '' : '/') + 'v0.1/apps/{owner_name}/{app_name}/analytics/models'; requestUrl = requestUrl.replace('{owner_name}', encodeURIComponent(ownerName)); requestUrl = requestUrl.replace('{app_name}', encodeURIComponent(appName)); let queryParameters = []; queryParameters.push('start=' + encodeURIComponent(client.serializeObject(start))); if (end !== null && end !== undefined) { queryParameters.push('end=' + encodeURIComponent(client.serializeObject(end))); } if (top !== null && top !== undefined) { queryParameters.push('$top=' + encodeURIComponent(top.toString())); } if (versions !== null && versions !== undefined) { queryParameters.push('versions=' + encodeURIComponent(versions.join('|'))); } if (queryParameters.length > 0) { requestUrl += '?' + queryParameters.join('&'); } // Create HTTP transport objects let httpRequest = new WebResource(); httpRequest.method = 'GET'; httpRequest.url = requestUrl; httpRequest.headers = {}; // Set Headers httpRequest.headers['Content-Type'] = 'application/json; charset=utf-8'; if(options) { for(let headerName in options['customHeaders']) { if (options['customHeaders'].hasOwnProperty(headerName)) { httpRequest.headers[headerName] = options['customHeaders'][headerName]; } } } httpRequest.body = null; // Send Request return client.pipeline(httpRequest, (err, response, responseBody) => { if (err) { return callback(err); } let statusCode = response.statusCode; if (statusCode !== 200) { let error = new Error(responseBody); error.statusCode = response.statusCode; error.request = msRest.stripRequest(httpRequest); error.response = msRest.stripResponse(response); if (responseBody === '') responseBody = null; let parsedErrorResponse; try { parsedErrorResponse = JSON.parse(responseBody); if (parsedErrorResponse) { let internalError = null; if (parsedErrorResponse.error) internalError = parsedErrorResponse.error; error.code = internalError ? internalError.code : parsedErrorResponse.code; error.message = internalError ? internalError.message : parsedErrorResponse.message; } if (parsedErrorResponse !== null && parsedErrorResponse !== undefined) { let resultMapper = new client.models['ErrorModel']().mapper(); error.body = client.deserialize(resultMapper, parsedErrorResponse, 'error.body'); } } catch (defaultError) { error.message = `Error "${defaultError.message}" occurred in deserializing the responseBody ` + `- "${responseBody}" for the default response.`; return callback(error); } return callback(error); } // Create Result let result = null; if (responseBody === '') responseBody = null; // Deserialize Response if (statusCode === 200) { let parsedResponse = null; try { parsedResponse = JSON.parse(responseBody); result = JSON.parse(responseBody); if (parsedResponse !== null && parsedResponse !== undefined) { let resultMapper = new client.models['AnalyticsModels']().mapper(); result = client.deserialize(resultMapper, parsedResponse, 'result'); } } catch (error) { let deserializationError = new Error(`Error ${error} occurred in deserializing the responseBody - ${responseBody}`); deserializationError.request = msRest.stripRequest(httpRequest); deserializationError.response = msRest.stripResponse(response); return callback(deserializationError); } } return callback(null, result, httpRequest, response); }); } /** * Logs received betwe