blacksmith

package module
v0.15.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 17, 2021 License: Apache-2.0 Imports: 8 Imported by: 0

README

Blacksmith

After a few years we decided to crystallize all of our data engineering best practices into a product, on top of which organizations can layer cloud-assisted data solutions.

Blacksmith is a programmable low-code ecosystem, offering a complete and consistent data engineering solution. It allows you to design, build, and deploy reliable data engineering platforms in a consistent way. The goal of Blacksmith is to address as many pain points as possible data engineering teams encounter.

Any team that is building — or think about building — a complete data engineering 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.

By leveraging Blacksmith, organizations benefit a single source of truth for all their data with a unique developer experience.

Powerful REST API (Enterprise Edition):

$ curl --request GET --url 'https://example.com/admin/api/store/jobs' \
  -d events.sources_in=cms \
  -d events.sources_in=crm \
  -d jobs.destinations_in=warehouse \
  -d jobs.actions_in=register \
  -d jobs.status_in=discarded \
  -d offset=0 -d limit=100

Built-in dashboard (Enterprise Edition): Blacksmith Dashboard

Product offerings

Blacksmith is not an open-source software. This repository only holds the public Go APIs, allowing organizations to build reliable data engineering solutions on top of Blacksmith using Go. Blacksmith itself is built and distributed in a Docker image.

Blacksmith is available in two Editions:

  • Blacksmith Standard Edition addresses the technical complexity of data engineering. It is and will always be free.

  • Blacksmith Enterprise Edition addresses the complexity of collaboration and governance across multi-team and multi-scope data solutions.

  • Compare Editions

Professional services

Along consulting and training, we provide different product offerings as well as different levels of support.

License

Repository licensed under the Apache License, Version 2.0.

By downloading, installing, and using Blacksmith, you agree to the Blacksmith Terms and Conditions.

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.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL