Denys Vuika 058d23d57f [ADF-3442] create library dialog (#4018)
* library dialog

* integrate with demo shell

* update resources

* fix license

* auto focus for the first input

* update e2e tests

* try close the dialog between tests

* fix afterEach

* Revert "try close the dialog between tests"

This reverts commit 63464f2b03c226c606d09b18c7d2782e3bb52c0a.

* update code due to css lint issues

* csslint settings for vs code

* missing import
lint fix
remove not used import
convert errorPage js to ts
convert tasklistpage js to ts
fix redirection creation folder in root
fix lint issue
fix e2e

* e2e fix

* fix PS tests

* navigation import

* fix tests tooltip
convert paginapage to ts

* fix lint

* fix lock files e2e
filterspage to ts

* fix lint

* fix cs cre
git dept 3 and not 50 as default in travis

* quiet log git download

* add some delay and change the delete lock

* fix node entry

* convert searchDialog to typescript
parallel protractor

* disable browser execute

* restote test

* change search tests

* move search in a separate e2e folder

* experiment fix e2e

* change util presence
change protractor conf

* fix unshare test

* improve query viewerPage using css over xpath

* waitForAngularEnabled before browser redirect

* convert util to ts and more

* convert other files to ts

* convert to ts other files

* trigger build

* function fixes use arrow function

* process service fixes

* lint fix
review timeout default

* fix failing tests

* restore timeout

* share dialog fix

* remove

* use configuration admin

* fix APS 2 login sso
2018-12-05 13:05:39 +00:00

134 lines
4.2 KiB
JavaScript

/*!
* @license
* Copyright 2016 Alfresco Software, Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
var exports = module.exports = {};
var request = require('request');
var RequestCoreAPI = require('./RequestUtil/RequestCoreAPI');
var url = require('url-join');
var path = require('path');
var fs = require('fs');
var TestConfig = require('../../test.config');
var peopleBaseUrl = 'people';
function read(initialFile) {
return new Promise(function (resolve, reject) {
fs.readFile(initialFile, function (err, file) {
if (err) {
//console.log('read error', err);
reject(err);
}
// console.log('read success', file);
resolve(file);
})
})
}
function write(file, uri, header) {
return new Promise(function (resolve, reject) {
request.put({url: uri, headers: header, body: file}, function (err, httpResponse, body) {
if (err) {
console.error('updated failed:', err);
reject(err);
}
var json_data = JSON.parse(body);
// console.log('write success', json_data);
resolve(body);
});
});
}
/**
* Update avatar using API
*
* @param requestUserModel {User that makes the request}
* @param fileModel
* @param personId
* @method updateAvatarViaAPI
*/
exports.updateAvatarViaAPI = function (requestUserModel, fileModel, personId) {
var absolutePath = path.resolve(path.join(TestConfig.main.rootPath, fileModel.getLocation()));
var uri = url(RequestCoreAPI.getBaseURL(), peopleBaseUrl, personId, "avatar");
// console.debug("Update avatar via API: fileName=" + fileModel.getName() + " uri=" + uri + " auth=" + requestUserModel.id + " password: " + requestUserModel.password);
var allHeaders = RequestCoreAPI.requestHeaders(requestUserModel);
allHeaders['Content-Type'] = 'application/octet-stream';
return read(absolutePath)
.then(function (file) {
return write(file, uri, allHeaders);
});
};
/**
* Get avatar using API
*
* @param requestUserModel {User that makes the request}
* @param personId
* @method getAvatarViaAPIWithRetry
*/
exports.getAvatarViaAPI = function (retry, requestUserModel, personId, callback) {
var uri = url(RequestCoreAPI.getBaseURL(), peopleBaseUrl, personId, "avatar");
// console.debug("Get avatar via API: uri= " + uri + " auth=" + requestUserModel.id + " password: " + requestUserModel.password);
function run() {
request.get({
url: uri,
headers: RequestCoreAPI.requestHeaders(requestUserModel)
}, function (error, httpResponse, body) {
retry--;
var statusCode = httpResponse.statusCode;
// console.log("status code: " + statusCode);
if (statusCode != "200" && retry > 0) {
run();
}
else if (typeof callback === 'function') {
callback.apply(null);
}
});
}
run();
};
/**
* Delete avatar using API
*
* @param requestUserModel {User that makes the request}
* @param personId
* @param callback
*/
exports.deleteAvatarViaAPI = function (requestUserModel, personId, callback) {
var uri = url(RequestCoreAPI.getBaseURL(), peopleBaseUrl, personId, "avatar");
request.del({url: uri, headers: RequestCoreAPI.requestHeaders(requestUserModel)}, function (error, response, body) {
if (error) {
return console.error('delete failed:', error);
}
// console.debug("Avatar deleted via API: " + " uri=" + uri + " auth=" + requestUserModel.id + " password: " + requestUserModel.password);
if (typeof callback === 'function') {
callback.apply(null);
}
});
};