Skip to content

Commit

Permalink
Update to Platformatic v2
Browse files Browse the repository at this point in the history
Signed-off-by: Matteo Collina <[email protected]>
  • Loading branch information
mcollina committed Sep 24, 2024
1 parent 7bc8772 commit 92240a9
Show file tree
Hide file tree
Showing 8 changed files with 2,158 additions and 944 deletions.
38 changes: 19 additions & 19 deletions config.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,13 @@ export interface AiWarpConfig {
logger?:
| boolean
| {
level?: string;
level: (
| ("fatal" | "error" | "warn" | "info" | "debug" | "trace" | "silent")
| {
[k: string]: unknown;
}
) &
string;
transport?:
| {
target?: string;
Expand Down Expand Up @@ -61,6 +67,9 @@ export interface AiWarpConfig {
};
[k: string]: unknown;
};
loggerInstance?: {
[k: string]: unknown;
};
serializerOpts?: {
schema?: {
[k: string]: unknown;
Expand All @@ -80,7 +89,9 @@ export interface AiWarpConfig {
requestIdLogLabel?: string;
jsonShorthand?: boolean;
trustProxy?: boolean | string | string[] | number;
http2?: boolean;
https?: {
allowHTTP1?: boolean;
key:
| string
| {
Expand Down Expand Up @@ -149,11 +160,13 @@ export interface AiWarpConfig {
defaultMetrics?: {
enabled: boolean;
};
prefix?: string;
auth?: {
username: string;
password: string;
};
labels?: {
[k: string]: string;
};
};
telemetry?: OpenTelemetry;
watch?:
Expand All @@ -168,6 +181,7 @@ export interface AiWarpConfig {
| boolean
| string;
$schema?: string;
module?: string;
service?: {
openapi?:
| {
Expand Down Expand Up @@ -205,24 +219,10 @@ export interface AiWarpConfig {
path?: string;
schema?: string;
url?: string;
fullResponse?: boolean;
fullRequest?: boolean;
validateResponse?: boolean;
}[];
versions?: {
/**
* The path to the directory containing the versions mappers
*/
dir: string;
configs: {
version: string;
openapi?: {
prefix?: string;
path?: string;
};
plugins?: {
[k: string]: unknown;
};
}[];
};
module?: string;
showAiWarpHomepage?: boolean;
aiProvider:
| {
Expand Down
80 changes: 49 additions & 31 deletions index.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import { join } from 'node:path'
import { platformaticService, Stackable } from '@platformatic/service'
import type { FastifyInstance } from 'fastify'
import { app as platformaticService, Stackable, buildStackable as serviceBuildStackable } from '@platformatic/service'
import { ConfigManager } from '@platformatic/config'
import fastifyUser from 'fastify-user'
import fastifyPlugin from 'fastify-plugin'
import fastifyStatic from '@fastify/static'
Expand All @@ -11,44 +13,60 @@ import authPlugin from './plugins/auth.js'
import apiPlugin from './plugins/api.js'
import rateLimitPlugin from './plugins/rate-limiting.js'

const stackable: Stackable<AiWarpConfig> = async function (fastify, opts) {
const { config } = fastify.platformatic
await fastify.register(fastifyUser as any, config.auth)
await fastify.register(authPlugin, opts)

if (config.showAiWarpHomepage !== undefined && config.showAiWarpHomepage) {
await fastify.register(fastifyStatic, {
root: join(import.meta.dirname, 'static')
})
export interface AiWarpMixin {
platformatic: {
configManager: ConfigManager<AiWarpConfig>,
config: AiWarpConfig
}
}

await fastify.register(platformaticService, opts)
type AiGenerator = new () => Generator

await fastify.register(warpPlugin, opts) // needs to be registered here for fastify.ai to be decorated
const stackable: Stackable<AiWarpConfig, AiGenerator> = {
async app (app, opts) {
const fastify = app as unknown as FastifyInstance & AiWarpMixin
const { config } = fastify.platformatic
await fastify.register(fastifyUser as any, config.auth)
await fastify.register(authPlugin, opts)

await fastify.register(rateLimitPlugin, opts)
await fastify.register(apiPlugin, opts)
}
if (config.showAiWarpHomepage !== undefined && config.showAiWarpHomepage) {
await fastify.register(fastifyStatic, {
root: join(import.meta.dirname, 'static'),
wildcard: false
})
}

await fastify.register(platformaticService, opts)

stackable.configType = 'ai-warp-app'
stackable.schema = schema
stackable.Generator = Generator
stackable.configManagerConfig = {
schema,
envWhitelist: ['PORT', 'HOSTNAME'],
allowToWatch: ['.env'],
schemaOptions: {
useDefaults: true,
coerceTypes: true,
allErrors: true,
strict: false
await fastify.register(warpPlugin, opts) // needs to be registered here for fastify.ai to be decorated

await fastify.register(rateLimitPlugin, opts)
await fastify.register(apiPlugin, opts)
},
async transformConfig () {}
configType: 'ai-warp-app',
schema: schema,
Generator: Generator,

Check failure on line 48 in index.ts

View workflow job for this annotation

GitHub Actions / setup-node-modules

Type 'typeof AiWarpGenerator' is not assignable to type 'AiGenerator'.
configManagerConfig: {
schema,
envWhitelist: ['PORT', 'HOSTNAME'],
allowToWatch: ['.env'],
schemaOptions: {
useDefaults: true,
coerceTypes: true,
allErrors: true,
strict: false
},
async transformConfig () {}
}
}

// break Fastify encapsulation
// @ts-expect-error
stackable[Symbol.for('skip-override')] = true
stackable.app[Symbol.for('skip-override')] = true

function buildStackable (opts: { config: string }) {
return serviceBuildStackable(opts, stackable.app)
}

export default fastifyPlugin(stackable)
export { Generator, schema }
export default stackable
export { Generator, schema, buildStackable }
7 changes: 7 additions & 0 deletions lib/generator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,13 @@ interface PackageJson {
class AiWarpGenerator extends ServiceGenerator {
private _packageJson: PackageJson | null = null

constructor (opts) {

Check failure on line 19 in lib/generator.ts

View workflow job for this annotation

GitHub Actions / setup-node-modules

Parameter 'opts' implicitly has an 'any' type.
super({
...opts,
module: '@platformatic/ai-warp'
})
}

getDefaultConfig (): { [x: string]: BaseGenerator.JSONValue } {
const defaultBaseConfig = super.getDefaultConfig()
// eslint-disable-next-line @typescript-eslint/strict-boolean-expressions
Expand Down
2 changes: 1 addition & 1 deletion lib/schema.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ const pkgJson: any = JSON.parse(readFileSync(pkgJsonPath, 'utf8'))

const aiWarpSchema = {
...schema.schema,
$id: 'ai-warp',
$id: `https://schemas.platformatic.com/@platformatic/ai-warp/${pkgJson.version}.json`,
title: 'Ai Warp Config',
version: pkgJson.version,
properties: {
Expand Down
Loading

0 comments on commit 92240a9

Please sign in to comment.