File structure refactor, move old files to old directory.

Removed legacy config path support in ConfigManager.
Moved model files to corresponding subdirectories, rather than being in
an uber model directory.
This commit is contained in:
Daniel Scalzi 2020-04-13 22:51:32 -04:00
parent 9097bafb5d
commit 75a7e0f713
No known key found for this signature in database
GPG Key ID: D18EA3FB4B142A57
30 changed files with 43 additions and 47 deletions

View File

@ -1,6 +1,6 @@
{
"name": "helioslauncher",
"version": "1.7.0",
"version": "2.0.0-alpha.0",
"productName": "Helios Launcher",
"description": "Modded Minecraft Launcher",
"author": "Daniel Scalzi (https://github.com/dscalzi/)",

View File

View File

@ -1,10 +1,10 @@
interface LauncherJava {
export interface LauncherJava {
sha1: string
url: string
version: string
}
interface LauncherVersions {
export interface LauncherVersions {
launcher: {
commit: string
name: string

View File

@ -15,7 +15,7 @@ export interface Natives {
windows?: string
}
interface BaseArtifact {
export interface BaseArtifact {
sha1: string
size: number

View File

@ -1,18 +1,19 @@
import { LoggerUtil } from './loggerutil'
import { join } from 'path'
import { pathExistsSync, writeFileSync, ensureDirSync, moveSync, readFileSync } from 'fs-extra'
import { pathExistsSync, writeFileSync, ensureDirSync, readFileSync } from 'fs-extra'
import { totalmem } from 'os'
import { SavedAccount } from './model/internal/config/SavedAccount'
import { LauncherConfig } from './model/internal/config/LauncherConfig'
import { ModConfig } from './model/internal/config/ModConfig'
import { NewsCache } from './model/internal/config/NewsCache'
import { SavedAccount } from './model/SavedAccount'
import { LauncherConfig } from './model/LauncherConfig'
import { ModConfig } from './model/ModConfig'
import { NewsCache } from './model/NewsCache'
import { LoggerUtil } from '../logging/loggerutil'
// TODO final review upon usage in implementation.
export class ConfigManager {
private static readonly logger = new LoggerUtil('%c[ConfigManager]', 'color: #a02d2a; font-weight: bold')
private static readonly logger = LoggerUtil.getLogger('ConfigManager')
private static readonly sysRoot = process.env.APPDATA || (process.platform == 'darwin' ? process.env.HOME + '/Library/Application Support' : process.env.HOME)
// TODO change
private static readonly dataPath = join(ConfigManager.sysRoot as string, '.westeroscraft')
private static readonly dataPath = join(ConfigManager.sysRoot as string, '.helioslauncher')
// Forked processes do not have access to electron, so we have this workaround.
private static readonly launcherDir = process.env.CONFIG_DIRECT_PATH || require('electron').remote.app.getPath('userData')
@ -46,8 +47,7 @@ export class ConfigManager {
}
private static readonly configPath = join(ConfigManager.getLauncherDirectory(), 'config.json')
private static readonly configPathLEGACY = join(ConfigManager.dataPath, 'config.json') // TODO remove, it's been 1 year.
private static readonly firstLaunch = !pathExistsSync(ConfigManager.configPath) && !pathExistsSync(ConfigManager.configPathLEGACY)
private static readonly firstLaunch = !pathExistsSync(ConfigManager.configPath)
/**
* Three types of values:
@ -135,14 +135,10 @@ export class ConfigManager {
if(!pathExistsSync(ConfigManager.configPath)){
// Create all parent directories.
ensureDirSync(join(ConfigManager.configPath, '..'))
if(pathExistsSync(ConfigManager.configPathLEGACY)){
moveSync(ConfigManager.configPathLEGACY, ConfigManager.configPath)
} else {
doLoad = false
ConfigManager.config = ConfigManager.DEFAULT_CONFIG
ConfigManager.save()
}
}
if(doLoad){
let doValidate = false
try {
@ -150,8 +146,8 @@ export class ConfigManager {
doValidate = true
} catch (err){
ConfigManager.logger.error(err)
ConfigManager.logger.log('Configuration file contains malformed JSON or is corrupt.')
ConfigManager.logger.log('Generating a new configuration file.')
ConfigManager.logger.info('Configuration file contains malformed JSON or is corrupt.')
ConfigManager.logger.info('Generating a new configuration file.')
ensureDirSync(join(ConfigManager.configPath, '..'))
ConfigManager.config = ConfigManager.DEFAULT_CONFIG
ConfigManager.save()
@ -161,7 +157,7 @@ export class ConfigManager {
ConfigManager.save()
}
}
ConfigManager.logger.log('Successfully Loaded')
ConfigManager.logger.info('Successfully Loaded')
}
/**

View File

@ -4,7 +4,7 @@ import { join } from "path"
import { readdirSync } from "fs-extra"
import { format } from "url"
import { autoUpdater } from 'electron-updater'
import isdev from "./isdev"
import isdev from "./util/isdev"
const installExtensions = async () => {
const installer = require('electron-devtools-installer');

View File

@ -1,4 +1,4 @@
import { Agent } from "./Agent";
import { Agent } from './Agent'
export interface AuthPayload {

View File

@ -1,10 +1,10 @@
import { LoggerUtil } from '../logging/loggerutil'
import { Agent } from '../model/mojang/auth/Agent'
import { Status, StatusColor } from './type/Status'
import { Agent } from './model/auth/Agent'
import { Status, StatusColor } from './model/internal/Status'
import axios, { AxiosError } from 'axios'
import { Session } from '../model/mojang/auth/Session'
import { AuthPayload } from '../model/mojang/auth/AuthPayload'
import { MojangResponse, MojangResponseCode, deciperResponseCode, isInternalError } from './type/Response'
import { Session } from './model/auth/Session'
import { AuthPayload } from './model/auth/AuthPayload'
import { MojangResponse, MojangResponseCode, deciperResponseCode, isInternalError } from './model/internal/Response'
export class Mojang {

View File

@ -4,16 +4,16 @@ import { join } from 'path'
import { pathExistsSync, pathExists, readdir, exists, readFileSync, createWriteStream, ensureDirSync, readFile, writeFileSync, unlink, createReadStream, readJsonSync } from 'fs-extra'
import Registry from 'winreg'
import { exec, spawn } from 'child_process'
import { LauncherJson } from './model/mojang/index/LauncherJson'
import { LauncherJson } from '../asset/model/mojang/LauncherJson'
import { createHash } from 'crypto'
import AdmZip from 'adm-zip'
import { forEachOfLimit, eachLimit } from 'async'
import { extract } from 'tar-fs'
import { createGunzip } from 'zlib'
import { VersionJson, AssetIndex, Rule, Natives, Library } from './model/mojang/index/VersionJson'
import { VersionJson, AssetIndex, Rule, Natives, Library } from '../asset/model/mojang/VersionJson'
import { ConfigManager } from './configmanager'
import isDev from './isdev'
import { ConfigManager } from '../config/configmanager'
import isDev from '../util/isdev'
const DistroManager = require('./distromanager')
// Constants

View File

@ -1,7 +1,7 @@
import { LoggerUtil } from './loggerutil'
import { ConfigManager } from './configmanager'
import { Mojang } from './mojang/mojang'
import { SavedAccount } from './model/internal/config/SavedAccount'
import { ConfigManager } from '../config/configmanager'
import { Mojang } from '../mojang/mojang'
import { SavedAccount } from '../config/model/SavedAccount'
/**
* AuthManager

View File

@ -3,7 +3,7 @@ import { Distribution, Module, Type, TypeMetadata, Server } from 'helios-distrib
import { readJson, writeJson } from 'fs-extra'
import { join } from 'path'
import { LoggerUtil } from './loggerutil'
import { ConfigManager } from './configmanager'
import { ConfigManager } from '../config/configmanager'
const logger = new LoggerUtil('%c[DistroManager]', 'color: #a02d2a; font-weight: bold')

View File

@ -1,4 +1,4 @@
import { ConfigManager } from './configmanager'
import { ConfigManager } from '../config/configmanager'
import { DistroManager, DistributionWrapper } from './distromanager'
import { join } from 'path'
import { remove } from 'fs-extra'

View File

@ -4,14 +4,14 @@ import { join, basename } from 'path'
import { ModuleWrapper, ServerWrapper } from './distromanager'
import { Type, Required } from 'helios-distribution-types'
import { LoggerUtil } from './loggerutil'
import { ConfigManager } from './configmanager'
import { ConfigManager } from '../config/configmanager'
import { spawn } from 'child_process'
import { SavedAccount } from './model/internal/config/SavedAccount'
import { SavedAccount } from '../config/model/SavedAccount'
import { tmpdir, release } from 'os'
import { SubModConfig } from './model/internal/config/ModConfig'
import { SubModConfig } from '../config/model/ModConfig'
import { pseudoRandomBytes } from 'crypto'
import { Util, LibraryInternal } from './assetguard'
import { VersionJson, Rule } from './model/mojang/index/VersionJson'
import { VersionJson, Rule } from '../asset/model/mojang/VersionJson'
import { URL } from 'url'
const logger = new LoggerUtil('%c[ProcessBuilder]', 'color: #003996; font-weight: bold')

View File

@ -2,8 +2,8 @@ import { Mojang } from "../../src/main/mojang/mojang"
import { expect } from 'chai'
import nock from 'nock'
import { URL } from 'url'
import { Session } from "../../src/main/model/mojang/auth/Session"
import { MojangResponseCode } from "../../src/main/mojang/type/Response"
import { Session } from "../../src/main/mojang/model/auth/Session"
import { MojangResponseCode } from "../../src/main/mojang/model/internal/Response"
function expectMojangResponse(res: any, responseCode: MojangResponseCode, negate = false) {
expect(res).to.not.be.an('error')