PURISTA API / @purista/dapr-sdk
@purista/k8s-sdk
SDK and helper to run PURISTA services in Kubernetes.
Here is a full example, how the index file might look like, if you want to deploy a service to Kubernetes.
typescript
// src/index.ts
import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http'
import { SimpleSpanProcessor } from '@opentelemetry/sdk-trace-base'
import {
DefaultConfigStore,
DefaultEventBridge,
DefaultSecretStore,
DefaultStateStore,
gracefulShutdown,
initLogger,
} from '@purista/core'
import { getHttpServer } from '@purista/k8s-sdk'
import { theServiceV1Service } from './service/theService/v1/'
const main = async () => {
// create a logger
const logger = initLogger()
// optional: set up opentelemetry if you like to use it
const exporter = new OTLPTraceExporter({
url: `http://localhost:14268/api/traces`,
})
const spanProcessor = new SimpleSpanProcessor(exporter)
// optional: set up stores if they are needed for your service
const secretStore = new DefaultSecretStore({ logger })
const configStore = new DefaultConfigStore({ logger })
const stateStore = new DefaultStateStore({ logger })
// set up the eventbridge and start the event bridge
const eventBridge = new DefaultEventBridge({}, { spanProcessor })
await eventBridge.start()
// set up the service
const theService = await theServiceV1Service.getInstance(eventBridge, {
spanProcessor,
configStore,
secretStore,
stateStore,
})
await theService.start()
// create http server
const server = getHttpServer({
logger,
// check event bridge health if /healthz endpoint is called
healthFn: () => eventBridge.isHealthy(),
// optional: expose the commands if they are defined to have url endpoint
services: theService,
// optional: expose service endpoints at [apiMountPath]/v[serviceVersion]/[path defined for command]
// defaults to /api
apiMountPath: '/api',
})
// register shut down methods
gracefulShutdown(logger, [
// start with the event bridge to no longer accept incoming messages
eventBridge,
// optional: shut down the service
theService,
// optional: shut down the secret store
secretStore,
// optional: shut down the config store
configStore,
// optional: shut down the state store
stateStore,
// stop the http server
server,
])
// start the http server
// defaults to port 8080
// optional: you can set the port in the optional parameter of this method
await server.start()
}
main()
Visit purista.dev
Follow on Twitter @purista_js
Join the Discord Chat
SDK and helper to run PURISTA services in Kubernetes.
This package provides the Dapr event bridge and adapters for secret, state and config stores provided by Dapr.
Here is a full example, how the index file might look like, if you want to deploy a service to Kubernetes.
Example
typescript
import { DaprConfigStore, DaprEventBridge, DaprSecretStore, DaprStateStore } from '@purista/dapr-sdk'
const eventBridge = new DaprEventBridge({
spanProcessor,
logger,
serve,
})
const secretStore = new DaprSecretStore({ logger, secretStoreName: 'local-secret-store' })
const stateStore = new DaprStateStore({ logger, stateStoreName: 'local-state-store' })
const configStore = new DaprConfigStore({ logger, configStoreName: 'local-config-store' })
// start the services ...
await eventBridge.start()
Enumerations
Classes
Type Aliases
- BulkSubscribeConfig
- BulkSubscribeOptions
- BulkSubscribeResponse
- BulkSubscribeResponseEntry
- DaprClientConfig
- DaprConfigStoreConfig
- DaprEventBridgeConfig
- DaprPubSubRouteType
- DaprPubSubRuleType
- DaprPubSubType
- DaprSecretStoreConfig
- DaprStateStoreConfig
- KeyValueType
- PubSubBulkPublishApiResponse
- PubSubBulkPublishEntry
- PubSubBulkPublishMessage
- PubSubBulkPublishResponse
- PubSubPublishOptions
- PubSubPublishResponseType
- PubSubSubscriptionOptionsType
- PubSubSubscriptionsType
- PubSubSubscriptionTopicRoutesType
- PubSubSubscriptionTopicRouteType
- PubSubSubscriptionTopicType
- PubSubSubscriptionType
- TypeDaprPubSubCallback