summaryrefslogtreecommitdiff
path: root/src/misc/dependencyInfo.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2018-07-07 19:19:00 +0900
committersyuilo <syuilotan@yahoo.co.jp>2018-07-07 19:19:00 +0900
commitaa4ef6745ad798bd7d4f05cb397ef1dd85279814 (patch)
treed34ded516f52b91c4ff1a5443776ce22d8f483f0 /src/misc/dependencyInfo.ts
parentRefactorijg (diff)
downloadsharkey-aa4ef6745ad798bd7d4f05cb397ef1dd85279814.tar.gz
sharkey-aa4ef6745ad798bd7d4f05cb397ef1dd85279814.tar.bz2
sharkey-aa4ef6745ad798bd7d4f05cb397ef1dd85279814.zip
Refactorng
Diffstat (limited to 'src/misc/dependencyInfo.ts')
-rw-r--r--src/misc/dependencyInfo.ts33
1 files changed, 33 insertions, 0 deletions
diff --git a/src/misc/dependencyInfo.ts b/src/misc/dependencyInfo.ts
new file mode 100644
index 0000000000..89af0d20fb
--- /dev/null
+++ b/src/misc/dependencyInfo.ts
@@ -0,0 +1,33 @@
+import Logger from './logger';
+import { execSync } from 'child_process';
+
+export default class {
+ private logger: Logger;
+
+ constructor() {
+ this.logger = new Logger('Deps');
+ }
+
+ public showAll(): void {
+ this.show('MongoDB', 'mongo --version', x => x.match(/^MongoDB shell version:? (.*)\r?\n/));
+ this.show('Redis', 'redis-server --version', x => x.match(/v=([0-9\.]*)/));
+ this.show('ImageMagick', 'magick -version', x => x.match(/^Version: ImageMagick (.+?)\r?\n/));
+ }
+
+ public show(serviceName: string, command: string, transform: (x: string) => RegExpMatchArray): void {
+ try {
+ // ステータス0以外のときにexecSyncはstderrをコンソール上に出力してしまうので
+ // プロセスからのstderrをすべて無視するように stdio オプションをセット
+ const x = execSync(command, { stdio: ['pipe', 'pipe', 'ignore'] });
+ const ver = transform(x.toString());
+ if (ver != null) {
+ this.logger.info(`${serviceName} ${ver[1]} found`);
+ } else {
+ this.logger.warn(`${serviceName} not found`);
+ this.logger.warn(`Regexp used for version check of ${serviceName} is probably messed up`);
+ }
+ } catch (e) {
+ this.logger.warn(`${serviceName} not found`);
+ }
+ }
+}