init.js 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. "use strict";
  2. var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
  3. function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
  4. return new (P || (P = Promise))(function (resolve, reject) {
  5. function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
  6. function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
  7. function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
  8. step((generator = generator.apply(thisArg, _arguments || [])).next());
  9. });
  10. };
  11. var __importDefault = (this && this.__importDefault) || function (mod) {
  12. return (mod && mod.__esModule) ? mod : { "default": mod };
  13. };
  14. Object.defineProperty(exports, "__esModule", { value: true });
  15. const child_process_1 = require("child_process");
  16. const fs_1 = __importDefault(require("fs"));
  17. const path_1 = __importDefault(require("path"));
  18. const util_1 = __importDefault(require("util"));
  19. const MAX_BUFFER = 10 * Math.pow(2, 20);
  20. function exec(command, stdout, stderr) {
  21. return new Promise((resolve, reject) => {
  22. try {
  23. let stdoutbuf = '';
  24. let stderrbuf = '';
  25. // EXEC CHILD PROCESS
  26. const p = child_process_1.exec(command, { maxBuffer: MAX_BUFFER }, (err, out) => {
  27. if (err)
  28. return reject(err);
  29. if (stdoutbuf.length > 0 && typeof stdout === 'function')
  30. stdout(stdoutbuf);
  31. if (stderrbuf.length > 0 && typeof stderr === 'function')
  32. stderr(stderrbuf);
  33. resolve(out);
  34. });
  35. // PIPE STDOUT
  36. if (typeof stdout === 'function') {
  37. p.stdout.on('data', chunk => {
  38. stdoutbuf += chunk;
  39. let i = -1;
  40. while ((i = stdoutbuf.indexOf('\n')) >= 0) {
  41. const line = stdoutbuf.substring(0, i);
  42. stdoutbuf = stdoutbuf.substring(i + 1);
  43. if (typeof stdout === 'function') {
  44. stdout(line);
  45. }
  46. }
  47. });
  48. }
  49. else if (typeof stdout !== 'undefined') {
  50. p.stdout.pipe(stdout);
  51. }
  52. // PIPE STDERR
  53. if (typeof stderr === 'function') {
  54. p.stderr.on('data', chunk => {
  55. stderrbuf += chunk;
  56. let i = -1;
  57. while ((i = stderrbuf.indexOf('\n')) >= 0) {
  58. const line = stderrbuf.substring(0, i);
  59. stderrbuf = stderrbuf.substring(i + 1);
  60. if (typeof stderr === 'function') {
  61. stderr(line);
  62. }
  63. }
  64. });
  65. }
  66. else if (typeof stderr !== 'undefined') {
  67. p.stderr.pipe(stderr);
  68. }
  69. }
  70. catch (err) {
  71. reject(err);
  72. }
  73. });
  74. }
  75. exports.exec = exec;
  76. const cli = {
  77. blue: v => `\x1b[34m${v}\x1b[0m`,
  78. green: v => `\x1b[32m${v}\x1b[0m`,
  79. yellow: v => `\x1b[33m${v}\x1b[0m`,
  80. red: v => `\x1b[31m${v}\x1b[0m`
  81. };
  82. function readFile(path, encoding = 'utf8') {
  83. return __awaiter(this, void 0, void 0, function* () {
  84. return new Promise((resolve, reject) => {
  85. fs_1.default.readFile(path, { encoding }, (err, data) => {
  86. if (err)
  87. return reject(err);
  88. try {
  89. resolve(data.toString());
  90. }
  91. catch (e) {
  92. reject(e);
  93. }
  94. });
  95. });
  96. });
  97. }
  98. function readJsonFile(path, encoding = 'utf8') {
  99. return __awaiter(this, void 0, void 0, function* () {
  100. return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
  101. try {
  102. resolve(JSON.parse(yield readFile(path, encoding)));
  103. }
  104. catch (e) {
  105. reject(e);
  106. }
  107. }));
  108. });
  109. }
  110. (() => __awaiter(void 0, void 0, void 0, function* () {
  111. try {
  112. const projectRootDir = path_1.default.resolve(process.cwd());
  113. if (!fs_1.default.existsSync(path_1.default.resolve(projectRootDir, 'package.json'))) {
  114. console.log(cli.blue('[INFO]'), 'Not an NPM project yet - initializing...');
  115. yield exec('npm init -y', process.stdout, process.stderr);
  116. }
  117. const cloneDir = path_1.default.resolve(projectRootDir, '.clone');
  118. if (fs_1.default.existsSync(cloneDir)) {
  119. console.log(cli.blue('[WARNING]'), `There's an old .clone directory. Removing first...`);
  120. yield util_1.default.promisify(fs_1.default.rm)(cloneDir, { force: true, recursive: true });
  121. }
  122. console.log(cli.blue('[INFO]'), 'Cloning boilerplate repository (via SSH)...');
  123. yield exec(`git clone ssh://git@bitbucket.siriusonline.de:7999/tsc/express-starter.git "${cloneDir}"`, process.stdout, process.stderr);
  124. let pkgJson = yield readJsonFile(path_1.default.resolve(cloneDir, 'package.json'));
  125. console.log(cli.blue('[INFO]'), 'Installing module dependencies...');
  126. let dependencies = Object.keys(pkgJson.dependencies).join('" "');
  127. yield exec(`npm install "${dependencies}"`, process.stdout, process.stderr);
  128. dependencies = Object.keys(pkgJson.devDependencies).join('" "');
  129. yield exec(`npm install --save-dev "${dependencies}"`, process.stdout, process.stderr);
  130. console.log(cli.blue('[INFO]'), 'Copying project files...');
  131. const copyFiles = ['.env', '.gitignore', '.prettierrc.js', 'tsconfig.json', '.vscode/settings.json', 'src', 'public', 'private'];
  132. for (const cpFile of copyFiles) {
  133. const sourceFile = path_1.default.resolve(cloneDir, cpFile);
  134. const targetFile = path_1.default.resolve(projectRootDir, cpFile);
  135. const targetDir = path_1.default.dirname(targetFile);
  136. if (!fs_1.default.existsSync(targetDir)) {
  137. yield util_1.default.promisify(fs_1.default.mkdir)(targetDir, { recursive: true, mode: 0o777 });
  138. }
  139. const stat = yield util_1.default.promisify(fs_1.default.stat)(sourceFile);
  140. if (stat.isFile()) {
  141. yield util_1.default.promisify(fs_1.default.copyFile)(sourceFile, targetFile);
  142. }
  143. else {
  144. yield exec(`cp -r "${sourceFile}" "${targetFile}"`);
  145. }
  146. }
  147. console.log(cli.blue('[INFO]'), 'Creating startup script');
  148. pkgJson = yield readJsonFile(path_1.default.resolve(projectRootDir, 'package.json'));
  149. pkgJson.scripts = Object.assign(Object.assign({}, pkgJson.scripts), { build: 'tsc -b', start: 'npm run build && node dist/index.js' });
  150. yield util_1.default.promisify(fs_1.default.writeFile)(path_1.default.resolve(projectRootDir, 'package.json'), JSON.stringify(pkgJson, null, 2));
  151. console.log(cli.blue('[INFO]'), 'Creating chat data directory');
  152. yield util_1.default.promisify(fs_1.default.mkdir)(path_1.default.resolve(projectRootDir, 'chatdata'));
  153. console.log(cli.blue('[INFO]'), 'Cleanup: Removing .clone directory...');
  154. yield util_1.default.promisify(fs_1.default.rm)(cloneDir, { force: true, recursive: true });
  155. console.log();
  156. console.log(cli.green('[SUCCESS] You can now start your express server with `npm start`'));
  157. process.exit(0);
  158. }
  159. catch (e) {
  160. console.error(e);
  161. process.exit(1);
  162. }
  163. }))();