From d08a77a2799cee9438c47fda7c9e6cffb405bb46 Mon Sep 17 00:00:00 2001 From: crusader Date: Tue, 1 Aug 2017 19:28:42 +0900 Subject: [PATCH] =?UTF-8?q?=E3=85=91=ED=9B=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/ts/@loafer/application/Application.ts | 33 ++++++ .../@loafer/application/ApplicationStater.ts | 5 + src/ts/@loafer/context/constants/index.ts | 1 - src/ts/@loafer/context/constants/reflect.ts | 2 - src/ts/@loafer/context/decorator/App.ts | 28 +++++ .../context/decorator/Configuration.ts | 10 +- src/ts/@loafer/context/decorator/Pouch.ts | 8 +- src/ts/@loafer/context/decorator/Service.ts | 12 +- .../definition/ConfigurationDefinition.ts | 2 +- .../context/implement/DefaultAppContext.ts | 4 +- .../context/util/metadata/configuration.ts | 7 -- src/ts/@loafer/context/util/metadata/index.ts | 2 - .../context/util/metadata/injectable.ts | 7 -- src/ts/@loafer/pouches/constants/reflect.ts | 1 + .../@loafer/pouches/constants/stereotype.ts | 1 + src/ts/@loafer/pouches/decorator/Inject.ts | 4 +- .../decorator/Injectable.ts | 12 +- .../decorator/PostConstruct.ts | 6 +- .../decorator/PreDestroy.ts | 6 +- .../{context => pouches}/decorator/Scope.ts | 6 +- src/ts/@loafer/pouches/decorator/Value.ts | 4 +- .../definition/InjectableDefinition.ts | 0 .../@loafer/pouches/factory/PouchFactory.ts | 2 +- .../factory/implement/AbstractPouchFactory.ts | 79 +++++++++++--- .../factory/implement/DefaultPouchFactory.ts | 103 +++++++++++++++++- .../DefaultSingletonPouchRegistry.ts | 1 + .../registry/PouchDefinitionRegistry.ts | 11 +- src/ts/@loafer/pouches/util/metadata/index.ts | 1 + .../@loafer/pouches/util/metadata/inject.ts | 8 +- .../pouches/util/metadata/injectable.ts | 9 ++ .../apikey/api/service/ApiKeyService.ts | 23 ---- src/ts/@overflow/app/config/AppConfig.ts | 15 --- src/ts/@overflow/app/config/index.ts | 3 +- src/ts/@overflow/app/index.tsx | 29 +++-- .../commons/redux/action/asyncRequest.ts | 16 +++ .../commons/redux/saga/asyncRequest.ts | 20 ++-- .../commons/websocket/WebSocketRPC.ts | 2 +- src/ts/@overflow/discovery/api/service/_ | 0 .../domain/api/service/DomainMemberService.ts | 18 --- .../domain/api/service/DomainService.ts | 18 --- .../email/api/service/EmailAuthService.ts | 35 ------ src/ts/@overflow/history/api/_ | 0 src/ts/@overflow/history/api/service/_ | 0 .../infra/api/service/InfraHostService.ts | 22 ---- .../infra/api/service/InfraMachineService.ts | 22 ---- .../api/service/InfraOSApplicationService.ts | 22 ---- .../infra/api/service/InfraOSDaemonService.ts | 22 ---- .../infra/api/service/InfraOSPortService.ts | 22 ---- .../infra/api/service/InfraOSService.ts | 22 ---- .../infra/api/service/InfraService.ts | 22 ---- .../infra/api/service/InfraServiceService.ts | 23 ---- .../member/api/service/MemberService.ts | 42 ------- src/ts/@overflow/meta/api/_ | 0 src/ts/@overflow/meta/api/service/_ | 0 .../api/service/NoAuthProbeService.ts | 25 ----- .../probe/api/service/ProbeService.ts | 25 ----- .../probe/api/service/ProbeTaskService.ts | 20 ---- .../sensor/api/service/SensorItemService.ts | 28 ----- .../sensor/api/service/SensorService.ts | 47 -------- .../api/service/TargetDiscoveryService.ts | 17 --- .../target/api/service/TargetService.ts | 36 ------ 61 files changed, 334 insertions(+), 637 deletions(-) create mode 100644 src/ts/@loafer/application/Application.ts create mode 100644 src/ts/@loafer/application/ApplicationStater.ts delete mode 100644 src/ts/@loafer/context/constants/reflect.ts create mode 100644 src/ts/@loafer/context/decorator/App.ts delete mode 100644 src/ts/@loafer/context/util/metadata/configuration.ts delete mode 100644 src/ts/@loafer/context/util/metadata/injectable.ts rename src/ts/@loafer/{context => pouches}/decorator/Injectable.ts (70%) rename src/ts/@loafer/{context => pouches}/decorator/PostConstruct.ts (72%) rename src/ts/@loafer/{context => pouches}/decorator/PreDestroy.ts (72%) rename src/ts/@loafer/{context => pouches}/decorator/Scope.ts (79%) rename src/ts/@loafer/{context => pouches}/definition/InjectableDefinition.ts (100%) create mode 100644 src/ts/@loafer/pouches/util/metadata/injectable.ts delete mode 100644 src/ts/@overflow/apikey/api/service/ApiKeyService.ts delete mode 100644 src/ts/@overflow/app/config/AppConfig.ts delete mode 100644 src/ts/@overflow/discovery/api/service/_ delete mode 100644 src/ts/@overflow/domain/api/service/DomainMemberService.ts delete mode 100644 src/ts/@overflow/domain/api/service/DomainService.ts delete mode 100644 src/ts/@overflow/email/api/service/EmailAuthService.ts delete mode 100644 src/ts/@overflow/history/api/_ delete mode 100644 src/ts/@overflow/history/api/service/_ delete mode 100644 src/ts/@overflow/infra/api/service/InfraHostService.ts delete mode 100644 src/ts/@overflow/infra/api/service/InfraMachineService.ts delete mode 100644 src/ts/@overflow/infra/api/service/InfraOSApplicationService.ts delete mode 100644 src/ts/@overflow/infra/api/service/InfraOSDaemonService.ts delete mode 100644 src/ts/@overflow/infra/api/service/InfraOSPortService.ts delete mode 100644 src/ts/@overflow/infra/api/service/InfraOSService.ts delete mode 100644 src/ts/@overflow/infra/api/service/InfraService.ts delete mode 100644 src/ts/@overflow/infra/api/service/InfraServiceService.ts delete mode 100644 src/ts/@overflow/member/api/service/MemberService.ts delete mode 100644 src/ts/@overflow/meta/api/_ delete mode 100644 src/ts/@overflow/meta/api/service/_ delete mode 100644 src/ts/@overflow/noauthprobe/api/service/NoAuthProbeService.ts delete mode 100644 src/ts/@overflow/probe/api/service/ProbeService.ts delete mode 100644 src/ts/@overflow/probe/api/service/ProbeTaskService.ts delete mode 100644 src/ts/@overflow/sensor/api/service/SensorItemService.ts delete mode 100644 src/ts/@overflow/sensor/api/service/SensorService.ts delete mode 100644 src/ts/@overflow/target/api/service/TargetDiscoveryService.ts delete mode 100644 src/ts/@overflow/target/api/service/TargetService.ts diff --git a/src/ts/@loafer/application/Application.ts b/src/ts/@loafer/application/Application.ts new file mode 100644 index 0000000..f55a25c --- /dev/null +++ b/src/ts/@loafer/application/Application.ts @@ -0,0 +1,33 @@ +import { + ClassType, +} from '@loafer/core/constants'; + +import AppContext from '@loafer/context/AppContext'; +import DefaultAppContext from '@loafer/context/implement/DefaultAppContext'; + +import ApplicationStater from '@loafer/application/ApplicationStater'; + +class Application { + private appContext: AppContext; + private appClass: ClassType; + private appInstance: ApplicationStater; + + public constructor(clazz: ClassType) { + this.appClass = clazz; + } + + public run(): AppContext { + this.appContext = new DefaultAppContext(); + this.appInstance = this.appContext.getPouchByClass(this.appClass, undefined); + + this.appInstance.start(); + + return this.appContext; + } + + public static run(clazz: ClassType): AppContext { + return new Application(clazz).run(); + } +} + +export default Application; diff --git a/src/ts/@loafer/application/ApplicationStater.ts b/src/ts/@loafer/application/ApplicationStater.ts new file mode 100644 index 0000000..0d4ba81 --- /dev/null +++ b/src/ts/@loafer/application/ApplicationStater.ts @@ -0,0 +1,5 @@ +interface ApplicationStater { + start(): void; +} + +export default ApplicationStater; diff --git a/src/ts/@loafer/context/constants/index.ts b/src/ts/@loafer/context/constants/index.ts index 1bc69c4..e69de29 100644 --- a/src/ts/@loafer/context/constants/index.ts +++ b/src/ts/@loafer/context/constants/index.ts @@ -1 +0,0 @@ -export * from './reflect'; diff --git a/src/ts/@loafer/context/constants/reflect.ts b/src/ts/@loafer/context/constants/reflect.ts deleted file mode 100644 index c85fa52..0000000 --- a/src/ts/@loafer/context/constants/reflect.ts +++ /dev/null @@ -1,2 +0,0 @@ -export const CONTEXT_CONFIGURATION_DEFINITION = 'loafer:context/configuration_definition'; -export const CONTEXT_INJECTABLE_DEFINITION = 'loafer:context/injectable_definition'; diff --git a/src/ts/@loafer/context/decorator/App.ts b/src/ts/@loafer/context/decorator/App.ts new file mode 100644 index 0000000..f126ca5 --- /dev/null +++ b/src/ts/@loafer/context/decorator/App.ts @@ -0,0 +1,28 @@ +import createDecorator from '@loafer/core/util/decorators/createDecorator'; +import ConfigurationDefinition from '@loafer/context/definition/ConfigurationDefinition'; +import { getInjectableDefinition } from '@loafer/pouches/util/metadata'; + +import GetAppContext from '@loafer/context'; +import { InjectableSterotype } from '@loafer/pouches/constants'; +import DefaultPouchFactory from '@loafer/pouches/factory/implement/DefaultPouchFactory'; +import PouchDefinitionRegistry from '@loafer/pouches/factory/registry/PouchDefinitionRegistry'; +import { validateQualifier } from '@loafer/pouches/util/qualifier'; + +const App = (qualifier?: string | symbol ) => createDecorator('App', { + classDecorator: (target: TFunction): TFunction | void => { + let configurationDefinition = getInjectableDefinition(target.prototype, ConfigurationDefinition, false); + if (undefined !== configurationDefinition) { + throw new Error('Cannot apply @Injectable or @Injectable stereotype decorator multiple times.'); + } + + configurationDefinition = getInjectableDefinition(target.prototype, ConfigurationDefinition, true); + configurationDefinition.Stereotype = InjectableSterotype.APP; + configurationDefinition.Qualifier = validateQualifier(target.prototype, qualifier); + + return target; + }, + +}); + + +export default App; diff --git a/src/ts/@loafer/context/decorator/Configuration.ts b/src/ts/@loafer/context/decorator/Configuration.ts index e1b4914..684b7bb 100644 --- a/src/ts/@loafer/context/decorator/Configuration.ts +++ b/src/ts/@loafer/context/decorator/Configuration.ts @@ -1,6 +1,6 @@ import createDecorator from '@loafer/core/util/decorators/createDecorator'; import ConfigurationDefinition from '@loafer/context/definition/ConfigurationDefinition'; -import { getConfigurationDefinition } from '@loafer/context/util/metadata'; +import { getInjectableDefinition } from '@loafer/pouches/util/metadata'; import GetAppContext from '@loafer/context'; import { InjectableSterotype } from '@loafer/pouches/constants'; @@ -10,19 +10,15 @@ import { validateQualifier } from '@loafer/pouches/util/qualifier'; const Configuration = (qualifier?: string | symbol ) => createDecorator('Configuration', { classDecorator: (target: TFunction): TFunction | void => { - let configurationDefinition: ConfigurationDefinition = getConfigurationDefinition(target.prototype, false); + let configurationDefinition: ConfigurationDefinition = getInjectableDefinition(target.prototype, ConfigurationDefinition, false); if (undefined !== configurationDefinition) { throw new Error('Cannot apply @Injectable or @Injectable stereotype decorator multiple times.'); } - configurationDefinition = getConfigurationDefinition(target.prototype, true); + configurationDefinition = getInjectableDefinition(target.prototype, ConfigurationDefinition, true); configurationDefinition.Stereotype = InjectableSterotype.CONFIGURATION; configurationDefinition.Qualifier = validateQualifier(target.prototype, qualifier); - let pouchFactory: DefaultPouchFactory = GetAppContext().getPouchFactory(); - let pouchDefinitionRegistry = pouchFactory; - pouchDefinitionRegistry.registerPouchDefinition(configurationDefinition); - return target; }, diff --git a/src/ts/@loafer/context/decorator/Pouch.ts b/src/ts/@loafer/context/decorator/Pouch.ts index 7399b44..a116c6f 100644 --- a/src/ts/@loafer/context/decorator/Pouch.ts +++ b/src/ts/@loafer/context/decorator/Pouch.ts @@ -1,12 +1,14 @@ import createDecorator from '@loafer/core/util/decorators/createDecorator'; + import ConfigurationDefinition from '@loafer/context/definition/ConfigurationDefinition'; -import { getConfigurationDefinition } from '@loafer/context/util/metadata'; -import { InjectableSterotype } from '@loafer/pouches/constants'; import PouchConfig from '@loafer/context/decorator/PouchConfig'; +import { getInjectableDefinition } from '@loafer/pouches/util/metadata'; +import { InjectableSterotype } from '@loafer/pouches/constants'; + const Pouch = (pouchConfig: PouchConfig = {}) => createDecorator('Pouch', { methodDecorator: (target: Object, propertyKey: string, descriptor: TypedPropertyDescriptor): TypedPropertyDescriptor => { - let configurationDefinition: ConfigurationDefinition = getConfigurationDefinition(target, false); + let configurationDefinition: ConfigurationDefinition = getInjectableDefinition(target, ConfigurationDefinition, false); if (undefined === configurationDefinition || InjectableSterotype.CONFIGURATION !== configurationDefinition.Stereotype) { throw new Error('Cannot apply @Pouch decorator on not @Configuration class.'); } diff --git a/src/ts/@loafer/context/decorator/Service.ts b/src/ts/@loafer/context/decorator/Service.ts index 80e6779..bd39cb6 100644 --- a/src/ts/@loafer/context/decorator/Service.ts +++ b/src/ts/@loafer/context/decorator/Service.ts @@ -1,6 +1,6 @@ import createDecorator from '@loafer/core/util/decorators/createDecorator'; -import InjectableDefinition from '@loafer/context/definition/InjectableDefinition'; -import { getInjectableDefinition } from '@loafer/context/util/metadata'; +import InjectableDefinition from '@loafer/pouches/definition/InjectableDefinition'; +import { getInjectableDefinition } from '@loafer/pouches/util/metadata'; import GetAppContext from '@loafer/context'; import { InjectableSterotype } from '@loafer/pouches/constants'; @@ -10,19 +10,15 @@ import PouchDefinitionRegistry from '@loafer/pouches/factory/registry/PouchDefin const Service = (qualifier?: string | symbol ) => createDecorator('Service', { classDecorator: (target: TFunction): TFunction | void => { - let injectableDefinition: InjectableDefinition = getInjectableDefinition(target.prototype, false); + let injectableDefinition: InjectableDefinition = getInjectableDefinition(target.prototype, InjectableDefinition, false); if (undefined !== injectableDefinition) { throw new Error('Cannot apply @Injectable or @Injectable stereotype decorator multiple times.'); } - injectableDefinition = getInjectableDefinition(target.prototype, true); + injectableDefinition = getInjectableDefinition(target.prototype, InjectableDefinition, true); injectableDefinition.Stereotype = InjectableSterotype.SERVICE; injectableDefinition.Qualifier = validateQualifier(target.prototype, qualifier); - let pouchFactory: DefaultPouchFactory = GetAppContext().getPouchFactory(); - let pouchDefinitionRegistry = pouchFactory; - pouchDefinitionRegistry.registerPouchDefinition(injectableDefinition); - return target; }, diff --git a/src/ts/@loafer/context/definition/ConfigurationDefinition.ts b/src/ts/@loafer/context/definition/ConfigurationDefinition.ts index 7120b60..90f0263 100644 --- a/src/ts/@loafer/context/definition/ConfigurationDefinition.ts +++ b/src/ts/@loafer/context/definition/ConfigurationDefinition.ts @@ -1,6 +1,6 @@ import { ClassType, DESIGN_RETURNTYPE, PropertyType } from '@loafer/core/constants'; -import InjectableDefinition from '@loafer/context/definition/InjectableDefinition'; import PouchConfig from '@loafer/context/decorator/PouchConfig'; +import InjectableDefinition from '@loafer/pouches/definition/InjectableDefinition'; class ConfigurationDefinition extends InjectableDefinition { protected _qualifier: PropertyType = undefined; diff --git a/src/ts/@loafer/context/implement/DefaultAppContext.ts b/src/ts/@loafer/context/implement/DefaultAppContext.ts index cbe3adb..046cc11 100644 --- a/src/ts/@loafer/context/implement/DefaultAppContext.ts +++ b/src/ts/@loafer/context/implement/DefaultAppContext.ts @@ -21,8 +21,8 @@ class DefaultAppContext implements AppContext { public getPouch(qualifier: PropertyType, clazz: ClassType, ...args: any[]): any { return this.pouchFactory.getPouch(qualifier, clazz, args); } - public getPouchByType(clazz: ClassType, qualifier: PropertyType, ...args: any[]): any { - return this.pouchFactory.getPouchByType(clazz, qualifier, args); + public getPouchByClass(clazz: ClassType, qualifier: PropertyType, ...args: any[]): any { + return this.pouchFactory.getPouchByClass(clazz, qualifier, args); } } diff --git a/src/ts/@loafer/context/util/metadata/configuration.ts b/src/ts/@loafer/context/util/metadata/configuration.ts deleted file mode 100644 index 8ec949f..0000000 --- a/src/ts/@loafer/context/util/metadata/configuration.ts +++ /dev/null @@ -1,7 +0,0 @@ -import { ClassType } from '@loafer/core/constants'; -import getClassMetadata from '@loafer/core/util/metadata/getClassMetadata'; -import { CONTEXT_INJECTABLE_DEFINITION } from '@loafer/context/constants'; -import ConfigurationDefinition from '@loafer/context/definition/ConfigurationDefinition'; - -export const getConfigurationDefinition = (clazz: ClassType, isCreate: boolean = false) => - getClassMetadata(clazz, CONTEXT_INJECTABLE_DEFINITION, ConfigurationDefinition, isCreate); diff --git a/src/ts/@loafer/context/util/metadata/index.ts b/src/ts/@loafer/context/util/metadata/index.ts index eafcf4b..e69de29 100644 --- a/src/ts/@loafer/context/util/metadata/index.ts +++ b/src/ts/@loafer/context/util/metadata/index.ts @@ -1,2 +0,0 @@ -export * from './configuration'; -export * from './injectable'; diff --git a/src/ts/@loafer/context/util/metadata/injectable.ts b/src/ts/@loafer/context/util/metadata/injectable.ts deleted file mode 100644 index 73e5ddc..0000000 --- a/src/ts/@loafer/context/util/metadata/injectable.ts +++ /dev/null @@ -1,7 +0,0 @@ -import { ClassType } from '@loafer/core/constants'; -import getClassMetadata from '@loafer/core/util/metadata/getClassMetadata'; -import { CONTEXT_INJECTABLE_DEFINITION } from '@loafer/context/constants'; -import InjectableDefinition from '@loafer/context/definition/InjectableDefinition'; - -export const getInjectableDefinition = (clazz: ClassType, isCreate: boolean = false) => - getClassMetadata(clazz, CONTEXT_INJECTABLE_DEFINITION, InjectableDefinition, isCreate); diff --git a/src/ts/@loafer/pouches/constants/reflect.ts b/src/ts/@loafer/pouches/constants/reflect.ts index 2020891..189782b 100644 --- a/src/ts/@loafer/pouches/constants/reflect.ts +++ b/src/ts/@loafer/pouches/constants/reflect.ts @@ -1 +1,2 @@ +export const POUCH_INJECTABLE_DEFINITION = 'loafer:pouch/injectable_definition'; export const POUCH_INJECT_DEFINITION = 'loafer:pouch/inject_definition'; diff --git a/src/ts/@loafer/pouches/constants/stereotype.ts b/src/ts/@loafer/pouches/constants/stereotype.ts index 28469f8..a5d1045 100644 --- a/src/ts/@loafer/pouches/constants/stereotype.ts +++ b/src/ts/@loafer/pouches/constants/stereotype.ts @@ -1,5 +1,6 @@ export enum InjectableSterotype { INJECTABLE = 'Injectable', + APP = 'App', CONFIGURATION = 'Configuration', SERVICE = 'Service', } diff --git a/src/ts/@loafer/pouches/decorator/Inject.ts b/src/ts/@loafer/pouches/decorator/Inject.ts index 9073ca3..00b1204 100644 --- a/src/ts/@loafer/pouches/decorator/Inject.ts +++ b/src/ts/@loafer/pouches/decorator/Inject.ts @@ -5,11 +5,11 @@ import { getInjectDefinition } from '@loafer/pouches/util/metadata'; const Inject = (injectConfig: InjectConfig = {}) => createDecorator('Inject', { propertyDecorator: (target: Object, propertyKey: string | symbol): void => { - let injectDefinition: InjectDefinition = getInjectDefinition(target, true); + let injectDefinition: InjectDefinition = getInjectDefinition(target, InjectDefinition, true); injectDefinition.addInject(injectConfig, propertyKey); }, parameterDecorator: (target: Object, propertyKey: string | symbol, parameterIndex: number): void => { - let injectDefinition: InjectDefinition = getInjectDefinition(target, true); + let injectDefinition: InjectDefinition = getInjectDefinition(target, InjectDefinition, true); injectDefinition.addInject(injectConfig, propertyKey, parameterIndex); }, diff --git a/src/ts/@loafer/context/decorator/Injectable.ts b/src/ts/@loafer/pouches/decorator/Injectable.ts similarity index 70% rename from src/ts/@loafer/context/decorator/Injectable.ts rename to src/ts/@loafer/pouches/decorator/Injectable.ts index df8b8f5..f0aa0f9 100644 --- a/src/ts/@loafer/context/decorator/Injectable.ts +++ b/src/ts/@loafer/pouches/decorator/Injectable.ts @@ -1,6 +1,6 @@ import createDecorator from '@loafer/core/util/decorators/createDecorator'; -import InjectableDefinition from '@loafer/context/definition/InjectableDefinition'; -import { getInjectableDefinition } from '@loafer/context/util/metadata'; +import InjectableDefinition from '@loafer/pouches/definition/InjectableDefinition'; +import { getInjectableDefinition } from '@loafer/pouches/util/metadata'; import GetAppContext from '@loafer/context'; import { validateQualifier } from '@loafer/pouches/util/qualifier'; @@ -9,18 +9,14 @@ import PouchDefinitionRegistry from '@loafer/pouches/factory/registry/PouchDefin const Injectable = (qualifier?: string | symbol ) => createDecorator('Injectable', { classDecorator: (target: TFunction): TFunction | void => { - let injectableDefinition: InjectableDefinition = getInjectableDefinition(target.prototype, false); + let injectableDefinition: InjectableDefinition = getInjectableDefinition(target.prototype, InjectableDefinition, false); if (undefined !== injectableDefinition) { throw new Error('Cannot apply @Injectable decorator multiple times.'); } - injectableDefinition = getInjectableDefinition(target.prototype, true); + injectableDefinition = getInjectableDefinition(target.prototype, InjectableDefinition, true); injectableDefinition.Qualifier = validateQualifier(target.prototype, qualifier); - let pouchFactory: DefaultPouchFactory = GetAppContext().getPouchFactory(); - let pouchDefinitionRegistry = pouchFactory; - pouchDefinitionRegistry.registerPouchDefinition(injectableDefinition); - return target; }, diff --git a/src/ts/@loafer/context/decorator/PostConstruct.ts b/src/ts/@loafer/pouches/decorator/PostConstruct.ts similarity index 72% rename from src/ts/@loafer/context/decorator/PostConstruct.ts rename to src/ts/@loafer/pouches/decorator/PostConstruct.ts index f7d8ab4..53f2264 100644 --- a/src/ts/@loafer/context/decorator/PostConstruct.ts +++ b/src/ts/@loafer/pouches/decorator/PostConstruct.ts @@ -1,10 +1,10 @@ import createDecorator from '@loafer/core/util/decorators/createDecorator'; -import InjectableDefinition from '@loafer/context/definition/InjectableDefinition'; -import { getInjectableDefinition } from '@loafer/context/util/metadata'; +import InjectableDefinition from '@loafer/pouches/definition/InjectableDefinition'; +import { getInjectableDefinition } from '@loafer/pouches/util/metadata'; const PostConstruct = createDecorator('PostConstruct', { methodDecorator: (target: Object, propertyKey: string, descriptor: TypedPropertyDescriptor): TypedPropertyDescriptor => { - let injectableDefinition = getInjectableDefinition(target, false); + let injectableDefinition = getInjectableDefinition(target, InjectableDefinition, false); if (undefined === injectableDefinition) { throw new Error('Cannot apply @PostConstruct decorator on the not @Injectable or @Injectable stereotype class.'); } diff --git a/src/ts/@loafer/context/decorator/PreDestroy.ts b/src/ts/@loafer/pouches/decorator/PreDestroy.ts similarity index 72% rename from src/ts/@loafer/context/decorator/PreDestroy.ts rename to src/ts/@loafer/pouches/decorator/PreDestroy.ts index 798b368..631ef51 100644 --- a/src/ts/@loafer/context/decorator/PreDestroy.ts +++ b/src/ts/@loafer/pouches/decorator/PreDestroy.ts @@ -1,10 +1,10 @@ import createDecorator from '@loafer/core/util/decorators/createDecorator'; -import InjectableDefinition from '@loafer/context/definition/InjectableDefinition'; -import { getInjectableDefinition } from '@loafer/context/util/metadata'; +import InjectableDefinition from '@loafer/pouches/definition/InjectableDefinition'; +import { getInjectableDefinition } from '@loafer/pouches/util/metadata'; const PreDestroy = createDecorator('PreDestroy', { methodDecorator: (target: Object, propertyKey: string, descriptor: TypedPropertyDescriptor): TypedPropertyDescriptor => { - let injectableDefinition = getInjectableDefinition(target, false); + let injectableDefinition = getInjectableDefinition(target, InjectableDefinition, false); if (undefined === injectableDefinition) { throw new Error('Cannot apply @PreDestroy decorator on the not @Injectable or @Injectable stereotype class.'); } diff --git a/src/ts/@loafer/context/decorator/Scope.ts b/src/ts/@loafer/pouches/decorator/Scope.ts similarity index 79% rename from src/ts/@loafer/context/decorator/Scope.ts rename to src/ts/@loafer/pouches/decorator/Scope.ts index b9f07a2..0fa1931 100644 --- a/src/ts/@loafer/context/decorator/Scope.ts +++ b/src/ts/@loafer/pouches/decorator/Scope.ts @@ -1,11 +1,11 @@ import createDecorator from '@loafer/core/util/decorators/createDecorator'; -import InjectableDefinition from '@loafer/context/definition/InjectableDefinition'; -import { getInjectableDefinition } from '@loafer/context/util/metadata'; +import InjectableDefinition from '@loafer/pouches/definition/InjectableDefinition'; +import { getInjectableDefinition } from '@loafer/pouches/util/metadata'; import { PouchScope } from '@loafer/pouches/constants'; const Scope = (scope: PouchScope = PouchScope.SINGLETON) => createDecorator('Scope', { classDecorator: (target: TFunction): TFunction | void => { - let injectableDefinition = getInjectableDefinition(target.prototype, false); + let injectableDefinition = getInjectableDefinition(target.prototype, InjectableDefinition, false); if (undefined === injectableDefinition) { throw new Error('Cannot apply @Scope decorator on the not @Injectable or @Injectable stereotype class.'); } diff --git a/src/ts/@loafer/pouches/decorator/Value.ts b/src/ts/@loafer/pouches/decorator/Value.ts index b7e622b..8c99994 100644 --- a/src/ts/@loafer/pouches/decorator/Value.ts +++ b/src/ts/@loafer/pouches/decorator/Value.ts @@ -4,11 +4,11 @@ import { getInjectDefinition } from '@loafer/pouches/util/metadata'; const Value = (value: string) => createDecorator('Value', { propertyDecorator: (target: Object, propertyKey: string | symbol): void => { - let injectDefinition: InjectDefinition = getInjectDefinition(target, true); + let injectDefinition: InjectDefinition = getInjectDefinition(target, InjectDefinition, true); injectDefinition.addValue(value, propertyKey); }, parameterDecorator: (target: Object, propertyKey: string | symbol, parameterIndex: number): void => { - let injectDefinition: InjectDefinition = getInjectDefinition(target, true); + let injectDefinition: InjectDefinition = getInjectDefinition(target, InjectDefinition, true); injectDefinition.addValue(value, propertyKey, parameterIndex); }, diff --git a/src/ts/@loafer/context/definition/InjectableDefinition.ts b/src/ts/@loafer/pouches/definition/InjectableDefinition.ts similarity index 100% rename from src/ts/@loafer/context/definition/InjectableDefinition.ts rename to src/ts/@loafer/pouches/definition/InjectableDefinition.ts diff --git a/src/ts/@loafer/pouches/factory/PouchFactory.ts b/src/ts/@loafer/pouches/factory/PouchFactory.ts index 3cbba9c..1a4ceb8 100644 --- a/src/ts/@loafer/pouches/factory/PouchFactory.ts +++ b/src/ts/@loafer/pouches/factory/PouchFactory.ts @@ -17,7 +17,7 @@ interface PouchFactory { * @param args are argument of target constructor * @returns an instance of pouch */ - getPouchByType(clazz: ClassType, qualifier: PropertyType, ...args: any[]): any; + getPouchByClass(clazz: ClassType, qualifier: PropertyType, ...args: any[]): any; } diff --git a/src/ts/@loafer/pouches/factory/implement/AbstractPouchFactory.ts b/src/ts/@loafer/pouches/factory/implement/AbstractPouchFactory.ts index 509984a..7845df6 100644 --- a/src/ts/@loafer/pouches/factory/implement/AbstractPouchFactory.ts +++ b/src/ts/@loafer/pouches/factory/implement/AbstractPouchFactory.ts @@ -3,6 +3,10 @@ import { PropertyType, } from '@loafer/core/constants'; +import { + InjectableSterotype, +} from '@loafer/pouches/constants'; + import { validateQualifier, } from '@loafer/pouches/util/qualifier'; @@ -15,16 +19,19 @@ import DefaultSingletonPouchRegistry from '@loafer/pouches/factory/implement/Def abstract class AbstractPouchFactory extends DefaultSingletonPouchRegistry implements PouchDefinitionRegistry { protected pouchDefinitionMap: Map>; + protected pouchDefinitionStereotypeMap: Map>; + public constructor() { super(); this.pouchDefinitionMap = new Map(); + this.pouchDefinitionStereotypeMap = new Map(); } public registerPouchDefinition(pouchDefinition: PouchDefinition): void { let clazz = pouchDefinition.Clazz; let qualifier = validateQualifier(clazz, pouchDefinition.Qualifier); - if (this.hasPouchDefinition(clazz, qualifier)) { + if (this.hasPouchDefinition(qualifier, clazz)) { throw new Error(`Pouch Definition[${clazz.constructor.name}:${qualifier}] is exist already`); } let map = this.pouchDefinitionMap.get(qualifier); @@ -34,30 +41,68 @@ abstract class AbstractPouchFactory extends DefaultSingletonPouchRegistry implem } map.set(clazz, pouchDefinition); } - public removePouchDefinition(clazz: ClassType, qualifier?: PropertyType): void { - const _qualifier = validateQualifier(clazz, qualifier); - if (!this.hasPouchDefinition(clazz, _qualifier)) { - throw new Error(`Pouch Definition[${clazz.constructor.name}:${qualifier}] is not exist`); - } - this.pouchDefinitionMap.get(_qualifier).delete(clazz); - if (0 === this.pouchDefinitionMap.get(_qualifier).size) { - this.pouchDefinitionMap.delete(_qualifier); - } - } - public getPouchDefinition(clazz: ClassType, qualifier?: PropertyType): PouchDefinition { - const _qualifier = validateQualifier(clazz, qualifier); - if (!this.pouchDefinitionMap.has(_qualifier)) { + public getPouchDefinition(qualifier: PropertyType, clazz?: ClassType): PouchDefinition { + if (!this.pouchDefinitionMap.has(qualifier)) { return undefined; } - return this.pouchDefinitionMap.get(_qualifier).get(clazz); + let map = this.pouchDefinitionMap.get(qualifier); + let count = map.size; + let pouchDefinition: PouchDefinition; + try { + pouchDefinition = this._getDefinition(map, clazz); + } catch(e) { + console.log(`Type of Pouch Definition[${qualifier}] cannot be specified (count:${count})`); + } + return pouchDefinition; } - public hasPouchDefinition(clazz: ClassType, qualifier?: PropertyType): boolean { - return undefined === this.getPouchDefinition(clazz, qualifier) ? false : true; + + public getPouchDefinitionByClass(clazz: ClassType, qualifier?: PropertyType): PouchDefinition { + const _qualifier = validateQualifier(clazz, qualifier); + return this.getPouchDefinition(_qualifier, clazz); + } + + + public hasPouchDefinition(qualifier: PropertyType, clazz?: ClassType): boolean { + return undefined === this.getPouchDefinition(qualifier, clazz) ? false : true; + } + public hasPouchDefinitionByClass(clazz: ClassType, qualifier?: PropertyType): boolean { + const _qualifier = validateQualifier(clazz, qualifier); + + return this.hasPouchDefinition(_qualifier, clazz); + } + + public removePouchDefinition(qualifier: PropertyType, clazz?: ClassType): void { + + if (!this.hasPouchDefinition(qualifier, clazz)) { + console.log(`Pouch Definition[${clazz.constructor.name}:${qualifier}] is not exist`); + return; + } + this.pouchDefinitionMap.get(qualifier).delete(clazz); + if (0 === this.pouchDefinitionMap.get(qualifier).size) { + this.pouchDefinitionMap.delete(qualifier); + } + } + + public removePouchDefinitionByClass(clazz: ClassType, qualifier?: PropertyType): void { + const _qualifier = validateQualifier(clazz, qualifier); + this.removePouchDefinition(_qualifier, clazz); } + private _getDefinition(map: Map, clazz?: ClassType): PouchDefinition { + if (undefined !== clazz) { + return map.get(clazz); + } + const count = map.size; + if (1 < count) { + throw new Error('Type of Pouch Definition cannot be specified.'); + } + for (let value of Array.from(map.values())) { + return value; + } + } } export default AbstractPouchFactory; diff --git a/src/ts/@loafer/pouches/factory/implement/DefaultPouchFactory.ts b/src/ts/@loafer/pouches/factory/implement/DefaultPouchFactory.ts index 3ce0931..95f0523 100644 --- a/src/ts/@loafer/pouches/factory/implement/DefaultPouchFactory.ts +++ b/src/ts/@loafer/pouches/factory/implement/DefaultPouchFactory.ts @@ -6,11 +6,24 @@ import { import { PouchScope, + POUCH_INJECT_DEFINITION, + POUCH_INJECTABLE_DEFINITION, } from '@loafer/pouches/constants'; + import { validateQualifier, } from '@loafer/pouches/util/qualifier'; +import InjectConfig from '@loafer/pouches/decorator/InjectConfig'; + + + +import InjectDefinition, { + InjectItem, +} from '@loafer/pouches/definition/InjectDefinition'; +import InjectableDefinition from '@loafer/pouches/definition/InjectableDefinition'; + + import PouchFactory from '@loafer/pouches/factory/PouchFactory'; import AbstractPouchFactory from '@loafer/pouches/factory/implement/AbstractPouchFactory'; import PouchDefinition from '@loafer/pouches/factory/config/PouchDefinition'; @@ -21,15 +34,99 @@ class DefaultPouchFactory extends AbstractPouchFactory implements PouchFactory, super(); } public getPouch(qualifier: PropertyType, clazz: ClassType, ...args: any[]): any { + let pouchDefinition = this._getPouchDefinition(qualifier, clazz); + if (undefined === pouchDefinition) { + throw new Error(`This class[${clazz.constructor.name}:${qualifier}] is not pouch.`); + } - return null; + return this._getPouch(pouchDefinition, ...args); } - public getPouchByType(clazz: ClassType, qualifier: PropertyType, ...args: any[]): any { + public getPouchByClass(clazz: ClassType, qualifier: PropertyType, ...args: any[]): any { let _qualifier = validateQualifier(clazz, qualifier); - return null; + let pouchDefinition = this._getPouchDefinition(_qualifier, clazz); + if (undefined === pouchDefinition) { + throw new Error(`This class[${clazz.constructor.name}:${qualifier}] is not pouch.`); + } + + return this._getPouch(pouchDefinition, ...args); } + private _getPouchDefinition(qualifier: PropertyType, clazz: ClassType): PouchDefinition { + let pouchDefinition = this.getPouchDefinition(qualifier, clazz); + + if (undefined === pouchDefinition) { + pouchDefinition = this._getInjectableDefinition(clazz); + if (undefined !== pouchDefinition) { + this.registerPouchDefinition(pouchDefinition); + } + } + + return pouchDefinition; + } + + private _getPouch(pouchDefinition: PouchDefinition, ...args: any[]): any { + let instance; + if (pouchDefinition.isSingleton()) { + instance = this.getSingleton(pouchDefinition.Qualifier, pouchDefinition.Clazz); + if (undefined !== instance) { + return instance; + } + } + instance = Object.create(pouchDefinition.Clazz); + instance.constructor.apply(instance, ...args); + + this._injectDependency(instance, pouchDefinition.Clazz); + } + + private _injectDependency(instance: any, clazz: ClassType): void { + if (clazz.constructor === Object) { + return; + } + + let injectDefinition: InjectDefinition = this._getInjectDefinition(clazz); + if (undefined !== injectDefinition) { + let injectors: Map = injectDefinition.injectors; + let propertyDescriptor: PropertyDescriptor; + injectors.forEach((injectItem, key, map) => { + propertyDescriptor = Object.getOwnPropertyDescriptor(clazz, key); + + switch (injectItem.decoratorType) { + case DecoratorType.PROPERTY: + this._injectDependencyProperty(instance, clazz, key, propertyDescriptor, injectItem.propertyConfig); + break; + case DecoratorType.PARAMETER: + this._injectDependencyParameter(instance, propertyDescriptor, injectItem.parameterConfigMap); + break; + default: + break; + } + }); + } + this._injectDependency(instance, Object.getPrototypeOf(clazz)); + } + + private _injectDependencyProperty(instance: any, clazz: ClassType, propertyKey: PropertyType, + propertyDescriptor: PropertyDescriptor, injectConfig: InjectConfig): void { + let pouch = this.getPouchByClass(injectConfig.clazz, injectConfig.qualifier); + if (injectConfig.required && undefined === instance) { + throw new Error(`Pouch which used by [${clazz.constructor.name}.${propertyKey}] is not exist in the context.`); + } + instance[propertyKey] = pouch; + } + + private _injectDependencyParameter(target: object, propertyDescriptor: PropertyDescriptor, + parameterConfigs: Map): void { + console.log(''); + } + + private _getInjectableDefinition(clazz: ClassType): InjectableDefinition { + return Reflect.getMetadata(POUCH_INJECTABLE_DEFINITION, clazz); + } + + private _getInjectDefinition(clazz: ClassType): InjectDefinition { + return Reflect.getMetadata(POUCH_INJECT_DEFINITION, clazz); + } } export default DefaultPouchFactory; diff --git a/src/ts/@loafer/pouches/factory/implement/DefaultSingletonPouchRegistry.ts b/src/ts/@loafer/pouches/factory/implement/DefaultSingletonPouchRegistry.ts index 5b3bbf4..04efd9c 100644 --- a/src/ts/@loafer/pouches/factory/implement/DefaultSingletonPouchRegistry.ts +++ b/src/ts/@loafer/pouches/factory/implement/DefaultSingletonPouchRegistry.ts @@ -13,6 +13,7 @@ class DefaultSingletonPouchRegistry implements SingletonPouchRegistry { protected singletonInstanceMap: Map>; protected constructor() { + this.singletonInstanceMap = new Map(); } public registerSingleton(pouch: any, qualifier?: PropertyType): void { diff --git a/src/ts/@loafer/pouches/factory/registry/PouchDefinitionRegistry.ts b/src/ts/@loafer/pouches/factory/registry/PouchDefinitionRegistry.ts index a815daa..44dd9eb 100644 --- a/src/ts/@loafer/pouches/factory/registry/PouchDefinitionRegistry.ts +++ b/src/ts/@loafer/pouches/factory/registry/PouchDefinitionRegistry.ts @@ -7,9 +7,14 @@ import PouchDefinition from '@loafer/pouches/factory/config/PouchDefinition'; interface PouchDefinitionRegistry { registerPouchDefinition(pouchDefinition: PouchDefinition): void; - removePouchDefinition(clazz: ClassType, qualifier?: PropertyType): void; - getPouchDefinition(clazz: ClassType, qualifier?: PropertyType): PouchDefinition; - hasPouchDefinition(clazz: ClassType, qualifier?: PropertyType): boolean; + + removePouchDefinition(qualifier: PropertyType, clazz?: ClassType): void; + getPouchDefinition(qualifier: PropertyType, clazz?: ClassType): PouchDefinition; + hasPouchDefinition(qualifier: PropertyType, clazz?: ClassType): boolean; + + removePouchDefinitionByClass(clazz: ClassType, qualifier?: PropertyType): void; + getPouchDefinitionByClass(clazz: ClassType, qualifier?: PropertyType): PouchDefinition; + hasPouchDefinitionByClass(clazz: ClassType, qualifier?: PropertyType): boolean; } export default PouchDefinitionRegistry; diff --git a/src/ts/@loafer/pouches/util/metadata/index.ts b/src/ts/@loafer/pouches/util/metadata/index.ts index d41ede0..397897a 100644 --- a/src/ts/@loafer/pouches/util/metadata/index.ts +++ b/src/ts/@loafer/pouches/util/metadata/index.ts @@ -1 +1,2 @@ export * from './inject'; +export * from './injectable'; diff --git a/src/ts/@loafer/pouches/util/metadata/inject.ts b/src/ts/@loafer/pouches/util/metadata/inject.ts index 8f5ce90..26f2011 100644 --- a/src/ts/@loafer/pouches/util/metadata/inject.ts +++ b/src/ts/@loafer/pouches/util/metadata/inject.ts @@ -1,9 +1,11 @@ import { ClassType } from '@loafer/core/constants'; -import getClassMetadata from '@loafer/core/util/metadata/getClassMetadata'; +import getClassMetadata, { + MetadataDefinable, +} from '@loafer/core/util/metadata/getClassMetadata'; import { POUCH_INJECT_DEFINITION } from '@loafer/pouches/constants'; import InjectDefinition from '@loafer/pouches/definition/InjectDefinition'; export const getInjectDefinition = - (clazz: ClassType, isCreate: boolean = false) => - getClassMetadata(clazz, POUCH_INJECT_DEFINITION, InjectDefinition, isCreate); + (clazz: ClassType, definitionType: MetadataDefinable, isCreate: boolean = false) => + getClassMetadata(clazz, POUCH_INJECT_DEFINITION, definitionType, isCreate); diff --git a/src/ts/@loafer/pouches/util/metadata/injectable.ts b/src/ts/@loafer/pouches/util/metadata/injectable.ts new file mode 100644 index 0000000..6e4c157 --- /dev/null +++ b/src/ts/@loafer/pouches/util/metadata/injectable.ts @@ -0,0 +1,9 @@ +import { ClassType } from '@loafer/core/constants'; +import getClassMetadata, { + MetadataDefinable, +} from '@loafer/core/util/metadata/getClassMetadata'; +import { POUCH_INJECTABLE_DEFINITION } from '@loafer/pouches/constants'; +import InjectableDefinition from '@loafer/pouches/definition/InjectableDefinition'; + +export const getInjectableDefinition = (clazz: ClassType, definitionType: MetadataDefinable, isCreate: boolean = false) => + getClassMetadata(clazz, POUCH_INJECTABLE_DEFINITION, definitionType, isCreate); diff --git a/src/ts/@overflow/apikey/api/service/ApiKeyService.ts b/src/ts/@overflow/apikey/api/service/ApiKeyService.ts deleted file mode 100644 index f86bb71..0000000 --- a/src/ts/@overflow/apikey/api/service/ApiKeyService.ts +++ /dev/null @@ -1,23 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import ApiKey from '../model/ApiKey'; -import Domain from '@overflow/domain/api/model/Domain'; - - -class ApiKeyService extends Service { - public constructor() { - super('ApiKeyService'); - } - - public regist(apikey: ApiKey): ApiKey { - - return null; - } - - public read(domain: Domain): ApiKey { - return null; - } - -} - - -export default ApiKeyService; diff --git a/src/ts/@overflow/app/config/AppConfig.ts b/src/ts/@overflow/app/config/AppConfig.ts deleted file mode 100644 index 158a828..0000000 --- a/src/ts/@overflow/app/config/AppConfig.ts +++ /dev/null @@ -1,15 +0,0 @@ -import Configuration from '@loafer/context/decorator/Configuration'; -import Pouch from '@loafer/context/decorator/Pouch'; -import WebSocketRPC from '@overflow/commons/websocket/WebSocketRPC'; - - -@Configuration() -class AppConfig { - /** - * setWebsocket - */ - @Pouch() - public setWebsocket(): WebSocketRPC { - return null; - } -} diff --git a/src/ts/@overflow/app/config/index.ts b/src/ts/@overflow/app/config/index.ts index 9c55950..4c77f41 100644 --- a/src/ts/@overflow/app/config/index.ts +++ b/src/ts/@overflow/app/config/index.ts @@ -2,7 +2,7 @@ import { ReducersMapObject } from 'redux'; import { SagaWatcher } from '@overflow/commons/constant'; import signInReducer from '@overflow/member/redux/reducer/signIn'; -// import signInSagaWatchers from '@overflow/member/redux/saga/signIn'; +import asyncRequestSagaWatchers from '@overflow/commons/redux/saga/asyncRequest'; // Container Configuration export interface ContainerConfig { @@ -39,6 +39,7 @@ const reduxConfig: ReduxConfig = { signInReducer, ], sagaWarchers: [ + ...asyncRequestSagaWatchers, ], }; diff --git a/src/ts/@overflow/app/index.tsx b/src/ts/@overflow/app/index.tsx index 6cc1441..9959a9a 100644 --- a/src/ts/@overflow/app/index.tsx +++ b/src/ts/@overflow/app/index.tsx @@ -41,7 +41,11 @@ import { import * as injectTapEventPlugin from 'react-tap-event-plugin'; +import Application from '@loafer/application/Application'; +import ApplicationStater from '@loafer/application/ApplicationStater'; import Platform from '@overflow/commons/platform'; +import App from '@loafer/context/decorator/App'; +import Inject from '@loafer/pouches/decorator/Inject'; import AppContext from '@loafer/context/AppContext'; import GetAppContext from '@loafer/context'; @@ -52,7 +56,9 @@ import { SagaWatcher } from '@overflow/commons/constant'; import appConfig, { Config, ReduxState } from './config'; -import App from './views/App'; + + +import * as AppView from './views/App'; declare global { interface Window { @@ -64,12 +70,14 @@ declare global { injectTapEventPlugin(); -class Application { +@App() +class OFApplication implements ApplicationStater { private static isProduction:boolean = process.env.NODE_ENV === 'production' ? true : false; - private static useReduxDevTools:boolean = window.devToolsExtension && !Application.isProduction ? true : false; + private static useReduxDevTools:boolean = window.devToolsExtension && !OFApplication.isProduction ? true : false; private config: Config; private container: HTMLElement; + @Inject() private context: AppContext; private rpcClient: WebSocketRPC; private store: Store; @@ -83,11 +91,10 @@ class Application { } public static main(): void { - let application = new Application(); - application.start(); + Application.run(OFApplication.prototype); } - private async start(): Promise { + public async start(): Promise { try { this.container = await Platform.getAppContainer(this.config.container.placeholderID); this.displayLoading(); @@ -152,7 +159,7 @@ class Application { this.store = createStore( ReducerContext.reducer, this.config.redux.state, - Application.useReduxDevTools ? compose(middleware, window.devToolsExtension()) : middleware, + OFApplication.useReduxDevTools ? compose(middleware, window.devToolsExtension()) : middleware, ); // saga this.sagaMiddleware.run(this.initReduxSagaWarchers, this.config.redux.sagaWarchers); @@ -202,13 +209,13 @@ class Application { private displayApp(): void { - Application.isProduction ? this.displayProductionApp() : this.displayDebugApp(); + OFApplication.isProduction ? this.displayProductionApp() : this.displayDebugApp(); } private displayProductionApp(): void { ReactDOM.render( - + , this.container, @@ -236,7 +243,7 @@ class Application { - + @@ -247,4 +254,4 @@ class Application { } -Application.main(); +OFApplication.main(); diff --git a/src/ts/@overflow/commons/redux/action/asyncRequest.ts b/src/ts/@overflow/commons/redux/action/asyncRequest.ts index 2c9c772..c37b648 100644 --- a/src/ts/@overflow/commons/redux/action/asyncRequest.ts +++ b/src/ts/@overflow/commons/redux/action/asyncRequest.ts @@ -8,6 +8,8 @@ export const REQUEST: REQUEST = '@@overflow/anync/REQUEST'; // Action Creater export type request = (service: string, method: string, requestType: string, ...args: any[]) => Action; +export type requestSuccess = (requestType: string, result: any) => Action; +export type requestFailure = (requestType: string, error: any) => Action; export const request: request = (service: string, method: string, requestType: string, ...args: any[]): Action => { return { @@ -20,3 +22,17 @@ export const request: request = (service: string, method: string, requestType: s }, }; }; + +export const requestSuccess: requestSuccess = (requestType: string, result: any): Action => { + return { + type: `${requestType}/SUCCESS`, + payload: result, + }; +}; + +export const requestFailure: requestFailure = (requestType: string, error: any): Action => { + return { + type: `${requestType}/FAILURE`, + payload: error, + }; +}; diff --git a/src/ts/@overflow/commons/redux/saga/asyncRequest.ts b/src/ts/@overflow/commons/redux/saga/asyncRequest.ts index 1fe6adc..e23b8c0 100644 --- a/src/ts/@overflow/commons/redux/saga/asyncRequest.ts +++ b/src/ts/@overflow/commons/redux/saga/asyncRequest.ts @@ -5,26 +5,26 @@ import GetAppContext from '@loafer/context'; import AppContext from '@loafer/context/AppContext'; import { SagaWatcher } from '@overflow/commons/constant'; import Action from '@overflow/commons/redux/Action'; +import * as AsyncRequestActions from '@overflow/commons/redux/action/asyncRequest'; + +import WebSocketRPC from '@overflow/commons/websocket/WebSocketRPC'; -import * as AsyncRequestActions from '../action/asyncRequest'; import AsyncRequestPayload from '../payload/AsyncRequestPayload'; function* request(action: Action): SagaIterator { + const {service, method, requestType, args} = action.payload; + try { - const {service, method, requestType, args} = action.payload; // yield put({ // type: types.SENDING_REQUEST, // payload: {sendingRequest: true}, - // }); - // let serviceInstance = GetAppContext().getPouch(service); - // const member = yield call({context: memberService, fn: memberService.signin}, signinId, signinPw); + // });`${service}.${method}` + let webSocketRPC: WebSocketRPC = GetAppContext().getPouchByClass(WebSocketRPC.prototype, undefined); + let result = yield call({context: webSocketRPC, fn: webSocketRPC.Call}, `${service}.${method}`, args); - // if (responseBody.token === undefined) { - // throw new Error(MESSAGES.UNABLE_TO_FIND_TOKEN_IN_LOGIN_RESPONSE); - // } - // yield put(SigninActions.requestSuccess(member)); + yield put(AsyncRequestActions.requestSuccess(requestType, result)); } catch (e) { - // yield put(SigninActions.requestFailure(e)); + yield put(AsyncRequestActions.requestFailure(requestType, e)); } finally { // yield put({ // type: types.SENDING_REQUEST, diff --git a/src/ts/@overflow/commons/websocket/WebSocketRPC.ts b/src/ts/@overflow/commons/websocket/WebSocketRPC.ts index 56092bb..b75d520 100644 --- a/src/ts/@overflow/commons/websocket/WebSocketRPC.ts +++ b/src/ts/@overflow/commons/websocket/WebSocketRPC.ts @@ -10,7 +10,7 @@ import { RPCResponse, } from './protocol/rpc'; -import Injectable from '@loafer/context/decorator/Injectable'; +import Injectable from '@loafer/pouches/decorator/Injectable'; export type OnDisconnectFunc = () => void; export type OnResponseFunc = (response: any) => void; diff --git a/src/ts/@overflow/discovery/api/service/_ b/src/ts/@overflow/discovery/api/service/_ deleted file mode 100644 index e69de29..0000000 diff --git a/src/ts/@overflow/domain/api/service/DomainMemberService.ts b/src/ts/@overflow/domain/api/service/DomainMemberService.ts deleted file mode 100644 index 6c2b200..0000000 --- a/src/ts/@overflow/domain/api/service/DomainMemberService.ts +++ /dev/null @@ -1,18 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import DomainMember from '../model/DomainMember'; - - -class DomainMemberService extends Service { - public constructor() { - super('DomainMemberService'); - } - - public regist(domainMember: DomainMember): void { - - return null; - } - -} - - -export default DomainMemberService; diff --git a/src/ts/@overflow/domain/api/service/DomainService.ts b/src/ts/@overflow/domain/api/service/DomainService.ts deleted file mode 100644 index 34661b2..0000000 --- a/src/ts/@overflow/domain/api/service/DomainService.ts +++ /dev/null @@ -1,18 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import Domain from '../model/Domain'; - - -class DomainService extends Service { - public constructor() { - super('DomainService'); - } - - public regist(domain: Domain): void { - - return null; - } - -} - - -export default DomainService; diff --git a/src/ts/@overflow/email/api/service/EmailAuthService.ts b/src/ts/@overflow/email/api/service/EmailAuthService.ts deleted file mode 100644 index 84731c5..0000000 --- a/src/ts/@overflow/email/api/service/EmailAuthService.ts +++ /dev/null @@ -1,35 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import EmailAuth from '../model/EmailAuth'; - - -class EmailAuthService extends Service { - public constructor() { - super('EmailAuthService'); - } - - public sendEmailByMember(id: number, email: string): Promise { - - return new Promise((resolve) => { - const json = this.send('sendEmailByMember', [id, email]); - }); - } - - public read(id: number): Promise { - return null; - } - - public readByAuthKey(authKey: string): Promise { - return null; - } - - public readByMember(memberId: number): Promise { - return null; - } - - public modify(auth:EmailAuth): Promise { - return null; - } -} - - -export default EmailAuthService; diff --git a/src/ts/@overflow/history/api/_ b/src/ts/@overflow/history/api/_ deleted file mode 100644 index e69de29..0000000 diff --git a/src/ts/@overflow/history/api/service/_ b/src/ts/@overflow/history/api/service/_ deleted file mode 100644 index e69de29..0000000 diff --git a/src/ts/@overflow/infra/api/service/InfraHostService.ts b/src/ts/@overflow/infra/api/service/InfraHostService.ts deleted file mode 100644 index 2f39656..0000000 --- a/src/ts/@overflow/infra/api/service/InfraHostService.ts +++ /dev/null @@ -1,22 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import InfraHost from '../model/InfraHost'; - - -class InfraHostService extends Service { - public constructor() { - super('InfraHostService'); - } - - public regist(infraHost: InfraHost): InfraHost { - - return null; - } - - public read(id: number): InfraHost { - return null; - } - -} - - -export default InfraHostService; diff --git a/src/ts/@overflow/infra/api/service/InfraMachineService.ts b/src/ts/@overflow/infra/api/service/InfraMachineService.ts deleted file mode 100644 index 7923d85..0000000 --- a/src/ts/@overflow/infra/api/service/InfraMachineService.ts +++ /dev/null @@ -1,22 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import InfraMachine from '../model/InfraMachine'; - - -class InfraMachinetService extends Service { - public constructor() { - super('InfraMachinetService'); - } - - public regist(infraMachine: InfraMachine): InfraMachine { - - return null; - } - - public read(id: number): InfraMachine { - return null; - } - -} - - -export default InfraMachinetService; diff --git a/src/ts/@overflow/infra/api/service/InfraOSApplicationService.ts b/src/ts/@overflow/infra/api/service/InfraOSApplicationService.ts deleted file mode 100644 index 7c7e8f1..0000000 --- a/src/ts/@overflow/infra/api/service/InfraOSApplicationService.ts +++ /dev/null @@ -1,22 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import InfraOSApplication from '../model/InfraOSApplication'; - - -class InfraOSApplicationService extends Service { - public constructor() { - super('InfraOSApplicationService'); - } - - public regist(infraOSApplication: InfraOSApplication): InfraOSApplication { - - return null; - } - - public read(id: number): InfraOSApplication { - return null; - } - -} - - -export default InfraOSApplicationService; diff --git a/src/ts/@overflow/infra/api/service/InfraOSDaemonService.ts b/src/ts/@overflow/infra/api/service/InfraOSDaemonService.ts deleted file mode 100644 index dad071e..0000000 --- a/src/ts/@overflow/infra/api/service/InfraOSDaemonService.ts +++ /dev/null @@ -1,22 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import InfraOSDaemon from '../model/InfraOSDaemon'; - - -class InfraOSDaemonService extends Service { - public constructor() { - super('InfraOSDaemonService'); - } - - public regist(infraOSDaemon: InfraOSDaemon): InfraOSDaemon { - - return null; - } - - public read(id: number): InfraOSDaemon { - return null; - } - -} - - -export default InfraOSDaemonService; diff --git a/src/ts/@overflow/infra/api/service/InfraOSPortService.ts b/src/ts/@overflow/infra/api/service/InfraOSPortService.ts deleted file mode 100644 index 6bfad44..0000000 --- a/src/ts/@overflow/infra/api/service/InfraOSPortService.ts +++ /dev/null @@ -1,22 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import InfraOSPort from '../model/InfraOSPort'; - - -class InfraOSDaemonService extends Service { - public constructor() { - super('InfraOSDaemonService'); - } - - public regist(infraOSPort: InfraOSPort): InfraOSPort { - - return null; - } - - public read(id: number): InfraOSPort { - return null; - } - -} - - -export default InfraOSDaemonService; diff --git a/src/ts/@overflow/infra/api/service/InfraOSService.ts b/src/ts/@overflow/infra/api/service/InfraOSService.ts deleted file mode 100644 index e75e286..0000000 --- a/src/ts/@overflow/infra/api/service/InfraOSService.ts +++ /dev/null @@ -1,22 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import InfraOS from '../model/InfraOS'; - - -class InfraOSService extends Service { - public constructor() { - super('InfraOSService'); - } - - public regist(infraOS: InfraOS): InfraOS { - - return null; - } - - public read(id: number): InfraOS { - return null; - } - -} - - -export default InfraOSService; diff --git a/src/ts/@overflow/infra/api/service/InfraService.ts b/src/ts/@overflow/infra/api/service/InfraService.ts deleted file mode 100644 index 1480ec1..0000000 --- a/src/ts/@overflow/infra/api/service/InfraService.ts +++ /dev/null @@ -1,22 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import Infra from '../model/Infra'; - - -class InfraService extends Service { - public constructor() { - super('InfraService'); - } - - public regist(infra: Infra): Infra { - - return null; - } - - public read(id: number): Infra { - return null; - } - -} - - -export default InfraService; diff --git a/src/ts/@overflow/infra/api/service/InfraServiceService.ts b/src/ts/@overflow/infra/api/service/InfraServiceService.ts deleted file mode 100644 index 6153528..0000000 --- a/src/ts/@overflow/infra/api/service/InfraServiceService.ts +++ /dev/null @@ -1,23 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import InfraService from '../model/InfraService'; - - -class InfraServiceService extends Service { - public constructor() { - super('InfraServiceService'); - } - - public regist(infraService: InfraService): InfraService { - - - return null; - } - - public read(id: number): InfraService { - return null; - } - -} - - -export default InfraServiceService; diff --git a/src/ts/@overflow/member/api/service/MemberService.ts b/src/ts/@overflow/member/api/service/MemberService.ts deleted file mode 100644 index c3d57c7..0000000 --- a/src/ts/@overflow/member/api/service/MemberService.ts +++ /dev/null @@ -1,42 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import Member from '../model/Member'; -import Injectable from '@loafer/context/decorator/Injectable'; - - -@Injectable() -export class MemberService extends Service { - - public constructor() { - super('MemberService'); - } - - public signin(signinId: string, signinPw: string): Promise { - return this.send('signin', [signinId, signinPw]); - } - - public signout(member: Member): Member { - - return null; - } - - public signup(member: Member): Member { - - return null; - } - - public read(id: number): Member { - - return null; - } - - public withdrawal(id: number): Member { - - return null; - } - - public modify(member: Member): Member { - return null; - } -} - -export default MemberService; diff --git a/src/ts/@overflow/meta/api/_ b/src/ts/@overflow/meta/api/_ deleted file mode 100644 index e69de29..0000000 diff --git a/src/ts/@overflow/meta/api/service/_ b/src/ts/@overflow/meta/api/service/_ deleted file mode 100644 index e69de29..0000000 diff --git a/src/ts/@overflow/noauthprobe/api/service/NoAuthProbeService.ts b/src/ts/@overflow/noauthprobe/api/service/NoAuthProbeService.ts deleted file mode 100644 index e5b9898..0000000 --- a/src/ts/@overflow/noauthprobe/api/service/NoAuthProbeService.ts +++ /dev/null @@ -1,25 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import NoAuthProbe from '../model/NoAuthProbe'; -import Domain from '@overflow/domain/api/model/Domain'; - -export class NoAuthProbeService extends Service { - - public constructor() { - super('NoAuthProbeService'); - } - - public regist(noAuthProbe: NoAuthProbe): NoAuthProbe { - return null; - } - - // Todo List - public readAllByDomain(domain: Domain): NoAuthProbe[] { - return null; - } - - public read(id: number): NoAuthProbe { - return null; - } -} - -export default NoAuthProbeService; diff --git a/src/ts/@overflow/probe/api/service/ProbeService.ts b/src/ts/@overflow/probe/api/service/ProbeService.ts deleted file mode 100644 index c3a12da..0000000 --- a/src/ts/@overflow/probe/api/service/ProbeService.ts +++ /dev/null @@ -1,25 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import Probe from '../model/Probe'; -import Domain from '@overflow/domain/api/model/Domain'; - -export class ProbeService extends Service { - - public constructor() { - super('ProbeService'); - } - - public regist(probe: Probe): Promise { - return null; - } - - public readAllByDomain(domain: Domain): Promise { - return null; - } - - public readByProbeKey(probeKey: string): Promise { - return null; - } - -} - -export default ProbeService; diff --git a/src/ts/@overflow/probe/api/service/ProbeTaskService.ts b/src/ts/@overflow/probe/api/service/ProbeTaskService.ts deleted file mode 100644 index 5030ab3..0000000 --- a/src/ts/@overflow/probe/api/service/ProbeTaskService.ts +++ /dev/null @@ -1,20 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import ProbeTask from '../model/ProbeTask'; -import Probe from '../model/Probe'; - -export class ProbeTaskService extends Service { - - public constructor() { - super('ProbeService'); - } - - public regist(probeTask:ProbeTask): void { - return null; - } - - public readAllByProbe(probe:Probe): Promise { - return null; - } -} - -export default ProbeTaskService; diff --git a/src/ts/@overflow/sensor/api/service/SensorItemService.ts b/src/ts/@overflow/sensor/api/service/SensorItemService.ts deleted file mode 100644 index 1e8b238..0000000 --- a/src/ts/@overflow/sensor/api/service/SensorItemService.ts +++ /dev/null @@ -1,28 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import SensorItem from '../model/SensorItem'; -import Sensor from '../model/Sensor'; - -export class SensorItemService extends Service { - - public constructor() { - super('SensorItemService'); - } - - public regist(sensorItem:SensorItem): Promise { - return null; - } - - public readAllBySensor(sensor:Sensor): Promise { - return null; - } - - public read(id:number): Promise { - return null; - } - - public remove(sensorItem:SensorItem): Promise { - return null; - } -} - -export default SensorItemService; diff --git a/src/ts/@overflow/sensor/api/service/SensorService.ts b/src/ts/@overflow/sensor/api/service/SensorService.ts deleted file mode 100644 index dd4f0c9..0000000 --- a/src/ts/@overflow/sensor/api/service/SensorService.ts +++ /dev/null @@ -1,47 +0,0 @@ - -import Service from '@overflow/commons/api/Service'; -import Sensor from '../model/Sensor'; -import Target from '@overflow/target/api/model/Target'; -import Probe from '@overflow/probe/api/model/Probe'; -import Domain from '@overflow/domain/api/model/Domain'; - -export class SensorService extends Service { - - public constructor() { - super('SensorService'); - } - - public regist(sensor:Sensor): Promise { - return this.send('regist', [sensor]); - } - - public readAllByTarget(target:Target): Promise { - return this.send('readAllByTarget', [target]); - } - - public readAllByProbe(probe: Probe): Promise { - return this.send('readAllByProbe', [probe]); - } - - public readAllByDomain(domain: Domain): Promise { - return this.send('readAllByDomain', [domain]); - } - - public read(id:number): Promise { - return this.send('read', [id]); - } - - public remove(sensor:Sensor): Promise { - return null; - } - - public start(sensor:Sensor): Promise { - return null; - } - - public stop(sensor:Sensor): Promise { - return null; - } -} - -export default SensorService; diff --git a/src/ts/@overflow/target/api/service/TargetDiscoveryService.ts b/src/ts/@overflow/target/api/service/TargetDiscoveryService.ts deleted file mode 100644 index 5cecd9c..0000000 --- a/src/ts/@overflow/target/api/service/TargetDiscoveryService.ts +++ /dev/null @@ -1,17 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import Probe from '@overflow/probe/api/model/Probe'; -import Host from '@overflow/discovery/api/model/Host'; - -export class TargetDiscoveryService extends Service { - public constructor() { - super('TargetDiscoveryService'); - } - - public saveAllTarget(hosts:Host[], probe:Probe): void { - return null; - } -} - -export default TargetDiscoveryService; - - diff --git a/src/ts/@overflow/target/api/service/TargetService.ts b/src/ts/@overflow/target/api/service/TargetService.ts deleted file mode 100644 index ff74536..0000000 --- a/src/ts/@overflow/target/api/service/TargetService.ts +++ /dev/null @@ -1,36 +0,0 @@ -import Service from '@overflow/commons/api/Service'; -import Target from '../model/Target'; -import Probe from '@overflow/probe/api/model/Probe'; - -export class TargetService extends Service { - - public constructor() { - super('TargetService'); - } - - public regist(target: Target): Promise { - return new Promise(resolve => { - const json = this.send('regist', target); - let tempTarget: Target; - - resolve(tempTarget); - }); - } - - public read(id:string): Promise { - return new Promise(resolve => { - resolve(null); - }); - } - - public readAllByProbe(probe:Probe): Promise { - return null; - } - - public remove(target:Target): Promise { - return null; - } -} - -export default TargetService; -