@uns-kit/core 2.0.22 → 2.0.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (80) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +130 -130
  3. package/dist/base-path.js.map +1 -1
  4. package/dist/config/app-config.d.ts +140 -140
  5. package/dist/config/project.config.extension.js.map +1 -1
  6. package/dist/config-file.js.map +1 -1
  7. package/dist/graphql/schema.js.map +1 -1
  8. package/dist/index.d.ts +7 -7
  9. package/dist/index.js +6 -6
  10. package/dist/index.js.map +1 -1
  11. package/dist/logger.d.ts +3 -3
  12. package/dist/logger.d.ts.map +1 -1
  13. package/dist/logger.js +88 -80
  14. package/dist/logger.js.map +1 -1
  15. package/dist/tools/auth/auth-client.js.map +1 -1
  16. package/dist/tools/auth/index.js.map +1 -1
  17. package/dist/tools/auth/secure-store.js.map +1 -1
  18. package/dist/tools/base-path.js.map +1 -1
  19. package/dist/tools/file-utils.js.map +1 -1
  20. package/dist/tools/generate-config-schema.js.map +1 -1
  21. package/dist/tools/generate-uns-dictionary.js +7 -7
  22. package/dist/tools/generate-uns-dictionary.js.map +1 -1
  23. package/dist/tools/generate-uns-measurements.js +7 -7
  24. package/dist/tools/generate-uns-measurements.js.map +1 -1
  25. package/dist/tools/generate-uns-reference.js +9 -9
  26. package/dist/tools/generate-uns-reference.js.map +1 -1
  27. package/dist/tools/pull-request.js.map +1 -1
  28. package/dist/tools/refresh-uns.js +50 -50
  29. package/dist/tools/refresh-uns.js.map +1 -1
  30. package/dist/tools/schema.js.map +1 -1
  31. package/dist/tools/sync-uns-schema.js +14 -14
  32. package/dist/tools/sync-uns-schema.js.map +1 -1
  33. package/dist/uns/handover-manager-event-emitter.js.map +1 -1
  34. package/dist/uns/handover-manager.js.map +1 -1
  35. package/dist/uns/process-config.js.map +1 -1
  36. package/dist/uns/process-name-service.js.map +1 -1
  37. package/dist/uns/status-monitor.js.map +1 -1
  38. package/dist/uns/uns-asset.js.map +1 -1
  39. package/dist/uns/uns-attributes.d.ts +2 -2
  40. package/dist/uns/uns-attributes.js.map +1 -1
  41. package/dist/uns/uns-dictionary-registry.js.map +1 -1
  42. package/dist/uns/uns-dictionary.generated.js.map +1 -1
  43. package/dist/uns/uns-event-emitter.js.map +1 -1
  44. package/dist/uns/uns-interfaces.js.map +1 -1
  45. package/dist/uns/uns-measurements.generated.js.map +1 -1
  46. package/dist/uns/uns-measurements.js.map +1 -1
  47. package/dist/uns/uns-object.js.map +1 -1
  48. package/dist/uns/uns-packet.js.map +1 -1
  49. package/dist/uns/uns-path.js.map +1 -1
  50. package/dist/uns/uns-proxy-process.js.map +1 -1
  51. package/dist/uns/uns-proxy.js.map +1 -1
  52. package/dist/uns/uns-tags.js.map +1 -1
  53. package/dist/uns/uns-topic-matcher.js.map +1 -1
  54. package/dist/uns/uns-topics.js.map +1 -1
  55. package/dist/uns-config/config-schema.js.map +1 -1
  56. package/dist/uns-config/host-placeholders.js.map +1 -1
  57. package/dist/uns-config/schema-tolls.js.map +1 -1
  58. package/dist/uns-config/schema-tools.js.map +1 -1
  59. package/dist/uns-config/secret-placeholders.js.map +1 -1
  60. package/dist/uns-config/secret-resolver.js.map +1 -1
  61. package/dist/uns-config/uns-core-schema.d.ts +3271 -3271
  62. package/dist/uns-config/uns-core-schema.js +76 -76
  63. package/dist/uns-config/uns-core-schema.js.map +1 -1
  64. package/dist/uns-grpc/uns-gateway-cli.js.map +1 -1
  65. package/dist/uns-grpc/uns-gateway-server.js.map +1 -1
  66. package/dist/uns-grpc/uns-gateway.proto +104 -104
  67. package/dist/uns-mqtt/mqtt-interfaces.js.map +1 -1
  68. package/dist/uns-mqtt/mqtt-proxy.d.ts +7 -0
  69. package/dist/uns-mqtt/mqtt-proxy.d.ts.map +1 -1
  70. package/dist/uns-mqtt/mqtt-proxy.js +70 -25
  71. package/dist/uns-mqtt/mqtt-proxy.js.map +1 -1
  72. package/dist/uns-mqtt/mqtt-topic-builder.js.map +1 -1
  73. package/dist/uns-mqtt/mqtt-worker-init.js.map +1 -1
  74. package/dist/uns-mqtt/mqtt-worker.js.map +1 -1
  75. package/dist/uns-mqtt/throttled-queue.js.map +1 -1
  76. package/dist/uns-mqtt/uns-mqtt-proxy.js.map +1 -1
  77. package/dist/uns-mqtt/ws-proxy.js.map +1 -1
  78. package/package.json +1 -1
  79. package/dist/app-config.d.ts.map +0 -1
  80. package/dist/app-config.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"schema.js","sourceRoot":"","sources":["../../src/graphql/schema.ts"],"names":[],"mappings":"AA0KA,MAAM,CAAN,IAAY,gBAIX;AAJD,WAAY,gBAAgB;IAC1B,+BAAW,CAAA;IACX,iCAAa,CAAA;IACb,mCAAe,CAAA;AACjB,CAAC,EAJW,gBAAgB,KAAhB,gBAAgB,QAI3B;AAqBD,MAAM,CAAN,IAAY,WAIX;AAJD,WAAY,WAAW;IACrB,sCAAuB,CAAA;IACvB,4CAA6B,CAAA;IAC7B,8BAAe,CAAA;AACjB,CAAC,EAJW,WAAW,KAAX,WAAW,QAItB","sourcesContent":["import { GraphQLResolveInfo, GraphQLScalarType, GraphQLScalarTypeConfig } from 'graphql';\r\nexport type Maybe<T> = T | null;\r\nexport type InputMaybe<T> = Maybe<T>;\r\nexport type Exact<T extends { [key: string]: unknown }> = { [K in keyof T]: T[K] };\r\nexport type MakeOptional<T, K extends keyof T> = Omit<T, K> & { [SubKey in K]?: Maybe<T[SubKey]> };\r\nexport type MakeMaybe<T, K extends keyof T> = Omit<T, K> & { [SubKey in K]: Maybe<T[SubKey]> };\r\nexport type MakeEmpty<T extends { [key: string]: unknown }, K extends keyof T> = { [_ in K]?: never };\r\nexport type Incremental<T> = T | { [P in keyof T]?: P extends ' $fragmentName' | '__typename' ? T[P] : never };\r\n/** All built-in and custom scalars, mapped to their actual values */\r\nexport type Scalars = {\r\n ID: { input: string; output: string; }\r\n String: { input: string; output: string; }\r\n Boolean: { input: boolean; output: boolean; }\r\n Int: { input: number; output: number; }\r\n Float: { input: number; output: number; }\r\n Date: { input: any; output: any; }\r\n Timestamp: { input: any; output: any; }\r\n};\r\n\r\nexport type InitUnsTopic = {\r\n topic?: InputMaybe<Scalars['String']['input']>;\r\n};\r\n\r\nexport type InsertUnsNode = {\r\n apiDescription?: InputMaybe<Scalars['String']['input']>;\r\n apiEndpoint?: InputMaybe<Scalars['String']['input']>;\r\n apiMethod?: InputMaybe<Scalars['String']['input']>;\r\n attributeNeedsPersistance?: InputMaybe<Scalars['Boolean']['input']>;\r\n attributeTags?: InputMaybe<Array<InputMaybe<Scalars['String']['input']>>>;\r\n attributeTimestamp?: InputMaybe<Scalars['Timestamp']['input']>;\r\n attributeType?: InputMaybe<UnsAttributeType>;\r\n description?: InputMaybe<Scalars['String']['input']>;\r\n fullTopic?: InputMaybe<Scalars['String']['input']>;\r\n parent: Scalars['Int']['input'];\r\n processName?: InputMaybe<Scalars['String']['input']>;\r\n processVersion?: InputMaybe<Scalars['String']['input']>;\r\n type?: InputMaybe<UnsNodeType>;\r\n unsNode?: InputMaybe<Scalars['String']['input']>;\r\n};\r\n\r\nexport type Mutation = {\r\n __typename?: 'Mutation';\r\n AddUnsNode?: Maybe<Scalars['Int']['output']>;\r\n DeleteRttNode?: Maybe<Scalars['Boolean']['output']>;\r\n DeleteUnsNode?: Maybe<Scalars['Boolean']['output']>;\r\n DeployRttNode?: Maybe<Scalars['Boolean']['output']>;\r\n ModifyUnsNode?: Maybe<Scalars['Boolean']['output']>;\r\n /** Purge all nodes that are older the maxAge in hours */\r\n PurgeOldNodes?: Maybe<Scalars['Boolean']['output']>;\r\n SetRttNodeConfig?: Maybe<Scalars['Boolean']['output']>;\r\n StartRttNode?: Maybe<Scalars['Boolean']['output']>;\r\n StopRttNode?: Maybe<Scalars['Boolean']['output']>;\r\n};\r\n\r\n\r\nexport type MutationAddUnsNodeArgs = {\r\n node?: InputMaybe<InsertUnsNode>;\r\n};\r\n\r\n\r\nexport type MutationDeleteRttNodeArgs = {\r\n rttNode?: InputMaybe<Scalars['String']['input']>;\r\n};\r\n\r\n\r\nexport type MutationDeleteUnsNodeArgs = {\r\n id?: InputMaybe<Scalars['Int']['input']>;\r\n};\r\n\r\n\r\nexport type MutationDeployRttNodeArgs = {\r\n rttNode?: InputMaybe<Scalars['String']['input']>;\r\n tag?: InputMaybe<Scalars['String']['input']>;\r\n};\r\n\r\n\r\nexport type MutationModifyUnsNodeArgs = {\r\n id?: InputMaybe<Scalars['Int']['input']>;\r\n node?: InputMaybe<UpdateUnsNode>;\r\n};\r\n\r\n\r\nexport type MutationPurgeOldNodesArgs = {\r\n maxAge?: InputMaybe<Scalars['Int']['input']>;\r\n};\r\n\r\n\r\nexport type MutationSetRttNodeConfigArgs = {\r\n configuration?: InputMaybe<Scalars['String']['input']>;\r\n rttNode?: InputMaybe<Scalars['String']['input']>;\r\n};\r\n\r\n\r\nexport type MutationStartRttNodeArgs = {\r\n rttNode?: InputMaybe<Scalars['String']['input']>;\r\n};\r\n\r\n\r\nexport type MutationStopRttNodeArgs = {\r\n rttNode?: InputMaybe<Scalars['String']['input']>;\r\n};\r\n\r\n/** name: uns-datahub */\r\nexport type Query = {\r\n __typename?: 'Query';\r\n GetRepositories?: Maybe<Array<Maybe<Repository>>>;\r\n GetRttNodeConfig?: Maybe<Scalars['String']['output']>;\r\n GetRttNodes?: Maybe<Array<Maybe<RttNode>>>;\r\n GetTags?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\r\n GetTreeStructure?: Maybe<Array<Maybe<TreeStructure>>>;\r\n GetUnsNodes?: Maybe<Array<Maybe<UnsNode>>>;\r\n};\r\n\r\n\r\n/** name: uns-datahub */\r\nexport type QueryGetRttNodeConfigArgs = {\r\n rttNode?: InputMaybe<Scalars['String']['input']>;\r\n};\r\n\r\n\r\n/** name: uns-datahub */\r\nexport type QueryGetTreeStructureArgs = {\r\n attributeTags?: InputMaybe<Array<InputMaybe<Scalars['String']['input']>>>;\r\n};\r\n\r\nexport type Repository = {\r\n __typename?: 'Repository';\r\n name?: Maybe<Scalars['String']['output']>;\r\n tags?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\r\n};\r\n\r\nexport type RttNode = {\r\n __typename?: 'RttNode';\r\n author?: Maybe<Scalars['String']['output']>;\r\n deployedVersions?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\r\n description?: Maybe<Scalars['String']['output']>;\r\n lastErrLog?: Maybe<Scalars['String']['output']>;\r\n lastLog?: Maybe<Scalars['String']['output']>;\r\n latestDeployedVersion?: Maybe<Scalars['String']['output']>;\r\n memory?: Maybe<Scalars['Int']['output']>;\r\n pid?: Maybe<Scalars['Int']['output']>;\r\n restarts?: Maybe<Scalars['Int']['output']>;\r\n rttNode?: Maybe<Scalars['String']['output']>;\r\n runningVersion?: Maybe<Scalars['String']['output']>;\r\n status?: Maybe<Scalars['String']['output']>;\r\n topics?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\r\n uptime?: Maybe<Scalars['Int']['output']>;\r\n version?: Maybe<Scalars['String']['output']>;\r\n};\r\n\r\nexport type TreeStructure = {\r\n __typename?: 'TreeStructure';\r\n apiDescription?: Maybe<Scalars['String']['output']>;\r\n apiEndpoint?: Maybe<Scalars['String']['output']>;\r\n apiMethod?: Maybe<Scalars['String']['output']>;\r\n attributeNeedsPersistance?: Maybe<Scalars['Boolean']['output']>;\r\n attributeTags?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\r\n attributeTimestamp?: Maybe<Scalars['Timestamp']['output']>;\r\n attributeType?: Maybe<UnsAttributeType>;\r\n children?: Maybe<Array<Maybe<TreeStructure>>>;\r\n description?: Maybe<Scalars['String']['output']>;\r\n fullTopic?: Maybe<Scalars['String']['output']>;\r\n id?: Maybe<Scalars['Int']['output']>;\r\n parent?: Maybe<Scalars['Int']['output']>;\r\n processName?: Maybe<Scalars['String']['output']>;\r\n processVersion?: Maybe<Scalars['String']['output']>;\r\n type?: Maybe<UnsNodeType>;\r\n unsNode?: Maybe<Scalars['String']['output']>;\r\n};\r\n\r\nexport enum UnsAttributeType {\r\n Api = 'Api',\r\n Data = 'Data',\r\n Table = 'Table'\r\n}\r\n\r\nexport type UnsNode = {\r\n __typename?: 'UnsNode';\r\n apiDescription?: Maybe<Scalars['String']['output']>;\r\n apiEndpoint?: Maybe<Scalars['String']['output']>;\r\n apiMethod?: Maybe<Scalars['String']['output']>;\r\n attributeNeedsPersistance?: Maybe<Scalars['Boolean']['output']>;\r\n attributeTags?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\r\n attributeTimestamp?: Maybe<Scalars['Timestamp']['output']>;\r\n attributeType?: Maybe<UnsAttributeType>;\r\n description?: Maybe<Scalars['String']['output']>;\r\n fullTopic?: Maybe<Scalars['String']['output']>;\r\n id?: Maybe<Scalars['Int']['output']>;\r\n parent?: Maybe<Scalars['Int']['output']>;\r\n processName?: Maybe<Scalars['String']['output']>;\r\n processVersion?: Maybe<Scalars['String']['output']>;\r\n type?: Maybe<UnsNodeType>;\r\n unsNode?: Maybe<Scalars['String']['output']>;\r\n};\r\n\r\nexport enum UnsNodeType {\r\n Attribute = 'Attribute',\r\n DynamicTopic = 'DynamicTopic',\r\n Topic = 'Topic'\r\n}\r\n\r\nexport type UpdateUnsNode = {\r\n apiDescription?: InputMaybe<Scalars['String']['input']>;\r\n apiEndpoint?: InputMaybe<Scalars['String']['input']>;\r\n apiMethod?: InputMaybe<Scalars['String']['input']>;\r\n attributeNeedsPersistance?: InputMaybe<Scalars['Boolean']['input']>;\r\n attributeTags?: InputMaybe<Array<InputMaybe<Scalars['String']['input']>>>;\r\n attributeTimestamp?: InputMaybe<Scalars['Timestamp']['input']>;\r\n attributeType?: InputMaybe<UnsAttributeType>;\r\n description?: InputMaybe<Scalars['String']['input']>;\r\n fullTopic?: InputMaybe<Scalars['String']['input']>;\r\n parent?: InputMaybe<Scalars['Int']['input']>;\r\n processName?: InputMaybe<Scalars['String']['input']>;\r\n processVersion?: InputMaybe<Scalars['String']['input']>;\r\n type?: InputMaybe<UnsNodeType>;\r\n unsNode?: InputMaybe<Scalars['String']['input']>;\r\n};\r\n\r\n\r\n\r\nexport type ResolverTypeWrapper<T> = Promise<T> | T;\r\n\r\n\r\nexport type ResolverWithResolve<TResult, TParent, TContext, TArgs> = {\r\n resolve: ResolverFn<TResult, TParent, TContext, TArgs>;\r\n};\r\nexport type Resolver<TResult, TParent = {}, TContext = {}, TArgs = {}> = ResolverFn<TResult, TParent, TContext, TArgs> | ResolverWithResolve<TResult, TParent, TContext, TArgs>;\r\n\r\nexport type ResolverFn<TResult, TParent, TContext, TArgs> = (\r\n parent: TParent,\r\n args: TArgs,\r\n context: TContext,\r\n info: GraphQLResolveInfo\r\n) => Promise<TResult> | TResult;\r\n\r\nexport type SubscriptionSubscribeFn<TResult, TParent, TContext, TArgs> = (\r\n parent: TParent,\r\n args: TArgs,\r\n context: TContext,\r\n info: GraphQLResolveInfo\r\n) => AsyncIterable<TResult> | Promise<AsyncIterable<TResult>>;\r\n\r\nexport type SubscriptionResolveFn<TResult, TParent, TContext, TArgs> = (\r\n parent: TParent,\r\n args: TArgs,\r\n context: TContext,\r\n info: GraphQLResolveInfo\r\n) => TResult | Promise<TResult>;\r\n\r\nexport interface SubscriptionSubscriberObject<TResult, TKey extends string, TParent, TContext, TArgs> {\r\n subscribe: SubscriptionSubscribeFn<{ [key in TKey]: TResult }, TParent, TContext, TArgs>;\r\n resolve?: SubscriptionResolveFn<TResult, { [key in TKey]: TResult }, TContext, TArgs>;\r\n}\r\n\r\nexport interface SubscriptionResolverObject<TResult, TParent, TContext, TArgs> {\r\n subscribe: SubscriptionSubscribeFn<any, TParent, TContext, TArgs>;\r\n resolve: SubscriptionResolveFn<TResult, any, TContext, TArgs>;\r\n}\r\n\r\nexport type SubscriptionObject<TResult, TKey extends string, TParent, TContext, TArgs> =\r\n | SubscriptionSubscriberObject<TResult, TKey, TParent, TContext, TArgs>\r\n | SubscriptionResolverObject<TResult, TParent, TContext, TArgs>;\r\n\r\nexport type SubscriptionResolver<TResult, TKey extends string, TParent = {}, TContext = {}, TArgs = {}> =\r\n | ((...args: any[]) => SubscriptionObject<TResult, TKey, TParent, TContext, TArgs>)\r\n | SubscriptionObject<TResult, TKey, TParent, TContext, TArgs>;\r\n\r\nexport type TypeResolveFn<TTypes, TParent = {}, TContext = {}> = (\r\n parent: TParent,\r\n context: TContext,\r\n info: GraphQLResolveInfo\r\n) => Maybe<TTypes> | Promise<Maybe<TTypes>>;\r\n\r\nexport type IsTypeOfResolverFn<T = {}, TContext = {}> = (obj: T, context: TContext, info: GraphQLResolveInfo) => boolean | Promise<boolean>;\r\n\r\nexport type NextResolverFn<T> = () => Promise<T>;\r\n\r\nexport type DirectiveResolverFn<TResult = {}, TParent = {}, TContext = {}, TArgs = {}> = (\r\n next: NextResolverFn<TResult>,\r\n parent: TParent,\r\n args: TArgs,\r\n context: TContext,\r\n info: GraphQLResolveInfo\r\n) => TResult | Promise<TResult>;\r\n\r\n\r\n\r\n/** Mapping between all available schema types and the resolvers types */\r\nexport type ResolversTypes = {\r\n Boolean: ResolverTypeWrapper<Scalars['Boolean']['output']>;\r\n Date: ResolverTypeWrapper<Scalars['Date']['output']>;\r\n InitUnsTopic: InitUnsTopic;\r\n InsertUnsNode: InsertUnsNode;\r\n Int: ResolverTypeWrapper<Scalars['Int']['output']>;\r\n Mutation: ResolverTypeWrapper<{}>;\r\n Query: ResolverTypeWrapper<{}>;\r\n Repository: ResolverTypeWrapper<Repository>;\r\n RttNode: ResolverTypeWrapper<RttNode>;\r\n String: ResolverTypeWrapper<Scalars['String']['output']>;\r\n Timestamp: ResolverTypeWrapper<Scalars['Timestamp']['output']>;\r\n TreeStructure: ResolverTypeWrapper<TreeStructure>;\r\n UnsAttributeType: UnsAttributeType;\r\n UnsNode: ResolverTypeWrapper<UnsNode>;\r\n UnsNodeType: UnsNodeType;\r\n UpdateUnsNode: UpdateUnsNode;\r\n};\r\n\r\n/** Mapping between all available schema types and the resolvers parents */\r\nexport type ResolversParentTypes = {\r\n Boolean: Scalars['Boolean']['output'];\r\n Date: Scalars['Date']['output'];\r\n InitUnsTopic: InitUnsTopic;\r\n InsertUnsNode: InsertUnsNode;\r\n Int: Scalars['Int']['output'];\r\n Mutation: {};\r\n Query: {};\r\n Repository: Repository;\r\n RttNode: RttNode;\r\n String: Scalars['String']['output'];\r\n Timestamp: Scalars['Timestamp']['output'];\r\n TreeStructure: TreeStructure;\r\n UnsNode: UnsNode;\r\n UpdateUnsNode: UpdateUnsNode;\r\n};\r\n\r\nexport interface DateScalarConfig extends GraphQLScalarTypeConfig<ResolversTypes['Date'], any> {\r\n name: 'Date';\r\n}\r\n\r\nexport type MutationResolvers<ContextType = any, ParentType extends ResolversParentTypes['Mutation'] = ResolversParentTypes['Mutation']> = {\r\n AddUnsNode?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType, Partial<MutationAddUnsNodeArgs>>;\r\n DeleteRttNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationDeleteRttNodeArgs>>;\r\n DeleteUnsNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationDeleteUnsNodeArgs>>;\r\n DeployRttNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationDeployRttNodeArgs>>;\r\n ModifyUnsNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationModifyUnsNodeArgs>>;\r\n PurgeOldNodes?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationPurgeOldNodesArgs>>;\r\n SetRttNodeConfig?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationSetRttNodeConfigArgs>>;\r\n StartRttNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationStartRttNodeArgs>>;\r\n StopRttNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationStopRttNodeArgs>>;\r\n};\r\n\r\nexport type QueryResolvers<ContextType = any, ParentType extends ResolversParentTypes['Query'] = ResolversParentTypes['Query']> = {\r\n GetRepositories?: Resolver<Maybe<Array<Maybe<ResolversTypes['Repository']>>>, ParentType, ContextType>;\r\n GetRttNodeConfig?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType, Partial<QueryGetRttNodeConfigArgs>>;\r\n GetRttNodes?: Resolver<Maybe<Array<Maybe<ResolversTypes['RttNode']>>>, ParentType, ContextType>;\r\n GetTags?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\r\n GetTreeStructure?: Resolver<Maybe<Array<Maybe<ResolversTypes['TreeStructure']>>>, ParentType, ContextType, Partial<QueryGetTreeStructureArgs>>;\r\n GetUnsNodes?: Resolver<Maybe<Array<Maybe<ResolversTypes['UnsNode']>>>, ParentType, ContextType>;\r\n};\r\n\r\nexport type RepositoryResolvers<ContextType = any, ParentType extends ResolversParentTypes['Repository'] = ResolversParentTypes['Repository']> = {\r\n name?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n tags?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\r\n __isTypeOf?: IsTypeOfResolverFn<ParentType, ContextType>;\r\n};\r\n\r\nexport type RttNodeResolvers<ContextType = any, ParentType extends ResolversParentTypes['RttNode'] = ResolversParentTypes['RttNode']> = {\r\n author?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n deployedVersions?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\r\n description?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n lastErrLog?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n lastLog?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n latestDeployedVersion?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n memory?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\r\n pid?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\r\n restarts?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\r\n rttNode?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n runningVersion?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n status?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n topics?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\r\n uptime?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\r\n version?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n __isTypeOf?: IsTypeOfResolverFn<ParentType, ContextType>;\r\n};\r\n\r\nexport interface TimestampScalarConfig extends GraphQLScalarTypeConfig<ResolversTypes['Timestamp'], any> {\r\n name: 'Timestamp';\r\n}\r\n\r\nexport type TreeStructureResolvers<ContextType = any, ParentType extends ResolversParentTypes['TreeStructure'] = ResolversParentTypes['TreeStructure']> = {\r\n apiDescription?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n apiEndpoint?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n apiMethod?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n attributeNeedsPersistance?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType>;\r\n attributeTags?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\r\n attributeTimestamp?: Resolver<Maybe<ResolversTypes['Timestamp']>, ParentType, ContextType>;\r\n attributeType?: Resolver<Maybe<ResolversTypes['UnsAttributeType']>, ParentType, ContextType>;\r\n children?: Resolver<Maybe<Array<Maybe<ResolversTypes['TreeStructure']>>>, ParentType, ContextType>;\r\n description?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n fullTopic?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n id?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\r\n parent?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\r\n processName?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n processVersion?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n type?: Resolver<Maybe<ResolversTypes['UnsNodeType']>, ParentType, ContextType>;\r\n unsNode?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n __isTypeOf?: IsTypeOfResolverFn<ParentType, ContextType>;\r\n};\r\n\r\nexport type UnsNodeResolvers<ContextType = any, ParentType extends ResolversParentTypes['UnsNode'] = ResolversParentTypes['UnsNode']> = {\r\n apiDescription?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n apiEndpoint?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n apiMethod?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n attributeNeedsPersistance?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType>;\r\n attributeTags?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\r\n attributeTimestamp?: Resolver<Maybe<ResolversTypes['Timestamp']>, ParentType, ContextType>;\r\n attributeType?: Resolver<Maybe<ResolversTypes['UnsAttributeType']>, ParentType, ContextType>;\r\n description?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n fullTopic?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n id?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\r\n parent?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\r\n processName?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n processVersion?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n type?: Resolver<Maybe<ResolversTypes['UnsNodeType']>, ParentType, ContextType>;\r\n unsNode?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\r\n __isTypeOf?: IsTypeOfResolverFn<ParentType, ContextType>;\r\n};\r\n\r\nexport type Resolvers<ContextType = any> = {\r\n Date?: GraphQLScalarType;\r\n Mutation?: MutationResolvers<ContextType>;\r\n Query?: QueryResolvers<ContextType>;\r\n Repository?: RepositoryResolvers<ContextType>;\r\n RttNode?: RttNodeResolvers<ContextType>;\r\n Timestamp?: GraphQLScalarType;\r\n TreeStructure?: TreeStructureResolvers<ContextType>;\r\n UnsNode?: UnsNodeResolvers<ContextType>;\r\n};\r\n"]}
