mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
* * reusable data table column moved * [ACA-4361] permission layout modified * * build fixed * fix build * * import fixed * * null safety operation * * fixed comments * * fix lint * * wait for reload list * * remove sleep * * add sleep * * fix comments * * fix comments * * floating promises fix * * remove wait
130 lines
3.9 KiB
TypeScript
Executable File
130 lines
3.9 KiB
TypeScript
Executable File
/* tslint:disable */
|
|
const alfrescoApi = require('@alfresco/js-api');
|
|
const program = require('commander');
|
|
const path = require('path');
|
|
const fs = require('fs');
|
|
/* tslint:enable */
|
|
import { logger } from './logger';
|
|
const MAX_RETRY = 3;
|
|
const TIMEOUT = 20000;
|
|
let counter = 0;
|
|
|
|
export default async function main(_args: string[]) {
|
|
|
|
program
|
|
.version('0.1.0')
|
|
.description('Check Content service is up ')
|
|
.usage('check-cs-env [options]')
|
|
.option('--host [type]', 'Remote environment host adf.lab.com ')
|
|
.option('-p, --password [type]', 'password ')
|
|
.option('-u, --username [type]', 'username ')
|
|
.option('-t, --time [type]', 'time ')
|
|
.option('-r, --retry [type]', 'retry ')
|
|
.parse(process.argv);
|
|
|
|
await checkEnv();
|
|
await checkDiskSpaceFullEnv();
|
|
}
|
|
|
|
async function checkEnv() {
|
|
try {
|
|
const alfrescoJsApi = new alfrescoApi.AlfrescoApiCompatibility({
|
|
provider: 'ECM',
|
|
hostEcm: program.host
|
|
});
|
|
|
|
await alfrescoJsApi.login(program.username, program.password);
|
|
} catch (error) {
|
|
if (error?.error?.code === 'ETIMEDOUT') {
|
|
logger.error('The env is not reachable. Terminating');
|
|
process.exit(1);
|
|
}
|
|
logger.error('Login error environment down or inaccessible');
|
|
counter++;
|
|
const retry = program.retry || MAX_RETRY;
|
|
const time = program.time || TIMEOUT;
|
|
if (retry === counter) {
|
|
logger.error('Give up');
|
|
process.exit(1);
|
|
} else {
|
|
logger.error(`Retry in 1 minute attempt N ${counter}`, error);
|
|
sleep(time);
|
|
checkEnv();
|
|
}
|
|
}
|
|
}
|
|
|
|
async function checkDiskSpaceFullEnv() {
|
|
logger.info(`Start Check disk full space`);
|
|
|
|
try {
|
|
|
|
const alfrescoJsApi = new alfrescoApi.AlfrescoApiCompatibility({
|
|
provider: 'ECM',
|
|
hostEcm: program.host
|
|
});
|
|
|
|
await alfrescoJsApi.login(program.username, program.password);
|
|
|
|
let folder;
|
|
|
|
try {
|
|
folder = await alfrescoJsApi.nodes.addNode('-my-', {
|
|
'name': `try-env`,
|
|
'relativePath': `Builds`,
|
|
'nodeType': 'cm:folder'
|
|
}, {}, {
|
|
'overwrite': true
|
|
});
|
|
|
|
} catch (error) {
|
|
folder = await alfrescoJsApi.nodes.getNode('-my-', {
|
|
'relativePath': `Builds/try-env`,
|
|
'nodeType': 'cm:folder'
|
|
}, {}, {
|
|
'overwrite': true
|
|
});
|
|
}
|
|
const pathFile = path.join(__dirname, '../', 'README.md');
|
|
|
|
const file = fs.createReadStream(pathFile);
|
|
|
|
const uploadedFile = await alfrescoJsApi.upload.uploadFile(
|
|
file,
|
|
'',
|
|
folder.entry.id,
|
|
null,
|
|
{
|
|
'name': 'README.md',
|
|
'nodeType': 'cm:content',
|
|
'autoRename': true
|
|
}
|
|
);
|
|
|
|
alfrescoJsApi.node.deleteNode(uploadedFile.entry.id, {permanent: true});
|
|
} catch (error) {
|
|
counter++;
|
|
|
|
const retry = program.retry || MAX_RETRY;
|
|
const time = program.time || TIMEOUT;
|
|
if (retry === counter) {
|
|
logger.info('=============================================================');
|
|
logger.info('================ Not able to upload a file ==================');
|
|
logger.info('================ Possible cause CS is full ==================');
|
|
logger.info('=============================================================');
|
|
process.exit(1);
|
|
} else {
|
|
logger.error(`Retry N ${counter} ${error?.error?.status}`);
|
|
sleep(time);
|
|
checkDiskSpaceFullEnv();
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function sleep(delay) {
|
|
const start = new Date().getTime();
|
|
while (new Date().getTime() < start + delay) { }
|
|
}
|