Documentation ¶
Overview ¶
Package blacksmith is the package to create applications on top of the Blacksmith framework.
Blacksmith is a cloud-native framework specifically designed for data engineering teams. It allows you to design, build, and deploy reliable data platforms in a consistent way. The goal of Blacksmith is to address as many pain points as possible engineering teams encounter while working on data solutions.
Any team that is building — or think about building — a complete data platform knows the tremendous amount of work needed to properly accomplish this mission. Think of Blacksmith as the central piece of your data engineering workflow, leading you to save months of customized and professional work.
A new application can be generated using the Blacksmith CLI:
$ blacksmith generate application --name <name> [--path <path>]
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type License ¶ added in v0.14.0
type License struct { // Key is the subscription license key. This information can also be set using // the environment variable `BLACKSMITH_LICENSE_KEY` Key string `json:"-"` // Token is the subscription license token. This information can also be set // using the environment variable `BLACKSMITH_LICENSE_TOKEN`. Token string `json:"-"` }
License holds the license details for using Blacksmith Enterprise Edition.
type Options ¶
type Options struct { // Logger allows you to use a logrus Logger across all Blacksmith adapters and // the application built on top of it. Logger *logrus.Logger `json:"-"` // Supervisor is the options passed to use the supervisor adapter. // The supervisor is optional. Supervisor *supervisor.Options `json:"supervisor"` // Wanderer is the options passed to use the wanderer adapter. // The wanderer is optional. Wanderer *wanderer.Options `json:"wanderer"` // Store is the options passed to use the store adapter. Store *store.Options `json:"store"` // PubSub is the options passed to use the pubsub adapter. // The pusub is optional. PubSub *pubsub.Options `json:"pubsub"` // Gateway is the options passed to use the gateway service. Gateway *service.Options `json:"gateway"` // Scheduler is the options passed to use the scheduler service. Scheduler *service.Options `json:"scheduler"` // Sources is a slice of options passed to create sources. Sources []*source.Options `json:"-"` // Destinations is a slice of options passed to create destinations. Destinations []*destination.Options `json:"-"` // License holds the license details for using Blacksmith Enterprise Edition. // This is not necessary for using the Standard Edition. License *License `json:"-"` }
Options is the options a user can pass to create a new application.
Directories ¶
Path | Synopsis |
---|---|
adapter
|
|
pubsub
Package pubsub provides the development kit for working with Publish / Subscribe mechanism between the gateway and scheduler services.
|
Package pubsub provides the development kit for working with Publish / Subscribe mechanism between the gateway and scheduler services. |
store
Package store provides the development kit for working with a database-as-a-queue, so the jobs queue can be persisted in a datastore.
|
Package store provides the development kit for working with a database-as-a-queue, so the jobs queue can be persisted in a datastore. |
supervisor
Package supervisor provides the development kit for running Blacksmith applications in a distributed environment.
|
Package supervisor provides the development kit for running Blacksmith applications in a distributed environment. |
wanderer
Package wanderer provides the development kit for working with database migrations.
|
Package wanderer provides the development kit for working with database migrations. |
Package flow is a middleman between sources and destinations.
|
Package flow is a middleman between sources and destinations. |
destination
Package destination provides the development kit for working with third-party services that will receive events from Blacksmith.
|
Package destination provides the development kit for working with third-party services that will receive events from Blacksmith. |
source
Package source provides the development kit for working with Blacksmith SDKs, cloud services, databases, or any kind of application able to send data or push notifications.
|
Package source provides the development kit for working with Blacksmith SDKs, cloud services, databases, or any kind of application able to send data or push notifications. |
helper
|
|
errors
Package errors provides the error interface used by the Blacksmith SDK and by the adapters.
|
Package errors provides the error interface used by the Blacksmith SDK and by the adapters. |
logger
Package logger contains tools such as defaults and hooks for working with logrus (github.com/sirupsen/logrus) correctly inside Blacksmith.
|
Package logger contains tools such as defaults and hooks for working with logrus (github.com/sirupsen/logrus) correctly inside Blacksmith. |
rest
Package rest provides utilities shared across the gateway and scheduler adapters to build REST APIs.
|
Package rest provides utilities shared across the gateway and scheduler adapters to build REST APIs. |
sqlike
Package sqlike provides a suite of utilities to work with SQL-like datastores.
|
Package sqlike provides a suite of utilities to work with SQL-like datastores. |
gateway
Package gateway provides the development kit for working with incoming events.
|
Package gateway provides the development kit for working with incoming events. |
scheduler
Package scheduler provides the development kit for working with a scheduler that receives events from the gateway and pubsub packages and, used in tandem with the store package, is in charge of the reliability of the event delivery to destinations.
|
Package scheduler provides the development kit for working with a scheduler that receives events from the gateway and pubsub packages and, used in tandem with the store package, is in charge of the reliability of the event delivery to destinations. |
Package version provides the version details of the Blacksmith SDK alongside the Go version used to compile the CLI and the application.
|
Package version provides the version details of the Blacksmith SDK alongside the Go version used to compile the CLI and the application. |