1
+ {"version":3,"file":"schema.js","sourceRoot":"","sources":["../../src/graphql/schema.ts"],"names":[],"mappings":"AA0KA,MAAM,CAAN,IAAY,gBAIX;AAJD,WAAY,gBAAgB;IAC1B,+BAAW,CAAA;IACX,iCAAa,CAAA;IACb,mCAAe,CAAA;AACjB,CAAC,EAJW,gBAAgB,KAAhB,gBAAgB,QAI3B;AAqBD,MAAM,CAAN,IAAY,WAIX;AAJD,WAAY,WAAW;IACrB,sCAAuB,CAAA;IACvB,4CAA6B,CAAA;IAC7B,8BAAe,CAAA;AACjB,CAAC,EAJW,WAAW,KAAX,WAAW,QAItB","sourcesContent":["import { GraphQLResolveInfo, GraphQLScalarType, GraphQLScalarTypeConfig } from 'graphql';\nexport type Maybe<T> = T | null;\nexport type InputMaybe<T> = Maybe<T>;\nexport type Exact<T extends { [key: string]: unknown }> = { [K in keyof T]: T[K] };\nexport type MakeOptional<T, K extends keyof T> = Omit<T, K> & { [SubKey in K]?: Maybe<T[SubKey]> };\nexport type MakeMaybe<T, K extends keyof T> = Omit<T, K> & { [SubKey in K]: Maybe<T[SubKey]> };\nexport type MakeEmpty<T extends { [key: string]: unknown }, K extends keyof T> = { [_ in K]?: never };\nexport type Incremental<T> = T | { [P in keyof T]?: P extends ' $fragmentName' | '__typename' ? T[P] : never };\n/** All built-in and custom scalars, mapped to their actual values */\nexport type Scalars = {\n ID: { input: string; output: string; }\n String: { input: string; output: string; }\n Boolean: { input: boolean; output: boolean; }\n Int: { input: number; output: number; }\n Float: { input: number; output: number; }\n Date: { input: any; output: any; }\n Timestamp: { input: any; output: any; }\n};\n\nexport type InitUnsTopic = {\n topic?: InputMaybe<Scalars['String']['input']>;\n};\n\nexport type InsertUnsNode = {\n apiDescription?: InputMaybe<Scalars['String']['input']>;\n apiEndpoint?: InputMaybe<Scalars['String']['input']>;\n apiMethod?: InputMaybe<Scalars['String']['input']>;\n attributeNeedsPersistance?: InputMaybe<Scalars['Boolean']['input']>;\n attributeTags?: InputMaybe<Array<InputMaybe<Scalars['String']['input']>>>;\n attributeTimestamp?: InputMaybe<Scalars['Timestamp']['input']>;\n attributeType?: InputMaybe<UnsAttributeType>;\n description?: InputMaybe<Scalars['String']['input']>;\n fullTopic?: InputMaybe<Scalars['String']['input']>;\n parent: Scalars['Int']['input'];\n processName?: InputMaybe<Scalars['String']['input']>;\n processVersion?: InputMaybe<Scalars['String']['input']>;\n type?: InputMaybe<UnsNodeType>;\n unsNode?: InputMaybe<Scalars['String']['input']>;\n};\n\nexport type Mutation = {\n __typename?: 'Mutation';\n AddUnsNode?: Maybe<Scalars['Int']['output']>;\n DeleteRttNode?: Maybe<Scalars['Boolean']['output']>;\n DeleteUnsNode?: Maybe<Scalars['Boolean']['output']>;\n DeployRttNode?: Maybe<Scalars['Boolean']['output']>;\n ModifyUnsNode?: Maybe<Scalars['Boolean']['output']>;\n /** Purge all nodes that are older the maxAge in hours */\n PurgeOldNodes?: Maybe<Scalars['Boolean']['output']>;\n SetRttNodeConfig?: Maybe<Scalars['Boolean']['output']>;\n StartRttNode?: Maybe<Scalars['Boolean']['output']>;\n StopRttNode?: Maybe<Scalars['Boolean']['output']>;\n};\n\n\nexport type MutationAddUnsNodeArgs = {\n node?: InputMaybe<InsertUnsNode>;\n};\n\n\nexport type MutationDeleteRttNodeArgs = {\n rttNode?: InputMaybe<Scalars['String']['input']>;\n};\n\n\nexport type MutationDeleteUnsNodeArgs = {\n id?: InputMaybe<Scalars['Int']['input']>;\n};\n\n\nexport type MutationDeployRttNodeArgs = {\n rttNode?: InputMaybe<Scalars['String']['input']>;\n tag?: InputMaybe<Scalars['String']['input']>;\n};\n\n\nexport type MutationModifyUnsNodeArgs = {\n id?: InputMaybe<Scalars['Int']['input']>;\n node?: InputMaybe<UpdateUnsNode>;\n};\n\n\nexport type MutationPurgeOldNodesArgs = {\n maxAge?: InputMaybe<Scalars['Int']['input']>;\n};\n\n\nexport type MutationSetRttNodeConfigArgs = {\n configuration?: InputMaybe<Scalars['String']['input']>;\n rttNode?: InputMaybe<Scalars['String']['input']>;\n};\n\n\nexport type MutationStartRttNodeArgs = {\n rttNode?: InputMaybe<Scalars['String']['input']>;\n};\n\n\nexport type MutationStopRttNodeArgs = {\n rttNode?: InputMaybe<Scalars['String']['input']>;\n};\n\n/** name: uns-datahub */\nexport type Query = {\n __typename?: 'Query';\n GetRepositories?: Maybe<Array<Maybe<Repository>>>;\n GetRttNodeConfig?: Maybe<Scalars['String']['output']>;\n GetRttNodes?: Maybe<Array<Maybe<RttNode>>>;\n GetTags?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\n GetTreeStructure?: Maybe<Array<Maybe<TreeStructure>>>;\n GetUnsNodes?: Maybe<Array<Maybe<UnsNode>>>;\n};\n\n\n/** name: uns-datahub */\nexport type QueryGetRttNodeConfigArgs = {\n rttNode?: InputMaybe<Scalars['String']['input']>;\n};\n\n\n/** name: uns-datahub */\nexport type QueryGetTreeStructureArgs = {\n attributeTags?: InputMaybe<Array<InputMaybe<Scalars['String']['input']>>>;\n};\n\nexport type Repository = {\n __typename?: 'Repository';\n name?: Maybe<Scalars['String']['output']>;\n tags?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\n};\n\nexport type RttNode = {\n __typename?: 'RttNode';\n author?: Maybe<Scalars['String']['output']>;\n deployedVersions?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\n description?: Maybe<Scalars['String']['output']>;\n lastErrLog?: Maybe<Scalars['String']['output']>;\n lastLog?: Maybe<Scalars['String']['output']>;\n latestDeployedVersion?: Maybe<Scalars['String']['output']>;\n memory?: Maybe<Scalars['Int']['output']>;\n pid?: Maybe<Scalars['Int']['output']>;\n restarts?: Maybe<Scalars['Int']['output']>;\n rttNode?: Maybe<Scalars['String']['output']>;\n runningVersion?: Maybe<Scalars['String']['output']>;\n status?: Maybe<Scalars['String']['output']>;\n topics?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\n uptime?: Maybe<Scalars['Int']['output']>;\n version?: Maybe<Scalars['String']['output']>;\n};\n\nexport type TreeStructure = {\n __typename?: 'TreeStructure';\n apiDescription?: Maybe<Scalars['String']['output']>;\n apiEndpoint?: Maybe<Scalars['String']['output']>;\n apiMethod?: Maybe<Scalars['String']['output']>;\n attributeNeedsPersistance?: Maybe<Scalars['Boolean']['output']>;\n attributeTags?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\n attributeTimestamp?: Maybe<Scalars['Timestamp']['output']>;\n attributeType?: Maybe<UnsAttributeType>;\n children?: Maybe<Array<Maybe<TreeStructure>>>;\n description?: Maybe<Scalars['String']['output']>;\n fullTopic?: Maybe<Scalars['String']['output']>;\n id?: Maybe<Scalars['Int']['output']>;\n parent?: Maybe<Scalars['Int']['output']>;\n processName?: Maybe<Scalars['String']['output']>;\n processVersion?: Maybe<Scalars['String']['output']>;\n type?: Maybe<UnsNodeType>;\n unsNode?: Maybe<Scalars['String']['output']>;\n};\n\nexport enum UnsAttributeType {\n Api = 'Api',\n Data = 'Data',\n Table = 'Table'\n}\n\nexport type UnsNode = {\n __typename?: 'UnsNode';\n apiDescription?: Maybe<Scalars['String']['output']>;\n apiEndpoint?: Maybe<Scalars['String']['output']>;\n apiMethod?: Maybe<Scalars['String']['output']>;\n attributeNeedsPersistance?: Maybe<Scalars['Boolean']['output']>;\n attributeTags?: Maybe<Array<Maybe<Scalars['String']['output']>>>;\n attributeTimestamp?: Maybe<Scalars['Timestamp']['output']>;\n attributeType?: Maybe<UnsAttributeType>;\n description?: Maybe<Scalars['String']['output']>;\n fullTopic?: Maybe<Scalars['String']['output']>;\n id?: Maybe<Scalars['Int']['output']>;\n parent?: Maybe<Scalars['Int']['output']>;\n processName?: Maybe<Scalars['String']['output']>;\n processVersion?: Maybe<Scalars['String']['output']>;\n type?: Maybe<UnsNodeType>;\n unsNode?: Maybe<Scalars['String']['output']>;\n};\n\nexport enum UnsNodeType {\n Attribute = 'Attribute',\n DynamicTopic = 'DynamicTopic',\n Topic = 'Topic'\n}\n\nexport type UpdateUnsNode = {\n apiDescription?: InputMaybe<Scalars['String']['input']>;\n apiEndpoint?: InputMaybe<Scalars['String']['input']>;\n apiMethod?: InputMaybe<Scalars['String']['input']>;\n attributeNeedsPersistance?: InputMaybe<Scalars['Boolean']['input']>;\n attributeTags?: InputMaybe<Array<InputMaybe<Scalars['String']['input']>>>;\n attributeTimestamp?: InputMaybe<Scalars['Timestamp']['input']>;\n attributeType?: InputMaybe<UnsAttributeType>;\n description?: InputMaybe<Scalars['String']['input']>;\n fullTopic?: InputMaybe<Scalars['String']['input']>;\n parent?: InputMaybe<Scalars['Int']['input']>;\n processName?: InputMaybe<Scalars['String']['input']>;\n processVersion?: InputMaybe<Scalars['String']['input']>;\n type?: InputMaybe<UnsNodeType>;\n unsNode?: InputMaybe<Scalars['String']['input']>;\n};\n\n\n\nexport type ResolverTypeWrapper<T> = Promise<T> | T;\n\n\nexport type ResolverWithResolve<TResult, TParent, TContext, TArgs> = {\n resolve: ResolverFn<TResult, TParent, TContext, TArgs>;\n};\nexport type Resolver<TResult, TParent = {}, TContext = {}, TArgs = {}> = ResolverFn<TResult, TParent, TContext, TArgs> | ResolverWithResolve<TResult, TParent, TContext, TArgs>;\n\nexport type ResolverFn<TResult, TParent, TContext, TArgs> = (\n parent: TParent,\n args: TArgs,\n context: TContext,\n info: GraphQLResolveInfo\n) => Promise<TResult> | TResult;\n\nexport type SubscriptionSubscribeFn<TResult, TParent, TContext, TArgs> = (\n parent: TParent,\n args: TArgs,\n context: TContext,\n info: GraphQLResolveInfo\n) => AsyncIterable<TResult> | Promise<AsyncIterable<TResult>>;\n\nexport type SubscriptionResolveFn<TResult, TParent, TContext, TArgs> = (\n parent: TParent,\n args: TArgs,\n context: TContext,\n info: GraphQLResolveInfo\n) => TResult | Promise<TResult>;\n\nexport interface SubscriptionSubscriberObject<TResult, TKey extends string, TParent, TContext, TArgs> {\n subscribe: SubscriptionSubscribeFn<{ [key in TKey]: TResult }, TParent, TContext, TArgs>;\n resolve?: SubscriptionResolveFn<TResult, { [key in TKey]: TResult }, TContext, TArgs>;\n}\n\nexport interface SubscriptionResolverObject<TResult, TParent, TContext, TArgs> {\n subscribe: SubscriptionSubscribeFn<any, TParent, TContext, TArgs>;\n resolve: SubscriptionResolveFn<TResult, any, TContext, TArgs>;\n}\n\nexport type SubscriptionObject<TResult, TKey extends string, TParent, TContext, TArgs> =\n | SubscriptionSubscriberObject<TResult, TKey, TParent, TContext, TArgs>\n | SubscriptionResolverObject<TResult, TParent, TContext, TArgs>;\n\nexport type SubscriptionResolver<TResult, TKey extends string, TParent = {}, TContext = {}, TArgs = {}> =\n | ((...args: any[]) => SubscriptionObject<TResult, TKey, TParent, TContext, TArgs>)\n | SubscriptionObject<TResult, TKey, TParent, TContext, TArgs>;\n\nexport type TypeResolveFn<TTypes, TParent = {}, TContext = {}> = (\n parent: TParent,\n context: TContext,\n info: GraphQLResolveInfo\n) => Maybe<TTypes> | Promise<Maybe<TTypes>>;\n\nexport type IsTypeOfResolverFn<T = {}, TContext = {}> = (obj: T, context: TContext, info: GraphQLResolveInfo) => boolean | Promise<boolean>;\n\nexport type NextResolverFn<T> = () => Promise<T>;\n\nexport type DirectiveResolverFn<TResult = {}, TParent = {}, TContext = {}, TArgs = {}> = (\n next: NextResolverFn<TResult>,\n parent: TParent,\n args: TArgs,\n context: TContext,\n info: GraphQLResolveInfo\n) => TResult | Promise<TResult>;\n\n\n\n/** Mapping between all available schema types and the resolvers types */\nexport type ResolversTypes = {\n Boolean: ResolverTypeWrapper<Scalars['Boolean']['output']>;\n Date: ResolverTypeWrapper<Scalars['Date']['output']>;\n InitUnsTopic: InitUnsTopic;\n InsertUnsNode: InsertUnsNode;\n Int: ResolverTypeWrapper<Scalars['Int']['output']>;\n Mutation: ResolverTypeWrapper<{}>;\n Query: ResolverTypeWrapper<{}>;\n Repository: ResolverTypeWrapper<Repository>;\n RttNode: ResolverTypeWrapper<RttNode>;\n String: ResolverTypeWrapper<Scalars['String']['output']>;\n Timestamp: ResolverTypeWrapper<Scalars['Timestamp']['output']>;\n TreeStructure: ResolverTypeWrapper<TreeStructure>;\n UnsAttributeType: UnsAttributeType;\n UnsNode: ResolverTypeWrapper<UnsNode>;\n UnsNodeType: UnsNodeType;\n UpdateUnsNode: UpdateUnsNode;\n};\n\n/** Mapping between all available schema types and the resolvers parents */\nexport type ResolversParentTypes = {\n Boolean: Scalars['Boolean']['output'];\n Date: Scalars['Date']['output'];\n InitUnsTopic: InitUnsTopic;\n InsertUnsNode: InsertUnsNode;\n Int: Scalars['Int']['output'];\n Mutation: {};\n Query: {};\n Repository: Repository;\n RttNode: RttNode;\n String: Scalars['String']['output'];\n Timestamp: Scalars['Timestamp']['output'];\n TreeStructure: TreeStructure;\n UnsNode: UnsNode;\n UpdateUnsNode: UpdateUnsNode;\n};\n\nexport interface DateScalarConfig extends GraphQLScalarTypeConfig<ResolversTypes['Date'], any> {\n name: 'Date';\n}\n\nexport type MutationResolvers<ContextType = any, ParentType extends ResolversParentTypes['Mutation'] = ResolversParentTypes['Mutation']> = {\n AddUnsNode?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType, Partial<MutationAddUnsNodeArgs>>;\n DeleteRttNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationDeleteRttNodeArgs>>;\n DeleteUnsNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationDeleteUnsNodeArgs>>;\n DeployRttNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationDeployRttNodeArgs>>;\n ModifyUnsNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationModifyUnsNodeArgs>>;\n PurgeOldNodes?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationPurgeOldNodesArgs>>;\n SetRttNodeConfig?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationSetRttNodeConfigArgs>>;\n StartRttNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationStartRttNodeArgs>>;\n StopRttNode?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType, Partial<MutationStopRttNodeArgs>>;\n};\n\nexport type QueryResolvers<ContextType = any, ParentType extends ResolversParentTypes['Query'] = ResolversParentTypes['Query']> = {\n GetRepositories?: Resolver<Maybe<Array<Maybe<ResolversTypes['Repository']>>>, ParentType, ContextType>;\n GetRttNodeConfig?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType, Partial<QueryGetRttNodeConfigArgs>>;\n GetRttNodes?: Resolver<Maybe<Array<Maybe<ResolversTypes['RttNode']>>>, ParentType, ContextType>;\n GetTags?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\n GetTreeStructure?: Resolver<Maybe<Array<Maybe<ResolversTypes['TreeStructure']>>>, ParentType, ContextType, Partial<QueryGetTreeStructureArgs>>;\n GetUnsNodes?: Resolver<Maybe<Array<Maybe<ResolversTypes['UnsNode']>>>, ParentType, ContextType>;\n};\n\nexport type RepositoryResolvers<ContextType = any, ParentType extends ResolversParentTypes['Repository'] = ResolversParentTypes['Repository']> = {\n name?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n tags?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\n __isTypeOf?: IsTypeOfResolverFn<ParentType, ContextType>;\n};\n\nexport type RttNodeResolvers<ContextType = any, ParentType extends ResolversParentTypes['RttNode'] = ResolversParentTypes['RttNode']> = {\n author?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n deployedVersions?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\n description?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n lastErrLog?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n lastLog?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n latestDeployedVersion?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n memory?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\n pid?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\n restarts?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\n rttNode?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n runningVersion?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n status?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n topics?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\n uptime?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\n version?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n __isTypeOf?: IsTypeOfResolverFn<ParentType, ContextType>;\n};\n\nexport interface TimestampScalarConfig extends GraphQLScalarTypeConfig<ResolversTypes['Timestamp'], any> {\n name: 'Timestamp';\n}\n\nexport type TreeStructureResolvers<ContextType = any, ParentType extends ResolversParentTypes['TreeStructure'] = ResolversParentTypes['TreeStructure']> = {\n apiDescription?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n apiEndpoint?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n apiMethod?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n attributeNeedsPersistance?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType>;\n attributeTags?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\n attributeTimestamp?: Resolver<Maybe<ResolversTypes['Timestamp']>, ParentType, ContextType>;\n attributeType?: Resolver<Maybe<ResolversTypes['UnsAttributeType']>, ParentType, ContextType>;\n children?: Resolver<Maybe<Array<Maybe<ResolversTypes['TreeStructure']>>>, ParentType, ContextType>;\n description?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n fullTopic?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n id?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\n parent?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\n processName?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n processVersion?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n type?: Resolver<Maybe<ResolversTypes['UnsNodeType']>, ParentType, ContextType>;\n unsNode?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n __isTypeOf?: IsTypeOfResolverFn<ParentType, ContextType>;\n};\n\nexport type UnsNodeResolvers<ContextType = any, ParentType extends ResolversParentTypes['UnsNode'] = ResolversParentTypes['UnsNode']> = {\n apiDescription?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n apiEndpoint?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n apiMethod?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n attributeNeedsPersistance?: Resolver<Maybe<ResolversTypes['Boolean']>, ParentType, ContextType>;\n attributeTags?: Resolver<Maybe<Array<Maybe<ResolversTypes['String']>>>, ParentType, ContextType>;\n attributeTimestamp?: Resolver<Maybe<ResolversTypes['Timestamp']>, ParentType, ContextType>;\n attributeType?: Resolver<Maybe<ResolversTypes['UnsAttributeType']>, ParentType, ContextType>;\n description?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n fullTopic?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n id?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\n parent?: Resolver<Maybe<ResolversTypes['Int']>, ParentType, ContextType>;\n processName?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n processVersion?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n type?: Resolver<Maybe<ResolversTypes['UnsNodeType']>, ParentType, ContextType>;\n unsNode?: Resolver<Maybe<ResolversTypes['String']>, ParentType, ContextType>;\n __isTypeOf?: IsTypeOfResolverFn<ParentType, ContextType>;\n};\n\nexport type Resolvers<ContextType = any> = {\n Date?: GraphQLScalarType;\n Mutation?: MutationResolvers<ContextType>;\n Query?: QueryResolvers<ContextType>;\n Repository?: RepositoryResolvers<ContextType>;\n RttNode?: RttNodeResolvers<ContextType>;\n Timestamp?: GraphQLScalarType;\n TreeStructure?: TreeStructureResolvers<ContextType>;\n UnsNode?: UnsNodeResolvers<ContextType>;\n};\n"]}
package/dist/index.d.ts CHANGED
@@ -1,8 +1,8 @@
1
- export { default as UnsProxyProcess } from "./uns/uns-proxy-process.js";
2
- export type { UnsProxyProcessPlugin, UnsProxyProcessPluginApi, UnsProxyProcessPluginMethod, UnsProxyProcessPluginMethods, } from "./uns/uns-proxy-process.js";
3
- export * from "./uns/uns-interfaces.js";
4
- export { ConfigFile } from "./config-file.js";
5
- export { default as logger } from "./logger.js";
6
- export { getLogger } from "./logger.js";
7
- export { resolveInfisicalConfig } from "./uns-config/secret-resolver.js";
1
+ export { default as UnsProxyProcess } from "./uns/uns-proxy-process.js";
2
+ export type { UnsProxyProcessPlugin, UnsProxyProcessPluginApi, UnsProxyProcessPluginMethod, UnsProxyProcessPluginMethods, } from "./uns/uns-proxy-process.js";
3
+ export * from "./uns/uns-interfaces.js";
4
+ export { ConfigFile } from "./config-file.js";
5
+ export { default as logger } from "./logger.js";
6
+ export { getLogger } from "./logger.js";
7
+ export { resolveInfisicalConfig } from "./uns-config/secret-resolver.js";
8
8
  //# sourceMappingURL=index.d.ts.map
