summaryrefslogtreecommitdiff
path: root/src/utils/dependencyInfo.ts
diff options
context:
space:
mode:
authorAya Morisawa <AyaMorisawa4869@gmail.com>2016-12-31 03:24:07 +0900
committerAya Morisawa <AyaMorisawa4869@gmail.com>2016-12-31 03:24:07 +0900
commit6ead284f31564a2fd1905a5683a94fbc33dc45f9 (patch)
tree2675cedce2888ae68c19db80893221f1c04eafc0 /src/utils/dependencyInfo.ts
parentExtract MachineInfo (diff)
downloadmisskey-6ead284f31564a2fd1905a5683a94fbc33dc45f9.tar.gz
misskey-6ead284f31564a2fd1905a5683a94fbc33dc45f9.tar.bz2
misskey-6ead284f31564a2fd1905a5683a94fbc33dc45f9.zip
Rename DependencyChecker to DependencyInfo
Diffstat (limited to 'src/utils/dependencyInfo.ts')
-rw-r--r--src/utils/dependencyInfo.ts38
1 files changed, 38 insertions, 0 deletions
diff --git a/src/utils/dependencyInfo.ts b/src/utils/dependencyInfo.ts
new file mode 100644
index 0000000000..e0d8f24d74
--- /dev/null
+++ b/src/utils/dependencyInfo.ts
@@ -0,0 +1,38 @@
+import Logger from './logger';
+import { exec } from 'shelljs';
+
+export default class DependencyInfo {
+ logger: Logger;
+
+ constructor() {
+ this.logger = new Logger('Deps');
+ }
+
+ showAll(): void {
+ this.logger.info('Checking started');
+ this.show('Node.js', 'node -v', x => x.match(/^v(.*)\r?\n$/));
+ this.show('npm', 'npm -v', x => x.match(/^(.*)\r?\n$/));
+ 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.logger.info('Checking finished');
+ }
+
+ show(serviceName: string, command: string, transform: (x: string) => RegExpMatchArray): void {
+ const code = {
+ success: 0,
+ notFound: 127
+ };
+ const x = exec(command, { silent: true }) as any;
+ if (x.code === code.success) {
+ let ver = transform(x.stdout);
+ 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`);
+ }
+ } else if (x.code === code.notFound) {
+ this.logger.warn(`${serviceName} not found`);
+ }
+ }
+}