diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2018-07-07 19:19:00 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2018-07-07 19:19:00 +0900 |
| commit | aa4ef6745ad798bd7d4f05cb397ef1dd85279814 (patch) | |
| tree | d34ded516f52b91c4ff1a5443776ce22d8f483f0 /src/misc/dependencyInfo.ts | |
| parent | Refactorijg (diff) | |
| download | sharkey-aa4ef6745ad798bd7d4f05cb397ef1dd85279814.tar.gz sharkey-aa4ef6745ad798bd7d4f05cb397ef1dd85279814.tar.bz2 sharkey-aa4ef6745ad798bd7d4f05cb397ef1dd85279814.zip | |
Refactorng
Diffstat (limited to 'src/misc/dependencyInfo.ts')
| -rw-r--r-- | src/misc/dependencyInfo.ts | 33 |
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`); + } + } +} |