From d874ef3d52b44e82137f09a66d4aaf40fe7075cd Mon Sep 17 00:00:00 2001 From: Torakushi Date: Mon, 25 Sep 2023 18:23:50 +0200 Subject: [PATCH] add node logger code generation --- src/gen_kotlin/templates/module.kt | 12 +++++++++--- src/gen_swift/templates/extern.m | 1 + src/gen_swift/templates/module.swift | 9 +++++---- src/gen_typescript/templates/Helpers.ts | 8 ++++++-- 4 files changed, 21 insertions(+), 9 deletions(-) diff --git a/src/gen_kotlin/templates/module.kt b/src/gen_kotlin/templates/module.kt index d2e7ea5..97688c3 100644 --- a/src/gen_kotlin/templates/module.kt +++ b/src/gen_kotlin/templates/module.kt @@ -62,7 +62,12 @@ class BreezSDKModule(reactContext: ReactApplicationContext) : ReactContextBaseJa } @ReactMethod - fun connect(config: ReadableMap, seed: ReadableArray, promise: Promise) { + fun connect( + config: ReadableMap, + seed: ReadableArray, + logFilePath: String, + promise: Promise, + ) { if (breezServices != null) { promise.reject(TAG, "BreezServices already initialized") return @@ -71,8 +76,9 @@ class BreezSDKModule(reactContext: ReactApplicationContext) : ReactContextBaseJa try { val configTmp = asConfig(config) ?: run { throw SdkException.Generic("Missing mandatory field config of type Config") } val emitter = reactApplicationContext.getJSModule(RCTDeviceEventEmitter::class.java) - - breezServices = connect(configTmp, asUByteList(seed), BreezSDKListener(emitter)) + val logFilePathTmp = logFilePath.takeUnless { it.isEmpty() } + + breezServices = connect(configTmp, asUByteList(seed), BreezSDKListener(emitter), BreezSDKNodeLogger(emitter), logFilePathTmp) promise.resolve(readableMapOf("status" to "ok")) } catch (e: SdkException) { e.printStackTrace() diff --git a/src/gen_swift/templates/extern.m b/src/gen_swift/templates/extern.m index fc5a9e3..2e59914 100644 --- a/src/gen_swift/templates/extern.m +++ b/src/gen_swift/templates/extern.m @@ -15,6 +15,7 @@ @interface RCT_EXTERN_MODULE(RNBreezSDK, RCTEventEmitter) RCT_EXTERN_METHOD( connect: (NSDictionary*)config seed: (NSArray*)seed + logFilePath: (NSString*)logFilePath resolve: (RCTPromiseResolveBlock)resolve reject: (RCTPromiseRejectBlock)reject ) diff --git a/src/gen_swift/templates/module.swift b/src/gen_swift/templates/module.swift index 4ee29eb..674e5f2 100644 --- a/src/gen_swift/templates/module.swift +++ b/src/gen_swift/templates/module.swift @@ -24,7 +24,7 @@ class RNBreezSDK: RCTEventEmitter { } override func supportedEvents() -> [String]! { - return [BreezSDKListener.emitterName, BreezSDKLogStream.emitterName] + return [BreezSDKListener.emitterName, BreezSDKLogStream.emitterName, BreezSDKNodeLogger.emitterName] } @objc @@ -56,8 +56,8 @@ class RNBreezSDK: RCTEventEmitter { } } - @objc(connect:seed:resolve:reject:) - func connect(_ config:[String: Any], seed:[UInt8], resolve: @escaping RCTPromiseResolveBlock, reject: @escaping RCTPromiseRejectBlock) -> Void { + @objc(connect:seed:logFilePath:resolve:reject:) + func connect(_ config: [String: Any], seed: [UInt8], logFilePath: String, resolve: @escaping RCTPromiseResolveBlock, reject: @escaping RCTPromiseRejectBlock) { if self.breezServices != nil { reject(RNBreezSDK.TAG, "BreezServices already initialized", nil) return @@ -65,7 +65,8 @@ class RNBreezSDK: RCTEventEmitter { do { let configTmp = try BreezSDKMapper.asConfig(data: config) - self.breezServices = try BreezSDK.connect(config: configTmp, seed: seed, listener: BreezSDKListener(emitter: self)) + let logFilePathTmp = logFilePath.isEmpty ? nil : logFilePath + breezServices = try BreezSDK.connect(config: configTmp, seed: seed, listener: BreezSDKListener(emitter: self), nodeLogger: BreezSDKNodeLogger(emitter: self), logFilePath: logFilePathTmp) resolve(["status": "ok"]) } catch let err { rejectErr(err: err, reject: reject) diff --git a/src/gen_typescript/templates/Helpers.ts b/src/gen_typescript/templates/Helpers.ts index 1e71826..050dbaf 100644 --- a/src/gen_typescript/templates/Helpers.ts +++ b/src/gen_typescript/templates/Helpers.ts @@ -2,10 +2,14 @@ export type EventListener = (breezEvent: BreezEvent) => void export type LogStream = (logEntry: LogEntry) => void -export const connect = async (config: Config, seed: number[], listener: EventListener): Promise => { +export type Logger = (logMessage: LogMessage) => void + +export const connect = async (config: Config, seed: number[], listener: EventListener, nodeLogger: Logger, logFilePath?: string ): Promise => { const subscription = BreezSDKEmitter.addListener("breezSdkEvent", listener) - await BreezSDK.connect(config, seed) + BreezSDKEmitter.addListener("breezSdkNodeLog", nodeLogger) + + await BreezSDK.connect(config, seed, logFilePath) return subscription }