logs.js
4.26 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
/*
* ADOBE CONFIDENTIAL
* __________________
*
* Copyright 2016 Adobe Systems Incorporated
* All Rights Reserved.
*
* NOTICE: All information contained herein is, and remains
* the property of Adobe Systems Incorporated and its suppliers,
* if any. The intellectual and technical concepts contained
* herein are proprietary to Adobe Systems Incorporated and its
* suppliers and are protected by trade secret or copyright law.
* Dissemination of this information or reproduction of this material
* is strictly forbidden unless prior written permission is obtained
* from Adobe Systems Incorporated.
*/
/* globals Promise */
define('screens/player/command/logs', [
'jquery',
'underscore',
'screens/player/command/command',
'screens/player/shared/serviceadmin',
'screens/player/store/store',
'screens/player/firmware/log/logger',
'screens/player/shared/csrf',
'module'
], function($, _, PlayerCommand, ServiceAdmin, Store, Logger, CSRFSupport, mod) {
'use strict';
function sendLogsToServer(csrf, path, logs) {
var formData = new FormData();
logs.forEach(function(log) {
formData.append('logfile', log.blob, log.name);
});
csrf.$ajax($, {
url: path,
type: 'POST',
cache: false,
contentType: false,
processData: false,
data: formData,
beforeSend: function() {
console.log('Sending logs to ' + path);
}
});
}
function retrieveLogs(logger) {
function loadBlob(logFile) {
return logger.getLogBlob(logFile).then(function(blob) {
return {
name: logFile,
blob: blob
};
});
}
return function(logFiles) {
return Promise.all(logFiles.map(loadBlob));
};
}
/**
* This command handler is able to process the following commands:
* - "logs" sends the device's log file to the server
*
* @class LogsCommand
* @implements {PlayerCommand}
*/
var LogsCommand = _.extend({}, PlayerCommand, {
serviceId: mod.id,
/**
* @function LogsCommand#canHandle
* @inheritdoc
*/
canHandle: function(cmd) {
return cmd === 'logs';
},
/**
* @function LogsCommand#activate
* @inheritdoc
*/
activate: function() {
return new Promise(function(resolve, reject) {
ServiceAdmin.onServiceHighestRankedStart(Store.serviceName, function(store) {
resolve(store);
});
}).then(function() {
return new Promise(function(resolve, reject) {
ServiceAdmin.onServiceHighestRankedStart(Logger.serviceName, function(logger) {
resolve(logger);
});
});
});
},
/**
* @function LogsCommand#handleCommand
* @inheritdoc
*/
handleCommand: function(command, payload) {
var store = ServiceAdmin.getService(Store.serviceName);
var logger = ServiceAdmin.getService(Logger.serviceName);
var state = store.getState();
var statusmodel = state.statusmodel;
var deviceUrl = (statusmodel || {}).devicePostUrl;
if (!deviceUrl) {
throw new Error('Unable to send logs. no device url.');
}
var csrf = new CSRFSupport({
serverURL: statusmodel.server
});
var restEndpoint = deviceUrl + '.logs.json';
logger.listLogs()
.then(retrieveLogs(logger))
.then(function(logs) {
return sendLogsToServer(csrf, restEndpoint, logs);
})
.catch(function(e) {
console.error('Error sending logs files to server.', e);
throw e;
});
}
});
return LogsCommand;
});
/* istanbul ignore next */
require([
'screens/player/command/logs',
'screens/player/shared/serviceadmin'
], function(Service, ServiceAdmin) {
'use strict';
ServiceAdmin.register(Service);
});