package/dist/index.js CHANGED
@@ -1,7 +1,7 @@
1
- export { default as UnsProxyProcess } from "./uns/uns-proxy-process.js";
2
- export * from "./uns/uns-interfaces.js";
3
- export { ConfigFile } from "./config-file.js";
4
- export { default as logger } from "./logger.js";
5
- export { getLogger } from "./logger.js";
6
- export { resolveInfisicalConfig } from "./uns-config/secret-resolver.js";
1
+ export { default as UnsProxyProcess } from "./uns/uns-proxy-process.js";
2
+ export * from "./uns/uns-interfaces.js";
3
+ export { ConfigFile } from "./config-file.js";
4
+ export { default as logger } from "./logger.js";
5
+ export { getLogger } from "./logger.js";
6
+ export { resolveInfisicalConfig } from "./uns-config/secret-resolver.js";
7
7
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAOxE,cAAc,yBAAyB,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC","sourcesContent":["export { default as UnsProxyProcess } from \"./uns/uns-proxy-process.js\";\r\nexport type {\r\n UnsProxyProcessPlugin,\r\n UnsProxyProcessPluginApi,\r\n UnsProxyProcessPluginMethod,\r\n UnsProxyProcessPluginMethods,\r\n} from \"./uns/uns-proxy-process.js\";\r\nexport * from \"./uns/uns-interfaces.js\";\nexport { ConfigFile } from \"./config-file.js\";\nexport { default as logger } from \"./logger.js\";\nexport { getLogger } from \"./logger.js\";\nexport { resolveInfisicalConfig } from \"./uns-config/secret-resolver.js\";\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAOxE,cAAc,yBAAyB,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC","sourcesContent":["export { default as UnsProxyProcess } from \"./uns/uns-proxy-process.js\";\nexport type {\n UnsProxyProcessPlugin,\n UnsProxyProcessPluginApi,\n UnsProxyProcessPluginMethod,\n UnsProxyProcessPluginMethods,\n} from \"./uns/uns-proxy-process.js\";\nexport * from \"./uns/uns-interfaces.js\";\nexport { ConfigFile } from \"./config-file.js\";\nexport { default as logger } from \"./logger.js\";\nexport { getLogger } from \"./logger.js\";\nexport { resolveInfisicalConfig } from \"./uns-config/secret-resolver.js\";\n"]}
package/dist/logger.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- declare const logger: import("winston").Logger;
2
- export declare function getLogger(modulePath: string): import("winston").Logger;
3
- export default logger;
1
+ declare const logger: import("winston").Logger;
2
+ export declare function getLogger(modulePath: string): import("winston").Logger;
3
+ export default logger;
4
4
  //# sourceMappingURL=logger.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AA0DA,QAAA,MAAM,MAAM,0BAuBV,CAAC;AAEH,wBAAgB,SAAS,CAAC,UAAU,EAAE,MAAM,4BAY3C;AAED,eAAe,MAAM,CAAA"}
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AA4EA,QAAA,MAAM,MAAM,0BAiBV,CAAC;AAEH,wBAAgB,SAAS,CAAC,UAAU,EAAE,MAAM,4BAY3C;AAED,eAAe,MAAM,CAAA"}
package/dist/logger.js CHANGED
@@ -1,81 +1,89 @@
1
- import { createLogger, format, transports } from 'winston';
2
- import GelfTransport from 'winston-gelf';
3
- import os from 'os';
4
- import path from 'path';
5
- import fs from 'fs';
6
- import { fileURLToPath } from 'url';
7
- import { ConfigFile } from './config-file.js';
8
- function loadPackageMeta() {
9
- const packageJsonPaths = [
10
- path.join(process.cwd(), 'package.json'),
11
- path.resolve(path.dirname(fileURLToPath(import.meta.url)), '..', 'package.json')
12
- ];
13
- for (const packageJsonPath of packageJsonPaths) {
14
- try {
15
- const raw = fs.readFileSync(packageJsonPath, 'utf8');
16
- const packageMeta = JSON.parse(raw);
17
- if (packageMeta.name || packageMeta.version) {
18
- return packageMeta;
19
- }
20
- }
21
- catch {
22
- // Try the next candidate.
23
- }
24
- }
25
- return {};
26
- }
27
- function loadLoggingConfig() {
28
- try {
29
- return ConfigFile.loadRawConfig().logging;
30
- }
31
- catch {
32
- return undefined;
33
- }
34
- }
35
- const packageMeta = loadPackageMeta();
36
- const loggingConfig = loadLoggingConfig();
37
- const loggerTransports = [
38
- new transports.Console()
39
- ];
40
- if (loggingConfig) {
41
- loggerTransports.push(new GelfTransport({
42
- gelfPro: {
43
- adapterName: loggingConfig.adapter,
44
- adapterOptions: {
45
- host: loggingConfig.host,
46
- port: loggingConfig.port
47
- }
48
- }
49
- }));
50
- }
51
- const logger = createLogger({
52
- level: 'info', // Default logging level
53
- // 👇 Global fields for ALL transports (console + GELF)
54
- defaultMeta: {
55
- service: packageMeta.name ?? 'unknown-service',
56
- version: packageMeta.version ?? 'unknown',
57
- environment: process.env.NODE_ENV || 'unknown',
58
- hostname: os.hostname()
59
- },
60
- format: format.combine(format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), format.errors({ stack: true }), // Include stack trace
61
- format.splat(), format.json()),
62
- transports: loggerTransports,
63
- exceptionHandlers: [
64
- new transports.Console(), // Log exceptions to console
65
- // Remove exception logging to file
66
- // new transports.File({ filename: 'logs/exceptions.log' })
67
- ]
68
- });
69
- export function getLogger(modulePath) {
70
- const normalizedModulePath = modulePath.startsWith('file:')
71
- ? fileURLToPath(modulePath)
72
- : modulePath;
73
- const relativePath = path.relative(process.cwd(), normalizedModulePath);
74
- const withoutExt = relativePath.replace(/\.[^/.]+$/, '');
75
- const dotted = withoutExt.split(path.sep).join('.');
76
- return logger.child({
77
- facility: dotted
78
- });
79
- }
80
- export default logger;
1
+ import { createLogger, format, transports } from 'winston';
2
+ import GelfTransport from 'winston-gelf';
3
+ import os from 'os';
4
+ import path from 'path';
5
+ import fs from 'fs';
6
+ import { fileURLToPath } from 'url';
7
+ import { ConfigFile } from './config-file.js';
8
+ function loadPackageMeta() {
9
+ const packageJsonPaths = [
10
+ path.join(process.cwd(), 'package.json'),
11
+ path.resolve(path.dirname(fileURLToPath(import.meta.url)), '..', 'package.json')
12
+ ];
13
+ for (const packageJsonPath of packageJsonPaths) {
14
+ try {
15
+ const raw = fs.readFileSync(packageJsonPath, 'utf8');
16
+ const packageMeta = JSON.parse(raw);
17
+ if (packageMeta.name || packageMeta.version) {
18
+ return packageMeta;
19
+ }
20
+ }
21
+ catch {
22
+ // Try the next candidate.
23
+ }
24
+ }
25
+ return {};
26
+ }
27
+ function loadLoggingConfig() {
28
+ try {
29
+ return ConfigFile.loadRawConfig().logging;
30
+ }
31
+ catch {
32
+ return undefined;
33
+ }
34
+ }
35
+ const packageMeta = loadPackageMeta();
36
+ const loggingConfig = loadLoggingConfig();
37
+ const gelfMeta = {
38
+ service: packageMeta.name ?? 'unknown-service',
39
+ version: packageMeta.version ?? 'unknown',
40
+ environment: process.env.NODE_ENV || 'unknown',
41
+ hostname: os.hostname()
42
+ };
43
+ const consoleFormat = format.combine(format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), format.errors({ stack: true }), format.splat(), format.json());
44
+ const loggerTransports = [
45
+ new transports.Console({
46
+ format: consoleFormat
47
+ })
48
+ ];
49
+ if (loggingConfig) {
50
+ loggerTransports.push(new GelfTransport({
51
+ format: format((info) => ({
52
+ ...info,
53
+ ...gelfMeta
54
+ }))(),
55
+ gelfPro: {
56
+ adapterName: loggingConfig.adapter,
57
+ adapterOptions: {
58
+ host: loggingConfig.host,
59
+ port: loggingConfig.port
60
+ }
61
+ }
62
+ }));
63
+ }
64
+ const logger = createLogger({
65
+ level: 'info', // Default logging level
66
+ format: format.combine(format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), format.errors({ stack: true }), // Include stack trace
67
+ format.splat(), format.json()),
68
+ transports: loggerTransports,
69
+ exceptionHandlers: [
70
+ new transports.Console({
71
+ format: consoleFormat
72
+ }), // Log exceptions to console
73
+ // Remove exception logging to file
74
+ // new transports.File({ filename: 'logs/exceptions.log' })
75
+ ]
76
+ });
77
+ export function getLogger(modulePath) {
78
+ const normalizedModulePath = modulePath.startsWith('file:')
79
+ ? fileURLToPath(modulePath)
80
+ : modulePath;
81
+ const relativePath = path.relative(process.cwd(), normalizedModulePath);
82
+ const withoutExt = relativePath.replace(/\.[^/.]+$/, '');
83
+ const dotted = withoutExt.split(path.sep).join('.');
84
+ return logger.child({
85
+ facility: dotted
86
+ });
87
+ }
88
+ export default logger;
81
89
  //# sourceMappingURL=logger.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC3D,OAAO,aAAa,MAAM,cAAc,CAAA;AACxC,OAAO,EAAE,MAAM,IAAI,CAAA;AACnB,OAAO,IAAI,MAAM,MAAM,CAAA;AACvB,OAAO,EAAE,MAAM,IAAI,CAAA;AACnB,OAAO,EAAE,aAAa,EAAE,MAAM,KAAK,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAE7C,SAAS,eAAe;IACtB,MAAM,gBAAgB,GAAG;QACvB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,cAAc,CAAC;QACxC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,cAAc,CAAC;KACjF,CAAA;IAED,KAAK,MAAM,eAAe,IAAI,gBAAgB,EAAE,CAAC;QAC/C,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC,CAAA;YACpD,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAwC,CAAA;YAC1E,IAAI,WAAW,CAAC,IAAI,IAAI,WAAW,CAAC,OAAO,EAAE,CAAC;gBAC5C,OAAO,WAAW,CAAA;YACpB,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,0BAA0B;QAC5B,CAAC;IACH,CAAC;IAED,OAAO,EAAE,CAAA;AACX,CAAC;AAED,SAAS,iBAAiB;IACxB,IAAI,CAAC;QACH,OAAO,UAAU,CAAC,aAAa,EAAE,CAAC,OAAO,CAAA;IAC3C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,SAAS,CAAA;IAClB,CAAC;AACH,CAAC;AAED,MAAM,WAAW,GAAG,eAAe,EAAE,CAAA;AACrC,MAAM,aAAa,GAAG,iBAAiB,EAAE,CAAA;AAEzC,MAAM,gBAAgB,GAAG;IACvB,IAAI,UAAU,CAAC,OAAO,EAAE;CACzB,CAAA;AAED,IAAI,aAAa,EAAE,CAAC;IAClB,gBAAgB,CAAC,IAAI,CACnB,IAAI,aAAa,CAAC;QAChB,OAAO,EAAE;YACP,WAAW,EAAE,aAAa,CAAC,OAAO;YAClC,cAAc,EAAE;gBACd,IAAI,EAAE,aAAa,CAAC,IAAI;gBACxB,IAAI,EAAE,aAAa,CAAC,IAAI;aACzB;SACF;KACF,CAAC,CACH,CAAA;AACH,CAAC;AAED,MAAM,MAAM,GAAG,YAAY,CAAC;IAC1B,KAAK,EAAE,MAAM,EAAE,wBAAwB;IAErC,uDAAuD;IACzD,WAAW,EAAE;QACX,OAAO,EAAE,WAAW,CAAC,IAAI,IAAI,iBAAiB;QAC9C,OAAO,EAAE,WAAW,CAAC,OAAO,IAAI,SAAS;QACzC,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,IAAI,SAAS;QAC9C,QAAQ,EAAE,EAAE,CAAC,QAAQ,EAAE;KACxB;IAED,MAAM,EAAE,MAAM,CAAC,OAAO,CACpB,MAAM,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,qBAAqB,EAAE,CAAC,EACnD,MAAM,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EAAE,sBAAsB;IACtD,MAAM,CAAC,KAAK,EAAE,EACd,MAAM,CAAC,IAAI,EAAE,CACd;IACD,UAAU,EAAE,gBAAgB;IAC5B,iBAAiB,EAAE;QACjB,IAAI,UAAU,CAAC,OAAO,EAAE,EAAE,4BAA4B;QACtD,mCAAmC;QACnC,2DAA2D;KAC5D;CACF,CAAC,CAAC;AAEH,MAAM,UAAU,SAAS,CAAC,UAAkB;IAC1C,MAAM,oBAAoB,GAAG,UAAU,CAAC,UAAU,CAAC,OAAO,CAAC;QACzD,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC;QAC3B,CAAC,CAAC,UAAU,CAAA;IAEd,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,oBAAoB,CAAC,CAAA;IACvE,MAAM,UAAU,GAAG,YAAY,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAA;IACxD,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IAEnD,OAAO,MAAM,CAAC,KAAK,CAAC;QAClB,QAAQ,EAAE,MAAM;KACjB,CAAC,CAAA;AACJ,CAAC;AAED,eAAe,MAAM,CAAA","sourcesContent":["import { createLogger, format, transports } from 'winston';\nimport GelfTransport from 'winston-gelf'\nimport os from 'os'\nimport path from 'path'\nimport fs from 'fs'\nimport { fileURLToPath } from 'url';\nimport { ConfigFile } from './config-file.js'\n\nfunction loadPackageMeta(): { name?: string; version?: string } {\n const packageJsonPaths = [\n path.join(process.cwd(), 'package.json'),\n path.resolve(path.dirname(fileURLToPath(import.meta.url)), '..', 'package.json')\n ]\n\n for (const packageJsonPath of packageJsonPaths) {\n try {\n const raw = fs.readFileSync(packageJsonPath, 'utf8')\n const packageMeta = JSON.parse(raw) as { name?: string; version?: string }\n if (packageMeta.name || packageMeta.version) {\n return packageMeta\n }\n } catch {\n // Try the next candidate.\n }\n }\n\n return {}\n}\n\nfunction loadLoggingConfig() {\n try {\n return ConfigFile.loadRawConfig().logging\n } catch {\n return undefined\n }\n}\n\nconst packageMeta = loadPackageMeta()\nconst loggingConfig = loadLoggingConfig()\n\nconst loggerTransports = [\n new transports.Console()\n]\n\nif (loggingConfig) {\n loggerTransports.push(\n new GelfTransport({\n gelfPro: {\n adapterName: loggingConfig.adapter,\n adapterOptions: {\n host: loggingConfig.host,\n port: loggingConfig.port\n }\n }\n })\n )\n}\n\nconst logger = createLogger({\n level: 'info', // Default logging level\n\n // 👇 Global fields for ALL transports (console + GELF)\n defaultMeta: {\n service: packageMeta.name ?? 'unknown-service',\n version: packageMeta.version ?? 'unknown',\n environment: process.env.NODE_ENV || 'unknown',\n hostname: os.hostname()\n },\n\n format: format.combine(\n format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }),\n format.errors({ stack: true }), // Include stack trace\n format.splat(),\n format.json()\n ),\n transports: loggerTransports,\n exceptionHandlers: [\n new transports.Console(), // Log exceptions to console\n // Remove exception logging to file\n // new transports.File({ filename: 'logs/exceptions.log' })\n ]\n});\n\nexport function getLogger(modulePath: string) {\n const normalizedModulePath = modulePath.startsWith('file:')\n ? fileURLToPath(modulePath)\n : modulePath\n\n const relativePath = path.relative(process.cwd(), normalizedModulePath)\n const withoutExt = relativePath.replace(/\\.[^/.]+$/, '')\n const dotted = withoutExt.split(path.sep).join('.')\n\n return logger.child({\n facility: dotted\n })\n}\n\nexport default logger\n"]}
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { createLogger, format, transports } from 'winston';\nimport GelfTransport from 'winston-gelf'\nimport os from 'os'\nimport path from 'path'\nimport fs from 'fs'\nimport { fileURLToPath } from 'url';\nimport { ConfigFile } from './config-file.js'\n\nfunction loadPackageMeta(): { name?: string; version?: string } {\n const packageJsonPaths = [\n path.join(process.cwd(), 'package.json'),\n path.resolve(path.dirname(fileURLToPath(import.meta.url)), '..', 'package.json')\n ]\n\n for (const packageJsonPath of packageJsonPaths) {\n try {\n const raw = fs.readFileSync(packageJsonPath, 'utf8')\n const packageMeta = JSON.parse(raw) as { name?: string; version?: string }\n if (packageMeta.name || packageMeta.version) {\n return packageMeta\n }\n } catch {\n // Try the next candidate.\n }\n }\n\n return {}\n}\n\nfunction loadLoggingConfig() {\n try {\n return ConfigFile.loadRawConfig().logging\n } catch {\n return undefined\n }\n}\n\nconst packageMeta = loadPackageMeta()\nconst loggingConfig = loadLoggingConfig()\nconst gelfMeta = {\n service: packageMeta.name ?? 'unknown-service',\n version: packageMeta.version ?? 'unknown',\n environment: process.env.NODE_ENV || 'unknown',\n hostname: os.hostname()\n}\nconst consoleFormat = format.combine(\n format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }),\n format.errors({ stack: true }),\n format.splat(),\n format.json()\n)\n\nconst loggerTransports = [\n new transports.Console({\n format: consoleFormat\n })\n]\n\nif (loggingConfig) {\n loggerTransports.push(\n new GelfTransport({\n format: format((info) => ({\n ...info,\n ...gelfMeta\n }))(),\n gelfPro: {\n adapterName: loggingConfig.adapter,\n adapterOptions: {\n host: loggingConfig.host,\n port: loggingConfig.port\n }\n }\n })\n )\n}\n\nconst logger = createLogger({\n level: 'info', // Default logging level\n\n format: format.combine(\n format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }),\n format.errors({ stack: true }), // Include stack trace\n format.splat(),\n format.json()\n ),\n transports: loggerTransports,\n exceptionHandlers: [\n new transports.Console({\n format: consoleFormat\n }), // Log exceptions to console\n // Remove exception logging to file\n // new transports.File({ filename: 'logs/exceptions.log' })\n ]\n});\n\nexport function getLogger(modulePath: string) {\n const normalizedModulePath = modulePath.startsWith('file:')\n ? fileURLToPath(modulePath)\n : modulePath\n\n const relativePath = path.relative(process.cwd(), normalizedModulePath)\n const withoutExt = relativePath.replace(/\\.[^/.]+$/, '')\n const dotted = withoutExt.split(path.sep).join('.')\n\n return logger.child({\n facility: dotted\n })\n}\n\nexport default logger\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"auth-client.js","sourceRoot":"","sources":["../../../src/tools/auth/auth-client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConfigFile } from \"../../config-file.js\";\r\nimport { SecureStoreFactory, ISecureStore } from \"./secure-store.js\";\r\nimport jwt from \"jsonwebtoken\";\r\nimport readline from \"readline\";\r\n\r\nconst cfg = await ConfigFile.loadConfig();\r\n\r\ntype LoginResponse = {\r\n accessToken: string;\r\n};\r\n\r\n/**\r\n * AuthClient handles acquiring and refreshing JWT access tokens\r\n * using the configured REST base URL.\r\n */\r\nexport class AuthClient {\r\n private readonly restBase: string;\r\n private readonly namespace: string;\r\n private store!: ISecureStore;\r\n\r\n private constructor(restBase: string) {\r\n this.restBase = restBase.replace(/\\/$/, \"\");\r\n // namespace store by rest base to allow multiple environments\r\n this.namespace = `uns-auth:${this.restBase}`;\r\n }\r\n\r\n static async create(): Promise<AuthClient> {\r\n const restBase: string = cfg?.uns?.rest;\r\n if (!restBase) throw new Error(\"config.uns.rest is not set\");\r\n const client = new AuthClient(restBase);\r\n client.store = await SecureStoreFactory.create(client.namespace);\r\n return client;\r\n }\r\n\r\n async getAccessToken(): Promise<string> {\r\n const accessToken = await this.store.get(\"accessToken\");\r\n const refreshToken = await this.store.get(\"refreshToken\");\r\n\r\n if (accessToken && !AuthClient.isExpired(accessToken)) {\r\n return accessToken;\r\n }\r\n\r\n // Try refresh if we have refresh token\r\n if (refreshToken) {\r\n try {\r\n const refreshed = await this.refresh(refreshToken);\r\n await this.persistTokens(refreshed.accessToken, refreshed.refreshToken);\r\n return refreshed.accessToken;\r\n } catch {\r\n // ignore, fallback to login\r\n }\r\n }\r\n\r\n // First try to get email and password from config\r\n const configEmail = cfg?.uns?.email;\r\n const configPassword = cfg?.uns?.password;\r\n if (typeof configEmail === \"string\" && typeof configPassword === \"string\") {\r\n try {\r\n const loggedIn = await this.login(configEmail, configPassword);\r\n await this.persistTokens(loggedIn.accessToken, loggedIn.refreshToken);\r\n return loggedIn.accessToken;\r\n } catch {\r\n // ignore, fallback to interactive login\r\n }\r\n }\r\n\r\n // Interactive login\r\n const { email, password } = await AuthClient.promptCredentials();\r\n const loggedIn = await this.login(email, password);\r\n await this.persistTokens(loggedIn.accessToken, loggedIn.refreshToken);\r\n return loggedIn.accessToken;\r\n }\r\n\r\n private static isExpired(token: string, skewSeconds = 30): boolean {\r\n try {\r\n const decoded: any = jwt.decode(token);\r\n if (!decoded || typeof decoded !== \"object\" || !decoded.exp) return true;\r\n const now = Math.floor(Date.now() / 1000);\r\n return decoded.exp <= now + skewSeconds;\r\n } catch {\r\n return true;\r\n }\r\n }\r\n\r\n private static endpoint(base: string, tail: string): string {\r\n // base ends without trailing slash; tail must not start with slash\r\n const b = base.replace(/\\/$/, \"\");\r\n const t = tail.replace(/^\\//, \"\");\r\n return `${b}/${t}`;\r\n }\r\n\r\n private static async fetchWithTimeout(url: string, init: RequestInit = {}, timeoutMs = 10_000): Promise<Response> {\r\n const controller = new AbortController();\r\n const id = setTimeout(() => controller.abort(), timeoutMs);\r\n try {\r\n const resp = await fetch(url, { ...init, signal: controller.signal });\r\n return resp;\r\n } finally {\r\n clearTimeout(id);\r\n }\r\n }\r\n\r\n private static extractRefreshCookie(resp: Response): string | null {\r\n const anyHeaders: any = resp.headers as any;\r\n const getSetCookie = typeof anyHeaders.getSetCookie === \"function\" ? anyHeaders.getSetCookie.bind(anyHeaders) : null;\r\n const candidates: string[] = getSetCookie ? getSetCookie() : (resp.headers.get(\"set-cookie\") ? [resp.headers.get(\"set-cookie\") as string] : []);\r\n for (const header of candidates) {\r\n const match = header.match(/(?:^|;\\s*)RefreshToken=([^;]+)/i);\r\n if (match) return match[1];\r\n }\r\n return null;\r\n }\r\n\r\n private async login(email: string, password: string): Promise<{ accessToken: string; refreshToken: string; }> {\r\n const url = AuthClient.endpoint(this.restBase, \"auth/login\");\r\n const resp = await AuthClient.fetchWithTimeout(url, {\r\n method: \"POST\",\r\n headers: { \"Content-Type\": \"application/json\" },\r\n body: JSON.stringify({ email, password }),\r\n }, 12_000);\r\n\r\n if (!resp.ok) {\r\n throw new Error(`Login failed: ${resp.status} ${resp.statusText}`);\r\n }\r\n const data = (await resp.json()) as LoginResponse;\r\n const refreshToken = AuthClient.extractRefreshCookie(resp);\r\n if (!data?.accessToken || !refreshToken) {\r\n throw new Error(\"Login response missing tokens\");\r\n }\r\n return { accessToken: data.accessToken, refreshToken };\r\n }\r\n\r\n private async refresh(refreshToken: string): Promise<{ accessToken: string; refreshToken: string; }> {\r\n const url = AuthClient.endpoint(this.restBase, \"auth/refresh\");\r\n const resp = await AuthClient.fetchWithTimeout(url, {\r\n method: \"POST\",\r\n headers: {\r\n // server expects cookie RefreshToken\r\n \"Cookie\": `RefreshToken=${refreshToken}`,\r\n },\r\n }, 8_000);\r\n\r\n if (!resp.ok) {\r\n throw new Error(`Refresh failed: ${resp.status} ${resp.statusText}`);\r\n }\r\n const data = (await resp.json()) as LoginResponse;\r\n const newRefreshToken = AuthClient.extractRefreshCookie(resp) || refreshToken;\r\n if (!data?.accessToken) throw new Error(\"Refresh response missing accessToken\");\r\n return { accessToken: data.accessToken, refreshToken: newRefreshToken };\r\n }\r\n\r\n private async persistTokens(accessToken: string, refreshToken: string): Promise<void> {\r\n await this.store.set(\"accessToken\", accessToken);\r\n await this.store.set(\"refreshToken\", refreshToken);\r\n }\r\n\r\n static async promptCredentials(): Promise<{ email: string; password: string }> {\r\n const rl = readline.createInterface({ input: process.stdin, output: process.stdout, terminal: true });\r\n\r\n const ask = (q: string) => new Promise<string>((resolve) => rl.question(q, (ans) => resolve(ans.trim())));\r\n\r\n const askMasked = (q: string) => new Promise<string>((resolve) => {\r\n const anyRl = rl as any;\r\n const out: any = anyRl.output || process.stdout;\r\n const origWrite = (anyRl._writeToOutput as ((str: string) => void))?.bind(rl) || ((s: string) => out.write(s));\r\n anyRl.stdoutMuted = true;\r\n anyRl._writeToOutput = function (stringToWrite: string) {\r\n // Keep prompt text intact; mask user input\r\n if (anyRl.stdoutMuted) {\r\n if (stringToWrite.startsWith(q)) {\r\n out.write(stringToWrite);\r\n } else if (stringToWrite.endsWith(\"\\n\")) {\r\n out.write(\"\\n\");\r\n } else {\r\n out.write(\"*\");\r\n }\r\n } else {\r\n origWrite(stringToWrite);\r\n }\r\n };\r\n rl.question(q, (value) => {\r\n anyRl.stdoutMuted = false;\r\n anyRl._writeToOutput = origWrite;\r\n out.write(\"\\n\");\r\n resolve(value.trim());\r\n });\r\n });\r\n\r\n try {\r\n const email = await ask(\"Email: \");\r\n const password = await askMasked(\"Password: \");\r\n rl.close();\r\n return { email, password };\r\n } catch (e) {\r\n rl.close();\r\n throw e;\r\n }\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"auth-client.js","sourceRoot":"","sources":["../../../src/tools/auth/auth-client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConfigFile } from \"../../config-file.js\";\nimport { SecureStoreFactory, ISecureStore } from \"./secure-store.js\";\nimport jwt from \"jsonwebtoken\";\nimport readline from \"readline\";\n\nconst cfg = await ConfigFile.loadConfig();\n\ntype LoginResponse = {\n accessToken: string;\n};\n\n/**\n * AuthClient handles acquiring and refreshing JWT access tokens\n * using the configured REST base URL.\n */\nexport class AuthClient {\n private readonly restBase: string;\n private readonly namespace: string;\n private store!: ISecureStore;\n\n private constructor(restBase: string) {\n this.restBase = restBase.replace(/\\/$/, \"\");\n // namespace store by rest base to allow multiple environments\n this.namespace = `uns-auth:${this.restBase}`;\n }\n\n static async create(): Promise<AuthClient> {\n const restBase: string = cfg?.uns?.rest;\n if (!restBase) throw new Error(\"config.uns.rest is not set\");\n const client = new AuthClient(restBase);\n client.store = await SecureStoreFactory.create(client.namespace);\n return client;\n }\n\n async getAccessToken(): Promise<string> {\n const accessToken = await this.store.get(\"accessToken\");\n const refreshToken = await this.store.get(\"refreshToken\");\n\n if (accessToken && !AuthClient.isExpired(accessToken)) {\n return accessToken;\n }\n\n // Try refresh if we have refresh token\n if (refreshToken) {\n try {\n const refreshed = await this.refresh(refreshToken);\n await this.persistTokens(refreshed.accessToken, refreshed.refreshToken);\n return refreshed.accessToken;\n } catch {\n // ignore, fallback to login\n }\n }\n\n // First try to get email and password from config\n const configEmail = cfg?.uns?.email;\n const configPassword = cfg?.uns?.password;\n if (typeof configEmail === \"string\" && typeof configPassword === \"string\") {\n try {\n const loggedIn = await this.login(configEmail, configPassword);\n await this.persistTokens(loggedIn.accessToken, loggedIn.refreshToken);\n return loggedIn.accessToken;\n } catch {\n // ignore, fallback to interactive login\n }\n }\n\n // Interactive login\n const { email, password } = await AuthClient.promptCredentials();\n const loggedIn = await this.login(email, password);\n await this.persistTokens(loggedIn.accessToken, loggedIn.refreshToken);\n return loggedIn.accessToken;\n }\n\n private static isExpired(token: string, skewSeconds = 30): boolean {\n try {\n const decoded: any = jwt.decode(token);\n if (!decoded || typeof decoded !== \"object\" || !decoded.exp) return true;\n const now = Math.floor(Date.now() / 1000);\n return decoded.exp <= now + skewSeconds;\n } catch {\n return true;\n }\n }\n\n private static endpoint(base: string, tail: string): string {\n // base ends without trailing slash; tail must not start with slash\n const b = base.replace(/\\/$/, \"\");\n const t = tail.replace(/^\\//, \"\");\n return `${b}/${t}`;\n }\n\n private static async fetchWithTimeout(url: string, init: RequestInit = {}, timeoutMs = 10_000): Promise<Response> {\n const controller = new AbortController();\n const id = setTimeout(() => controller.abort(), timeoutMs);\n try {\n const resp = await fetch(url, { ...init, signal: controller.signal });\n return resp;\n } finally {\n clearTimeout(id);\n }\n }\n\n private static extractRefreshCookie(resp: Response): string | null {\n const anyHeaders: any = resp.headers as any;\n const getSetCookie = typeof anyHeaders.getSetCookie === \"function\" ? anyHeaders.getSetCookie.bind(anyHeaders) : null;\n const candidates: string[] = getSetCookie ? getSetCookie() : (resp.headers.get(\"set-cookie\") ? [resp.headers.get(\"set-cookie\") as string] : []);\n for (const header of candidates) {\n const match = header.match(/(?:^|;\\s*)RefreshToken=([^;]+)/i);\n if (match) return match[1];\n }\n return null;\n }\n\n private async login(email: string, password: string): Promise<{ accessToken: string; refreshToken: string; }> {\n const url = AuthClient.endpoint(this.restBase, \"auth/login\");\n const resp = await AuthClient.fetchWithTimeout(url, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ email, password }),\n }, 12_000);\n\n if (!resp.ok) {\n throw new Error(`Login failed: ${resp.status} ${resp.statusText}`);\n }\n const data = (await resp.json()) as LoginResponse;\n const refreshToken = AuthClient.extractRefreshCookie(resp);\n if (!data?.accessToken || !refreshToken) {\n throw new Error(\"Login response missing tokens\");\n }\n return { accessToken: data.accessToken, refreshToken };\n }\n\n private async refresh(refreshToken: string): Promise<{ accessToken: string; refreshToken: string; }> {\n const url = AuthClient.endpoint(this.restBase, \"auth/refresh\");\n const resp = await AuthClient.fetchWithTimeout(url, {\n method: \"POST\",\n headers: {\n // server expects cookie RefreshToken\n \"Cookie\": `RefreshToken=${refreshToken}`,\n },\n }, 8_000);\n\n if (!resp.ok) {\n throw new Error(`Refresh failed: ${resp.status} ${resp.statusText}`);\n }\n const data = (await resp.json()) as LoginResponse;\n const newRefreshToken = AuthClient.extractRefreshCookie(resp) || refreshToken;\n if (!data?.accessToken) throw new Error(\"Refresh response missing accessToken\");\n return { accessToken: data.accessToken, refreshToken: newRefreshToken };\n }\n\n private async persistTokens(accessToken: string, refreshToken: string): Promise<void> {\n await this.store.set(\"accessToken\", accessToken);\n await this.store.set(\"refreshToken\", refreshToken);\n }\n\n static async promptCredentials(): Promise<{ email: string; password: string }> {\n const rl = readline.createInterface({ input: process.stdin, output: process.stdout, terminal: true });\n\n const ask = (q: string) => new Promise<string>((resolve) => rl.question(q, (ans) => resolve(ans.trim())));\n\n const askMasked = (q: string) => new Promise<string>((resolve) => {\n const anyRl = rl as any;\n const out: any = anyRl.output || process.stdout;\n const origWrite = (anyRl._writeToOutput as ((str: string) => void))?.bind(rl) || ((s: string) => out.write(s));\n anyRl.stdoutMuted = true;\n anyRl._writeToOutput = function (stringToWrite: string) {\n // Keep prompt text intact; mask user input\n if (anyRl.stdoutMuted) {\n if (stringToWrite.startsWith(q)) {\n out.write(stringToWrite);\n } else if (stringToWrite.endsWith(\"\\n\")) {\n out.write(\"\\n\");\n } else {\n out.write(\"*\");\n }\n } else {\n origWrite(stringToWrite);\n }\n };\n rl.question(q, (value) => {\n anyRl.stdoutMuted = false;\n anyRl._writeToOutput = origWrite;\n out.write(\"\\n\");\n resolve(value.trim());\n });\n });\n\n try {\n const email = await ask(\"Email: \");\n const password = await askMasked(\"Password: \");\n rl.close();\n return { email, password };\n } catch (e) {\n rl.close();\n throw e;\n }\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tools/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC","sourcesContent":["export { AuthClient } from \"./auth-client.js\";\r\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tools/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC","sourcesContent":["export { AuthClient } from \"./auth-client.js\";\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"secure-store.js","sourceRoot":"","sources":["../../../src/tools/auth/secure-store.ts"],"names":[],"mappings":"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","sourcesContent":["import os from \"os\";\r\nimport path from \"path\";\r\nimport fs from \"fs\";\r\n\r\n/**\r\n * Abstraction over secure storage for tokens.\r\n *\r\n * Prefers OS keychain via `keytar` if available at runtime.\r\n * Falls back to a local file store with restricted permissions.\r\n */\r\nexport interface ISecureStore {\r\n get(key: string): Promise<string | null>;\r\n set(key: string, value: string): Promise<void>;\r\n del(key: string): Promise<void>;\r\n}\r\n\r\n/**\r\n * Try to lazily import keytar without making it a hard dependency.\r\n */\r\nasync function tryLoadKeytar(): Promise<any | null> {\r\n try {\r\n // Avoid static import to prevent type resolution errors when not installed\r\n const dynamicImport = new Function(\"m\", \"return import(m)\") as (m: string) => Promise<any>;\r\n const mod = await dynamicImport(\"keytar\");\r\n return (mod && (mod.default || mod)) ?? null;\r\n } catch {\r\n return null;\r\n }\r\n}\r\n\r\nclass KeytarStore implements ISecureStore {\r\n private service: string;\r\n private keytar: any;\r\n constructor(service: string, keytar: any) {\r\n this.service = service;\r\n this.keytar = keytar;\r\n }\r\n async get(key: string): Promise<string | null> {\r\n return (await this.keytar.getPassword(this.service, key)) ?? null;\r\n }\r\n async set(key: string, value: string): Promise<void> {\r\n await this.keytar.setPassword(this.service, key, value);\r\n }\r\n async del(key: string): Promise<void> {\r\n await this.keytar.deletePassword(this.service, key);\r\n }\r\n}\r\n\r\nclass FileStore implements ISecureStore {\r\n private filePath: string;\r\n\r\n constructor(namespace: string) {\r\n const baseDir = FileStore.resolveBaseDir();\r\n const folder = path.join(baseDir, \"uns-auth\");\r\n if (!fs.existsSync(folder)) {\r\n fs.mkdirSync(folder, { recursive: true, mode: 0o700 });\r\n }\r\n this.filePath = path.join(folder, `${FileStore.sanitize(namespace)}.json`);\r\n if (!fs.existsSync(this.filePath)) {\r\n fs.writeFileSync(this.filePath, \"{}\", { mode: 0o600 });\r\n }\r\n try {\r\n // tighten permissions if possible (no-op on Windows)\r\n fs.chmodSync(this.filePath, 0o600);\r\n } catch {\r\n // ignore\r\n }\r\n }\r\n\r\n private static resolveBaseDir(): string {\r\n if (process.platform === \"win32\") {\r\n return process.env.APPDATA || path.join(os.homedir(), \"AppData\", \"Roaming\");\r\n }\r\n // Linux and macOS default to XDG_CONFIG_HOME or ~/.config\r\n return process.env.XDG_CONFIG_HOME || path.join(os.homedir(), \".config\");\r\n }\r\n\r\n private static sanitize(name: string): string {\r\n return name.replace(/[^a-zA-Z0-9_.-]/g, \"_\");\r\n }\r\n\r\n private async load(): Promise<Record<string, string>> {\r\n try {\r\n const raw = await fs.promises.readFile(this.filePath, \"utf-8\");\r\n return JSON.parse(raw || \"{}\");\r\n } catch {\r\n return {};\r\n }\r\n }\r\n\r\n private async save(data: Record<string, string>): Promise<void> {\r\n const json = JSON.stringify(data, null, 2);\r\n await fs.promises.writeFile(this.filePath, json, { mode: 0o600 });\r\n try {\r\n fs.chmodSync(this.filePath, 0o600);\r\n } catch {\r\n // ignore\r\n }\r\n }\r\n\r\n async get(key: string): Promise<string | null> {\r\n const data = await this.load();\r\n return data[key] ?? null;\r\n }\r\n\r\n async set(key: string, value: string): Promise<void> {\r\n const data = await this.load();\r\n data[key] = value;\r\n await this.save(data);\r\n }\r\n\r\n async del(key: string): Promise<void> {\r\n const data = await this.load();\r\n delete data[key];\r\n await this.save(data);\r\n }\r\n}\r\n\r\nexport class SecureStoreFactory {\r\n /**\r\n * Creates a secure store for a namespace. Tries keytar first; falls back to file store.\r\n */\r\n static async create(namespace: string): Promise<ISecureStore> {\r\n const keytar = await tryLoadKeytar();\r\n if (keytar) {\r\n return new KeytarStore(namespace, keytar);\r\n }\r\n return new FileStore(namespace);\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"secure-store.js","sourceRoot":"","sources":["../../../src/tools/auth/secure-store.ts"],"names":[],"mappings":"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","sourcesContent":["import os from \"os\";\nimport path from \"path\";\nimport fs from \"fs\";\n\n/**\n * Abstraction over secure storage for tokens.\n *\n * Prefers OS keychain via `keytar` if available at runtime.\n * Falls back to a local file store with restricted permissions.\n */\nexport interface ISecureStore {\n get(key: string): Promise<string | null>;\n set(key: string, value: string): Promise<void>;\n del(key: string): Promise<void>;\n}\n\n/**\n * Try to lazily import keytar without making it a hard dependency.\n */\nasync function tryLoadKeytar(): Promise<any | null> {\n try {\n // Avoid static import to prevent type resolution errors when not installed\n const dynamicImport = new Function(\"m\", \"return import(m)\") as (m: string) => Promise<any>;\n const mod = await dynamicImport(\"keytar\");\n return (mod && (mod.default || mod)) ?? null;\n } catch {\n return null;\n }\n}\n\nclass KeytarStore implements ISecureStore {\n private service: string;\n private keytar: any;\n constructor(service: string, keytar: any) {\n this.service = service;\n this.keytar = keytar;\n }\n async get(key: string): Promise<string | null> {\n return (await this.keytar.getPassword(this.service, key)) ?? null;\n }\n async set(key: string, value: string): Promise<void> {\n await this.keytar.setPassword(this.service, key, value);\n }\n async del(key: string): Promise<void> {\n await this.keytar.deletePassword(this.service, key);\n }\n}\n\nclass FileStore implements ISecureStore {\n private filePath: string;\n\n constructor(namespace: string) {\n const baseDir = FileStore.resolveBaseDir();\n const folder = path.join(baseDir, \"uns-auth\");\n if (!fs.existsSync(folder)) {\n fs.mkdirSync(folder, { recursive: true, mode: 0o700 });\n }\n this.filePath = path.join(folder, `${FileStore.sanitize(namespace)}.json`);\n if (!fs.existsSync(this.filePath)) {\n fs.writeFileSync(this.filePath, \"{}\", { mode: 0o600 });\n }\n try {\n // tighten permissions if possible (no-op on Windows)\n fs.chmodSync(this.filePath, 0o600);\n } catch {\n // ignore\n }\n }\n\n private static resolveBaseDir(): string {\n if (process.platform === \"win32\") {\n return process.env.APPDATA || path.join(os.homedir(), \"AppData\", \"Roaming\");\n }\n // Linux and macOS default to XDG_CONFIG_HOME or ~/.config\n return process.env.XDG_CONFIG_HOME || path.join(os.homedir(), \".config\");\n }\n\n private static sanitize(name: string): string {\n return name.replace(/[^a-zA-Z0-9_.-]/g, \"_\");\n }\n\n private async load(): Promise<Record<string, string>> {\n try {\n const raw = await fs.promises.readFile(this.filePath, \"utf-8\");\n return JSON.parse(raw || \"{}\");\n } catch {\n return {};\n }\n }\n\n private async save(data: Record<string, string>): Promise<void> {\n const json = JSON.stringify(data, null, 2);\n await fs.promises.writeFile(this.filePath, json, { mode: 0o600 });\n try {\n fs.chmodSync(this.filePath, 0o600);\n } catch {\n // ignore\n }\n }\n\n async get(key: string): Promise<string | null> {\n const data = await this.load();\n return data[key] ?? null;\n }\n\n async set(key: string, value: string): Promise<void> {\n const data = await this.load();\n data[key] = value;\n await this.save(data);\n }\n\n async del(key: string): Promise<void> {\n const data = await this.load();\n delete data[key];\n await this.save(data);\n }\n}\n\nexport class SecureStoreFactory {\n /**\n * Creates a secure store for a namespace. Tries keytar first; falls back to file store.\n */\n static async create(namespace: string): Promise<ISecureStore> {\n const keytar = await tryLoadKeytar();\n if (keytar) {\n return new KeytarStore(namespace, keytar);\n }\n return new FileStore(namespace);\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"base-path.js","sourceRoot":"","sources":["../../src/tools/base-path.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAElD,MAAM,CAAC,MAAM,QAAQ,GAAG,eAAe,EAAE,CAAC","sourcesContent":["import { resolveBasePath } from \"../base-path.js\";\r\n\r\nexport const basePath = resolveBasePath();\r\n"]}
1
+ {"version":3,"file":"base-path.js","sourceRoot":"","sources":["../../src/tools/base-path.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAElD,MAAM,CAAC,MAAM,QAAQ,GAAG,eAAe,EAAE,CAAC","sourcesContent":["import { resolveBasePath } from \"../base-path.js\";\n\nexport const basePath = resolveBasePath();\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"file-utils.js","sourceRoot":"","sources":["../../src/tools/file-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,QAAgB;IACzD,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;IAE3D,IAAI,CAAC;QACH,OAAO,MAAM,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;IAC9C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAK,KAA+B,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YACvD,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,QAAgB,EAAE,OAAe;IAC5E,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;IAC3D,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC,YAAY,CAAC,CAAC;IAEzD,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;QACxB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC7D,MAAM,SAAS,CAAC,YAAY,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;IAC/C,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["import { mkdir, readFile, writeFile } from \"node:fs/promises\";\r\nimport path from \"node:path\";\r\n\r\nexport async function readTextFileIfExists(filePath: string): Promise<string | undefined> {\r\n const absolutePath = path.resolve(process.cwd(), filePath);\r\n\r\n try {\r\n return await readFile(absolutePath, \"utf8\");\r\n } catch (error) {\r\n if ((error as NodeJS.ErrnoException).code === \"ENOENT\") {\r\n return undefined;\r\n }\r\n throw error;\r\n }\r\n}\r\n\r\nexport async function writeTextFileIfChanged(filePath: string, content: string): Promise<boolean> {\r\n const absolutePath = path.resolve(process.cwd(), filePath);\r\n const current = await readTextFileIfExists(absolutePath);\r\n\r\n if (current === content) {\r\n return false;\r\n }\r\n\r\n await mkdir(path.dirname(absolutePath), { recursive: true });\r\n await writeFile(absolutePath, content, \"utf8\");\r\n return true;\r\n}\r\n"]}
1
+ {"version":3,"file":"file-utils.js","sourceRoot":"","sources":["../../src/tools/file-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,QAAgB;IACzD,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;IAE3D,IAAI,CAAC;QACH,OAAO,MAAM,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;IAC9C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAK,KAA+B,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YACvD,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,QAAgB,EAAE,OAAe;IAC5E,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;IAC3D,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC,YAAY,CAAC,CAAC;IAEzD,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;QACxB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC7D,MAAM,SAAS,CAAC,YAAY,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;IAC/C,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["import { mkdir, readFile, writeFile } from \"node:fs/promises\";\nimport path from \"node:path\";\n\nexport async function readTextFileIfExists(filePath: string): Promise<string | undefined> {\n const absolutePath = path.resolve(process.cwd(), filePath);\n\n try {\n return await readFile(absolutePath, \"utf8\");\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code === \"ENOENT\") {\n return undefined;\n }\n throw error;\n }\n}\n\nexport async function writeTextFileIfChanged(filePath: string, content: string): Promise<boolean> {\n const absolutePath = path.resolve(process.cwd(), filePath);\n const current = await readTextFileIfExists(absolutePath);\n\n if (current === content) {\n return false;\n }\n\n await mkdir(path.dirname(absolutePath), { recursive: true });\n await writeFile(absolutePath, content, \"utf8\");\n return true;\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"generate-config-schema.js","sourceRoot":"","sources":["../../src/tools/generate-config-schema.ts"],"names":[],"mappings":"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","sourcesContent":["import fs from \"node:fs\";\r\nimport path from \"node:path\";\r\nimport { pathToFileURL } from \"node:url\";\r\nimport { zodToJsonSchema } from \"zod-to-json-schema\";\r\nimport { zodToTs, printNode, withGetType } from \"zod-to-ts\";\r\nimport { z } from \"zod\";\r\n\r\nimport { hostValueSchema } from \"../uns-config/host-placeholders.js\";\r\nimport { secretValueSchema } from \"../uns-config/secret-placeholders.js\";\r\nimport { composeConfigSchema } from \"../uns-config/schema-tools.js\";\r\n\r\nfunction write(filePath: string, data: string) {\r\n fs.mkdirSync(path.dirname(filePath), { recursive: true });\r\n fs.writeFileSync(filePath, data);\r\n}\r\n\r\nlet tsLoaderReady = false;\r\n\r\nasync function ensureTsLoader(): Promise<void> {\r\n if (tsLoaderReady) {\r\n return;\r\n }\r\n tsLoaderReady = true;\r\n try {\r\n await import(\"tsx/esm\");\r\n } catch (error) {\r\n throw new Error(\r\n \"Unable to load TypeScript project.config.extension. Install 'tsx' (e.g. pnpm add -D tsx) or provide a compiled JavaScript file.\",\r\n );\r\n }\r\n}\r\n\r\nasync function loadProjectExtrasSchema(): Promise<z.AnyZodObject> {\r\n const base = path.resolve(process.cwd(), \"src/config/project.config.extension\");\r\n const extensions = [\"\", \".ts\", \".mts\", \".tsx\", \".js\", \".mjs\", \".cjs\"];\r\n\r\n for (const ext of extensions) {\r\n const candidate = ext ? `${base}${ext}` : base;\r\n if (!fs.existsSync(candidate)) {\r\n continue;\r\n }\r\n\r\n const lowerExt = path.extname(candidate).toLowerCase();\r\n try {\r\n if (lowerExt === \".ts\" || lowerExt === \".mts\" || lowerExt === \".tsx\") {\r\n await ensureTsLoader();\r\n }\r\n\r\n const module = await import(pathToFileURL(candidate).href);\r\n if (module?.projectExtrasSchema) {\r\n return module.projectExtrasSchema as z.AnyZodObject;\r\n }\r\n\r\n throw new Error(`Module '${candidate}' does not export projectExtrasSchema.`);\r\n } catch (error) {\r\n const reason = error instanceof Error ? error.message : String(error);\r\n throw new Error(`Failed to load project config extension at '${candidate}': ${reason}`);\r\n }\r\n }\r\n\r\n const coreModule = await import(\"../config/project.config.extension.js\");\r\n return coreModule.projectExtrasSchema as z.AnyZodObject;\r\n}\r\n\r\n// Keep placeholder-backed values as plain strings in the generated TypeScript typings so\r\n// consuming code reflects the resolved shapes while the JSON schema still exposes full unions.\r\nconst renderAsString = (typescript: any) =>\r\n typescript.factory.createKeywordTypeNode(typescript.SyntaxKind.StringKeyword);\r\n\r\nfor (const schema of [hostValueSchema, secretValueSchema]) {\r\n withGetType(schema, renderAsString);\r\n}\r\n\r\nconst { unsCoreSchema } = await import(\"../uns-config/uns-core-schema.js\");\r\nconst projectExtrasSchema = await loadProjectExtrasSchema();\r\nconst baseSchema = composeConfigSchema(unsCoreSchema, projectExtrasSchema).strict();\r\n\r\n// 1) JSON Schema for VS Code $schema\r\nconst jsonSchema = zodToJsonSchema(baseSchema, \"AppConfig\");\r\nwrite(path.resolve(\"config.schema.json\"), JSON.stringify(jsonSchema, null, 2));\r\n\r\n// 2) TypeScript `export type AppConfig = {...}`\r\nconst { node } = zodToTs(baseSchema, \"AppConfig\");\r\nconst interfaceBody = printNode(node);\r\n\r\nlet shouldAugment = true;\r\ntry {\r\n const pkgJsonPath = path.resolve(process.cwd(), \"package.json\");\r\n if (fs.existsSync(pkgJsonPath)) {\r\n const pkg = JSON.parse(fs.readFileSync(pkgJsonPath, \"utf8\"));\r\n if (pkg?.name === \"@uns-kit/core\") {\r\n shouldAugment = false;\r\n }\r\n }\r\n} catch {\r\n shouldAugment = true;\r\n}\r\n\r\nconst augmentationBlock = shouldAugment\r\n ? `\\n\\ntype GeneratedProjectAppConfig = ProjectAppConfig;\\ntype GeneratedAppConfig = AppConfig;\\n\\ndeclare module \"@uns-kit/core/config/app-config.js\" {\\n interface ProjectAppConfig extends GeneratedProjectAppConfig {}\\n interface AppConfig extends GeneratedAppConfig {}\\n}\\n`\r\n : \"\\n\";\r\n\r\nconst tsContent = `/* Auto-generated. Do not edit by hand. */\\nexport interface ProjectAppConfig ${interfaceBody}\\n\\nexport interface AppConfig extends ProjectAppConfig {}${augmentationBlock}`;\r\n\r\nwrite(path.resolve(\"./src/config/app-config.ts\"), tsContent);\r\n\r\nconsole.log(\"Generated config.schema.json and updated src/config/app-config.ts\");\r\n"]}
1
+ {"version":3,"file":"generate-config-schema.js","sourceRoot":"","sources":["../../src/tools/generate-config-schema.ts"],"names":[],"mappings":"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","sourcesContent":["import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { pathToFileURL } from \"node:url\";\nimport { zodToJsonSchema } from \"zod-to-json-schema\";\nimport { zodToTs, printNode, withGetType } from \"zod-to-ts\";\nimport { z } from \"zod\";\n\nimport { hostValueSchema } from \"../uns-config/host-placeholders.js\";\nimport { secretValueSchema } from \"../uns-config/secret-placeholders.js\";\nimport { composeConfigSchema } from \"../uns-config/schema-tools.js\";\n\nfunction write(filePath: string, data: string) {\n fs.mkdirSync(path.dirname(filePath), { recursive: true });\n fs.writeFileSync(filePath, data);\n}\n\nlet tsLoaderReady = false;\n\nasync function ensureTsLoader(): Promise<void> {\n if (tsLoaderReady) {\n return;\n }\n tsLoaderReady = true;\n try {\n await import(\"tsx/esm\");\n } catch (error) {\n throw new Error(\n \"Unable to load TypeScript project.config.extension. Install 'tsx' (e.g. pnpm add -D tsx) or provide a compiled JavaScript file.\",\n );\n }\n}\n\nasync function loadProjectExtrasSchema(): Promise<z.AnyZodObject> {\n const base = path.resolve(process.cwd(), \"src/config/project.config.extension\");\n const extensions = [\"\", \".ts\", \".mts\", \".tsx\", \".js\", \".mjs\", \".cjs\"];\n\n for (const ext of extensions) {\n const candidate = ext ? `${base}${ext}` : base;\n if (!fs.existsSync(candidate)) {\n continue;\n }\n\n const lowerExt = path.extname(candidate).toLowerCase();\n try {\n if (lowerExt === \".ts\" || lowerExt === \".mts\" || lowerExt === \".tsx\") {\n await ensureTsLoader();\n }\n\n const module = await import(pathToFileURL(candidate).href);\n if (module?.projectExtrasSchema) {\n return module.projectExtrasSchema as z.AnyZodObject;\n }\n\n throw new Error(`Module '${candidate}' does not export projectExtrasSchema.`);\n } catch (error) {\n const reason = error instanceof Error ? error.message : String(error);\n throw new Error(`Failed to load project config extension at '${candidate}': ${reason}`);\n }\n }\n\n const coreModule = await import(\"../config/project.config.extension.js\");\n return coreModule.projectExtrasSchema as z.AnyZodObject;\n}\n\n// Keep placeholder-backed values as plain strings in the generated TypeScript typings so\n// consuming code reflects the resolved shapes while the JSON schema still exposes full unions.\nconst renderAsString = (typescript: any) =>\n typescript.factory.createKeywordTypeNode(typescript.SyntaxKind.StringKeyword);\n\nfor (const schema of [hostValueSchema, secretValueSchema]) {\n withGetType(schema, renderAsString);\n}\n\nconst { unsCoreSchema } = await import(\"../uns-config/uns-core-schema.js\");\nconst projectExtrasSchema = await loadProjectExtrasSchema();\nconst baseSchema = composeConfigSchema(unsCoreSchema, projectExtrasSchema).strict();\n\n// 1) JSON Schema for VS Code $schema\nconst jsonSchema = zodToJsonSchema(baseSchema, \"AppConfig\");\nwrite(path.resolve(\"config.schema.json\"), JSON.stringify(jsonSchema, null, 2));\n\n// 2) TypeScript `export type AppConfig = {...}`\nconst { node } = zodToTs(baseSchema, \"AppConfig\");\nconst interfaceBody = printNode(node);\n\nlet shouldAugment = true;\ntry {\n const pkgJsonPath = path.resolve(process.cwd(), \"package.json\");\n if (fs.existsSync(pkgJsonPath)) {\n const pkg = JSON.parse(fs.readFileSync(pkgJsonPath, \"utf8\"));\n if (pkg?.name === \"@uns-kit/core\") {\n shouldAugment = false;\n }\n }\n} catch {\n shouldAugment = true;\n}\n\nconst augmentationBlock = shouldAugment\n ? `\\n\\ntype GeneratedProjectAppConfig = ProjectAppConfig;\\ntype GeneratedAppConfig = AppConfig;\\n\\ndeclare module \"@uns-kit/core/config/app-config.js\" {\\n interface ProjectAppConfig extends GeneratedProjectAppConfig {}\\n interface AppConfig extends GeneratedAppConfig {}\\n}\\n`\n : \"\\n\";\n\nconst tsContent = `/* Auto-generated. Do not edit by hand. */\\nexport interface ProjectAppConfig ${interfaceBody}\\n\\nexport interface AppConfig extends ProjectAppConfig {}${augmentationBlock}`;\n\nwrite(path.resolve(\"./src/config/app-config.ts\"), tsContent);\n\nconsole.log(\"Generated config.schema.json and updated src/config/app-config.ts\");\n"]}
@@ -53,13 +53,13 @@ function parseArgs(argv) {
53
53
  return { input, output, lang };
54
54
  }
55
55
  function printHelp() {
56
- console.log(`Usage: tsx packages/uns-core/src/tools/generate-uns-dictionary.ts [options]
57
-
58
- Options:
59
- --input <file> Path to uns-dictionary.json (default: ${DEFAULT_INPUT})
60
- --output <file> Path to generated TS file (default: src/uns/uns-dictionary.generated.ts)
61
- --lang <code> Preferred description language code (default: "sl")
62
- --help, -h Show this help
56
+ console.log(`Usage: tsx packages/uns-core/src/tools/generate-uns-dictionary.ts [options]
57
+
58
+ Options:
59
+ --input <file> Path to uns-dictionary.json (default: ${DEFAULT_INPUT})
60
+ --output <file> Path to generated TS file (default: src/uns/uns-dictionary.generated.ts)
61
+ --lang <code> Preferred description language code (default: "sl")
62
+ --help, -h Show this help
63
63
  `);
64
64
  }
65
65
  async function readDictionaryFromJson(filePath) {