mirror of
https://iceshrimp.dev/limepotato/jormungandr-bite.git
synced 2025-01-25 06:41:36 -07:00
This commit is contained in:
parent
8250074968
commit
a7e1489a5e
5 changed files with 16 additions and 12 deletions
|
@ -38,7 +38,7 @@ if (!fs.existsSync('./.config/config.yml')) {
|
|||
|
||||
(global as any).MISSKEY_CONFIG_PATH = '.config/config.yml';
|
||||
import { IConfig } from './src/config';
|
||||
const config = eval(require('typescript').transpile(require('fs').readFileSync('./src/config.ts').toString())) as IConfig;
|
||||
const config = eval(require('typescript').transpile(require('fs').readFileSync('./src/config.ts').toString()))() as IConfig;
|
||||
|
||||
const tsProject = ts.createProject('tsconfig.json');
|
||||
|
||||
|
|
3
src/conf.ts
Normal file
3
src/conf.ts
Normal file
|
@ -0,0 +1,3 @@
|
|||
import load from './config';
|
||||
|
||||
export default load();
|
|
@ -6,6 +6,8 @@ import * as fs from 'fs';
|
|||
import * as yaml from 'js-yaml';
|
||||
import * as isUrl from 'is-url';
|
||||
|
||||
export const path = (global as any).MISSKEY_CONFIG_PATH ? (global as any).MISSKEY_CONFIG_PATH : `${__dirname}/../.config/config.yml`;
|
||||
|
||||
/**
|
||||
* ユーザーが設定する必要のある情報
|
||||
*/
|
||||
|
@ -62,10 +64,7 @@ interface Mixin {
|
|||
|
||||
export type IConfig = ISource & Mixin;
|
||||
|
||||
export default load();
|
||||
|
||||
function load() {
|
||||
const path = (global as any).MISSKEY_CONFIG_PATH ? (global as any).MISSKEY_CONFIG_PATH : `${__dirname}/../.config/config.yml`;
|
||||
export default function load() {
|
||||
const config = yaml.safeLoad(fs.readFileSync(path, 'utf8')) as ISource;
|
||||
|
||||
const mixin: Mixin = {} as Mixin;
|
||||
|
|
14
src/index.ts
14
src/index.ts
|
@ -21,12 +21,13 @@ import EnvironmentInfo from './utils/environmentInfo';
|
|||
import MachineInfo from './utils/machineInfo';
|
||||
import DependencyInfo from './utils/dependencyInfo';
|
||||
|
||||
import { path as configPath } from './config';
|
||||
import loadConfig from './config';
|
||||
|
||||
// Init babel
|
||||
require('babel-core/register');
|
||||
require('babel-polyfill');
|
||||
|
||||
global.config = require('./config').default(`${__dirname}/../.config/config.yml`);
|
||||
|
||||
enum InitResult {
|
||||
Success,
|
||||
Warn,
|
||||
|
@ -76,6 +77,8 @@ async function masterMain(): Promise<void> {
|
|||
return;
|
||||
}
|
||||
|
||||
const config = loadConfig();
|
||||
|
||||
spawnWorkers(() => {
|
||||
Logger.info(chalk.bold.green(`Now listening on port ${config.port}`));
|
||||
|
||||
|
@ -103,9 +106,6 @@ async function masterMain(): Promise<void> {
|
|||
* Init worker proccess
|
||||
*/
|
||||
function workerMain(): void {
|
||||
// Register config
|
||||
global.config = config;
|
||||
|
||||
// Init mongo
|
||||
initdb().then(db => {
|
||||
global.db = db;
|
||||
|
@ -134,11 +134,13 @@ async function init(): Promise<InitResult> {
|
|||
new DependencyInfo().showAll();
|
||||
|
||||
let configLogger = new Logger('Config');
|
||||
if (!fs.existsSync(`${__dirname}/../.config/config.yml`)) {
|
||||
if (!fs.existsSync(configPath)) {
|
||||
configLogger.error('Configuration not found');
|
||||
return InitResult.Failure;
|
||||
}
|
||||
|
||||
const config = loadConfig();
|
||||
|
||||
configLogger.info('Successfully loaded');
|
||||
configLogger.info(`maintainer: ${config.maintainer}`);
|
||||
|
||||
|
|
|
@ -8,7 +8,7 @@ import * as https from 'https';
|
|||
import * as express from 'express';
|
||||
import vhost = require('vhost');
|
||||
|
||||
import config from './config';
|
||||
import config from './conf';
|
||||
|
||||
/**
|
||||
* Init app
|
||||
|
|
Loading…
Reference in a new issue