cmd

package
v1.10.17 Latest Latest
Warning

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

Go to latest
Published: Oct 18, 2021 License: MIT Imports: 73 Imported by: 0

Documentation

Overview

Package cmd is the front-end interface for the application as a command-line utility.

KeyStoreAuthenticator

KeyStoreAuthenticator prompts the user for their password, which is used to unlock their keystore file to interact with the Ethereum blockchain. Since multiple keystore files can exist at the configured directory, the KeyStoreAuthenticator will try the password on all keystore files present.

Client

Client is how the application is invoked from the command line. When you run the binary, for example `./chainlink n`, client.RunNode is called to start the Chainlink core. Similarly, running `./chainlink j` returns information on all jobs in the node, and `./chainlink s` with another argument as a JobID gives information specific to that job.

Renderer

Renderer helps format and display data (based on the kind of data it is) to the command line.

Index

Constants

This section is empty.

Variables

View Source
var ErrNoCredentialFile = errors.New("no API user credential file was passed")
View Source
var (
	// ErrorNoAPICredentialsAvailable is returned when not run from a terminal
	// and no API credentials have been provided
	ErrorNoAPICredentialsAvailable = errors.New("API credentials must be supplied")
)

Functions

func AdvisoryLock added in v1.10.17

func AdvisoryLock(ctx context.Context, db *sql.DB, timeout time.Duration) (postgres.Locker, error)

Try to immediately acquire an advisory lock. The lock will be released on application stop.

func NewApp

func NewApp(client *Client) *cli.App

NewApp returns the command-line parser/function-router for the given client

Types

type APIInitializer

type APIInitializer interface {
	// Initialize creates a new user for API access, or does nothing if one exists.
	Initialize(orm sessions.ORM) (sessions.User, error)
}

APIInitializer is the interface used to create the API User credentials needed to access the API. Does nothing if API user already exists.

func NewFileAPIInitializer

func NewFileAPIInitializer(file string) APIInitializer

NewFileAPIInitializer creates a concrete instance of APIInitializer that pulls API user credentials from the passed file path.

func NewPromptingAPIInitializer

func NewPromptingAPIInitializer(prompter Prompter) APIInitializer

NewPromptingAPIInitializer creates a concrete instance of APIInitializer that uses the terminal to solicit credentials from the user.

type AppFactory

type AppFactory interface {
	NewApplication(config.GeneralConfig) (chainlink.Application, error)
}

AppFactory implements the NewApplication method.

type BridgePresenter added in v1.10.16

type BridgePresenter struct {
	presenters.BridgeResource
}

func (*BridgePresenter) FriendlyConfirmations added in v1.10.16

func (p *BridgePresenter) FriendlyConfirmations() string

FriendlyConfirmations converts the confirmations to a string

func (*BridgePresenter) RenderTable added in v1.10.16

func (p *BridgePresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type BridgePresenters added in v1.10.16

type BridgePresenters []BridgePresenter

func (BridgePresenters) RenderTable added in v1.10.16

func (ps BridgePresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type CSAKeyPresenter added in v1.10.16

type CSAKeyPresenter struct {
	JAID
	presenters.CSAKeyResource
}

func (*CSAKeyPresenter) RenderTable added in v1.10.16

func (p *CSAKeyPresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

func (*CSAKeyPresenter) ToRow added in v1.10.16

func (p *CSAKeyPresenter) ToRow() []string

type CSAKeyPresenters added in v1.10.16

type CSAKeyPresenters []CSAKeyPresenter

func (CSAKeyPresenters) RenderTable added in v1.10.16

func (ps CSAKeyPresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type ChainPresenter added in v1.10.17

type ChainPresenter struct {
	presenters.ChainResource
}

func (ChainPresenter) RenderTable added in v1.10.17

func (p ChainPresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer Just renders a single row

func (*ChainPresenter) ToRow added in v1.10.17

func (p *ChainPresenter) ToRow() []string

type ChainPresenters added in v1.10.17

type ChainPresenters []ChainPresenter

func (ChainPresenters) RenderTable added in v1.10.17

func (ps ChainPresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type ChainlinkAppFactory

type ChainlinkAppFactory struct{}

ChainlinkAppFactory is used to create a new Application.

func (ChainlinkAppFactory) NewApplication

NewApplication returns a new instance of the node with the given config.

type ChainlinkRunner

type ChainlinkRunner struct{}

ChainlinkRunner is used to run the node application.

func (ChainlinkRunner) Run

Run sets the log level based on config and starts the web router to listen for input and return data.

type ChangePasswordPrompter

type ChangePasswordPrompter interface {
	Prompt() (web.UpdatePasswordRequest, error)
}

ChangePasswordPrompter is an interface primarily used for DI to obtain a password change request from the User.

func NewChangePasswordPrompter

func NewChangePasswordPrompter() ChangePasswordPrompter

NewChangePasswordPrompter returns the production password change request prompter

type Client

type Client struct {
	Renderer
	Config                         config.GeneralConfig
	AppFactory                     AppFactory
	KeyStoreAuthenticator          TerminalKeyStoreAuthenticator
	FallbackAPIInitializer         APIInitializer
	Runner                         Runner
	HTTP                           HTTPClient
	CookieAuthenticator            CookieAuthenticator
	FileSessionRequestBuilder      SessionRequestBuilder
	PromptingSessionRequestBuilder SessionRequestBuilder
	ChangePasswordPrompter         ChangePasswordPrompter
	PasswordPrompter               PasswordPrompter
}

Client is the shell for the node, local commands and remote commands.

func (*Client) ChangePassword

func (cli *Client) ChangePassword(c *clipkg.Context) (err error)

ChangePassword prompts the user for the old password and a new one, then posts it to Chainlink to change the password.

func (*Client) ConfigureChain added in v1.10.17

func (cli *Client) ConfigureChain(c *cli.Context) (err error)

func (*Client) CreateBridge added in v1.10.16

func (cli *Client) CreateBridge(c *cli.Context) (err error)

CreateBridge adds a new bridge to the chainlink node

func (*Client) CreateCSAKey added in v1.10.16

func (cli *Client) CreateCSAKey(c *cli.Context) (err error)

CreateCSAKey creates a new CSA key

func (*Client) CreateChain added in v1.10.17

func (cli *Client) CreateChain(c *cli.Context) (err error)

CreateChain adds a new chain to the chainlink node

func (*Client) CreateETHKey added in v1.10.16

func (cli *Client) CreateETHKey(c *cli.Context) (err error)

CreateETHKey creates a new ethereum key with the same password as the one used to unlock the existing key.

func (*Client) CreateExternalInitiator

func (cli *Client) CreateExternalInitiator(c *clipkg.Context) (err error)

CreateExternalInitiator adds an external initiator

func (*Client) CreateJob added in v1.10.17

func (cli *Client) CreateJob(c *cli.Context) (err error)

CreateJob creates a job Valid input is a TOML string or a path to TOML file

func (*Client) CreateMigration added in v1.10.17

func (cli *Client) CreateMigration(c *clipkg.Context) error

CreateMigration displays the database migration status

func (*Client) CreateNode added in v1.10.17

func (cli *Client) CreateNode(c *cli.Context) (err error)

CreateNode adds a new node to the nodelink node

func (*Client) CreateOCRKeyBundle added in v1.10.16

func (cli *Client) CreateOCRKeyBundle(c *cli.Context) error

CreateOCRKeyBundle creates a key and inserts it into encrypted_ocr_key_bundles, protected by the password in the password file

func (*Client) CreateP2PKey added in v1.10.16

func (cli *Client) CreateP2PKey(c *cli.Context) (err error)

CreateP2PKey creates a new P2P key

func (*Client) CreateVRFKey added in v1.10.16

func (cli *Client) CreateVRFKey(c *cli.Context) error

CreateVRFKey creates a key in the VRF keystore, protected by the password in the vrf password file provided when starting the chainlink node.

func (*Client) DeleteETHKey added in v1.10.16

func (cli *Client) DeleteETHKey(c *cli.Context) (err error)

DeleteETHKey deletes an Ethereum key, address of key must be passed

func (*Client) DeleteExternalInitiator

func (cli *Client) DeleteExternalInitiator(c *clipkg.Context) (err error)

DeleteExternalInitiator removes an external initiator

func (*Client) DeleteJob added in v1.10.17

func (cli *Client) DeleteJob(c *cli.Context) error

DeleteJob deletes a job

func (*Client) DeleteOCRKeyBundle added in v1.10.16

func (cli *Client) DeleteOCRKeyBundle(c *cli.Context) error

DeleteOCRKeyBundle creates a key and inserts it into encrypted_ocr_keys, protected by the password in the password file

func (*Client) DeleteP2PKey added in v1.10.16

func (cli *Client) DeleteP2PKey(c *cli.Context) (err error)

DeleteP2PKey deletes a P2P key, key ID must be passed

func (*Client) DeleteUser

func (cli *Client) DeleteUser(c *clipkg.Context) (err error)

DeleteUser is run locally to remove the User row from the node's database.

func (*Client) DeleteVRFKey added in v1.10.16

func (cli *Client) DeleteVRFKey(c *cli.Context) error

DeleteVRFKey deletes (hard or soft) the VRF key with given public key from the db and memory. V2 jobs referencing the VRF key will be removed if the key is deleted (no such protection for the V1 jobs exists).

func (*Client) ExportETHKey added in v1.10.16

func (cli *Client) ExportETHKey(c *cli.Context) (err error)

ExportETHKey exports an ETH key, address must be passed

func (*Client) ExportOCRKey added in v1.10.16

func (cli *Client) ExportOCRKey(c *cli.Context) (err error)

ExportOCRKey exports OCR key bundles by ID ID of the key must be passed

func (*Client) ExportP2PKey added in v1.10.16

func (cli *Client) ExportP2PKey(c *cli.Context) (err error)

ExportP2PKey exports a P2P key, key ID must be passed

func (*Client) ExportVRFKey added in v1.10.16

func (cli *Client) ExportVRFKey(c *cli.Context) error

ExportVRFKey saves encrypted copy of VRF key with given public key to requested file path.

func (*Client) GetConfiguration added in v1.10.16

func (cli *Client) GetConfiguration(c *clipkg.Context) (err error)

GetConfiguration gets the nodes environment variables

func (*Client) ImportETHKey added in v1.10.16

func (cli *Client) ImportETHKey(c *cli.Context) (err error)

ImportETHKey imports an Ethereum key, file path must be passed

func (*Client) ImportOCRKey added in v1.10.16

func (cli *Client) ImportOCRKey(c *cli.Context) (err error)

ImportOCRKey imports OCR key bundle, file path must be passed

func (*Client) ImportP2PKey added in v1.10.16

func (cli *Client) ImportP2PKey(c *cli.Context) (err error)

ImportP2PKey imports and stores a P2P key, path to key must be passed

func (*Client) ImportVRFKey added in v1.10.16

func (cli *Client) ImportVRFKey(c *cli.Context) error

ImportVRFKey reads a file into an EncryptedVRFKey in the db

func (*Client) IndexBridges added in v1.10.16

func (cli *Client) IndexBridges(c *cli.Context) (err error)

IndexBridges returns all bridges.

func (*Client) IndexChains added in v1.10.17

func (cli *Client) IndexChains(c *cli.Context) (err error)

IndexChains returns all chains.

func (*Client) IndexExternalInitiators added in v1.10.16

func (cli *Client) IndexExternalInitiators(c *clipkg.Context) (err error)

IndexExternalInitiators lists external initiators

func (*Client) IndexNodes added in v1.10.17

func (cli *Client) IndexNodes(c *cli.Context) (err error)

IndexNodes returns all nodes.

func (*Client) IndexTransactions added in v1.10.16

func (cli *Client) IndexTransactions(c *cli.Context) error

IndexTransactions returns the list of transactions in descending order, taking an optional page parameter

func (*Client) IndexTxAttempts added in v1.10.16

func (cli *Client) IndexTxAttempts(c *cli.Context) error

IndexTxAttempts returns the list of transactions in descending order, taking an optional page parameter

func (*Client) ListCSAKeys added in v1.10.16

func (cli *Client) ListCSAKeys(c *cli.Context) (err error)

ListCSAKeys retrieves a list of all CSA keys

func (*Client) ListETHKeys added in v1.10.16

func (cli *Client) ListETHKeys(c *cli.Context) (err error)

ListETHKeys renders the active account address with its ETH & LINK balance

func (*Client) ListJobs added in v1.10.17

func (cli *Client) ListJobs(c *cli.Context) (err error)

ListJobs lists all jobs

func (*Client) ListOCRKeyBundles added in v1.10.16

func (cli *Client) ListOCRKeyBundles(c *cli.Context) error

ListOCRKeyBundles lists the available OCR Key Bundles

func (*Client) ListP2PKeys added in v1.10.16

func (cli *Client) ListP2PKeys(c *cli.Context) (err error)

ListP2PKeys retrieves a list of all P2P keys

func (*Client) ListVRFKeys added in v1.10.16

func (cli *Client) ListVRFKeys(c *cli.Context) error

ListKeys Lists the keys in the db

func (*Client) MigrateDatabase added in v1.10.16

func (cli *Client) MigrateDatabase(c *clipkg.Context) error

MigrateDatabase migrates the database

func (*Client) PrepareTestDatabase added in v1.10.16

func (cli *Client) PrepareTestDatabase(c *clipkg.Context) error

PrepareTestDatabase calls ResetDatabase then loads fixtures required for tests

func (*Client) RebroadcastTransactions added in v1.10.16

func (cli *Client) RebroadcastTransactions(c *clipkg.Context) (err error)

RebroadcastTransactions run locally to force manual rebroadcasting of transactions in a given nonce range.

func (*Client) RemoteLogin

func (cli *Client) RemoteLogin(c *clipkg.Context) error

RemoteLogin creates a cookie session to run remote commands.

func (*Client) RemoveBridge

func (cli *Client) RemoveBridge(c *cli.Context) (err error)

RemoveBridge removes a specific Bridge by name.

func (*Client) RemoveChain added in v1.10.17

func (cli *Client) RemoveChain(c *cli.Context) (err error)

RemoveChain removes a specific Chain by name.

func (*Client) RemoveNode added in v1.10.17

func (cli *Client) RemoveNode(c *cli.Context) (err error)

RemoveNode removes a specific Node by name.

func (*Client) ReplayFromBlock added in v1.10.16

func (cli *Client) ReplayFromBlock(c *clipkg.Context) (err error)

ReplayFromBlock replays chain data from the given block number until the most recent

func (*Client) ResetDatabase added in v1.10.16

func (cli *Client) ResetDatabase(c *clipkg.Context) error

ResetDatabase drops, creates and migrates the database specified by DATABASE_URL This is useful to setup the database for testing

func (*Client) RollbackDatabase added in v1.10.17

func (cli *Client) RollbackDatabase(c *clipkg.Context) error

VersionDatabase displays the current database version.

func (*Client) RunNode

func (cli *Client) RunNode(c *clipkg.Context) error

RunNode starts the Chainlink core.

func (*Client) SendEther

func (cli *Client) SendEther(c *cli.Context) (err error)

SendEther transfers ETH from the node's account to a specified address.

func (*Client) SetEvmGasPriceDefault added in v1.10.17

func (cli *Client) SetEvmGasPriceDefault(c *clipkg.Context) (err error)

SetEvmGasPriceDefault specifies the minimum gas price to use for outgoing transactions

func (*Client) SetLogLevel added in v1.10.16

func (cli *Client) SetLogLevel(c *clipkg.Context) (err error)

SetLogLevel sets the log level on the node

func (*Client) SetLogPkg added in v1.10.16

func (cli *Client) SetLogPkg(c *clipkg.Context) (err error)

SetLogPkg sets the package log filter on the node

func (*Client) SetLogSQL added in v1.10.16

func (cli *Client) SetLogSQL(c *clipkg.Context) (err error)

SetLogSQL enables or disables the log sql statemnts

func (*Client) SetNextNonce added in v1.10.16

func (cli *Client) SetNextNonce(c *clipkg.Context) error

SetNextNonce manually updates the keys.next_nonce field for the given key with the given nonce value

func (*Client) ShowBridge

func (cli *Client) ShowBridge(c *cli.Context) (err error)

ShowBridge returns the info for the given Bridge name.

func (*Client) ShowJob added in v1.10.17

func (cli *Client) ShowJob(c *cli.Context) (err error)

ShowJob displays the details of a job

func (*Client) ShowTransaction added in v1.10.16

func (cli *Client) ShowTransaction(c *cli.Context) (err error)

ShowTransaction returns the info for the given transaction hash

func (*Client) Status added in v1.10.16

func (cli *Client) Status(c *clipkg.Context) error

Status will display the health of various services

func (*Client) StatusDatabase added in v1.10.17

func (cli *Client) StatusDatabase(c *clipkg.Context) error

StatusDatabase displays the database migration status

func (*Client) TriggerPipelineRun added in v1.10.16

func (cli *Client) TriggerPipelineRun(c *cli.Context) error

TriggerPipelineRun triggers a job run based on a job ID

func (*Client) VersionDatabase added in v1.10.16

func (cli *Client) VersionDatabase(c *clipkg.Context) error

VersionDatabase displays the current database version.

type CookieAuthenticator

type CookieAuthenticator interface {
	Cookie() (*http.Cookie, error)
	Authenticate(sessions.SessionRequest) (*http.Cookie, error)
}

CookieAuthenticator is the interface to generating a cookie to authenticate future HTTP requests.

func NewSessionCookieAuthenticator

func NewSessionCookieAuthenticator(config SessionCookieAuthenticatorConfig, store CookieStore) CookieAuthenticator

NewSessionCookieAuthenticator creates a SessionCookieAuthenticator using the passed config and builder.

type CookieStore

type CookieStore interface {
	Save(cookie *http.Cookie) error
	Retrieve() (*http.Cookie, error)
}

CookieStore is a place to store and retrieve cookies.

type DiskCookieConfig added in v1.10.17

type DiskCookieConfig interface {
	RootDir() string
}

type DiskCookieStore

type DiskCookieStore struct {
	Config DiskCookieConfig
}

DiskCookieStore saves a single cookie in the local cli working directory.

func (DiskCookieStore) Retrieve

func (d DiskCookieStore) Retrieve() (*http.Cookie, error)

Retrieve returns any Saved cookies.

func (DiskCookieStore) Save

func (d DiskCookieStore) Save(cookie *http.Cookie) error

Save stores a cookie.

type EthKeyPresenter added in v1.10.16

type EthKeyPresenter struct {
	presenters.ETHKeyResource
}

func (*EthKeyPresenter) RenderTable added in v1.10.16

func (p *EthKeyPresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

func (*EthKeyPresenter) ToRow added in v1.10.16

func (p *EthKeyPresenter) ToRow() []string

type EthKeyPresenters added in v1.10.16

type EthKeyPresenters []EthKeyPresenter

func (EthKeyPresenters) RenderTable added in v1.10.16

func (ps EthKeyPresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type EthTxPresenter added in v1.10.16

type EthTxPresenter struct {
	JAID
	presenters.EthTxResource
}

func (*EthTxPresenter) RenderTable added in v1.10.16

func (p *EthTxPresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type EthTxPresenters added in v1.10.16

type EthTxPresenters []EthTxPresenter

func (EthTxPresenters) RenderTable added in v1.10.16

func (ps EthTxPresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type ExternalInitiatorPresenter added in v1.10.16

type ExternalInitiatorPresenter struct {
	JAID
	presenters.ExternalInitiatorResource
}

func (*ExternalInitiatorPresenter) RenderTable added in v1.10.16

func (eip *ExternalInitiatorPresenter) RenderTable(rt RendererTable) error

func (*ExternalInitiatorPresenter) ToRow added in v1.10.16

func (eip *ExternalInitiatorPresenter) ToRow() []string

type ExternalInitiatorPresenters added in v1.10.16

type ExternalInitiatorPresenters []ExternalInitiatorPresenter

func (*ExternalInitiatorPresenters) RenderTable added in v1.10.16

func (eips *ExternalInitiatorPresenters) RenderTable(rt RendererTable) error

type HTTPClient

type HTTPClient interface {
	Get(string, ...map[string]string) (*http.Response, error)
	Post(string, io.Reader) (*http.Response, error)
	Put(string, io.Reader) (*http.Response, error)
	Patch(string, io.Reader, ...map[string]string) (*http.Response, error)
	Delete(string) (*http.Response, error)
}

HTTPClient encapsulates all methods used to interact with a chainlink node API.

func NewAuthenticatedHTTPClient

func NewAuthenticatedHTTPClient(config HTTPClientConfig, cookieAuth CookieAuthenticator, sessionRequest sessions.SessionRequest) HTTPClient

NewAuthenticatedHTTPClient uses the CookieAuthenticator to generate a sessionID which is then used for all subsequent HTTP API requests.

type HTTPClientConfig added in v1.10.17

type HTTPClientConfig interface {
	SessionCookieAuthenticatorConfig
}

type HealthCheckPresenter added in v1.10.16

type HealthCheckPresenter struct {
	webPresenters.Check
}

func (*HealthCheckPresenter) ToRow added in v1.10.16

func (p *HealthCheckPresenter) ToRow() []string

type HealthCheckPresenters added in v1.10.16

type HealthCheckPresenters []HealthCheckPresenter

func (HealthCheckPresenters) RenderTable added in v1.10.16

func (ps HealthCheckPresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type JAID added in v1.10.16

type JAID struct {
	ID string `json:"id"`
}

JAID represents a JSON API ID.

It implements the api2go MarshalIdentifier and UnmarshalIdentitier interface.

When you embed a JSONAPI resource into a presenter, it will not render the ID into the JSON object when you perform a json.Marshal. Instead we use this to override the ID field of the resource with a JSON tag that will render.

Embed this into a Presenter to render the ID. For example

type JobPresenter struct {
	JAID
	presenters.JobResource
}

func NewJAID added in v1.10.16

func NewJAID(id string) JAID

func (JAID) GetID added in v1.10.16

func (jaid JAID) GetID() string

GetID implements the api2go MarshalIdentifier interface.

func (*JAID) SetID added in v1.10.16

func (jaid *JAID) SetID(value string) error

SetID implements the api2go UnmarshalIdentitier interface.

type JobPresenter added in v1.10.16

type JobPresenter struct {
	JAID // This is needed to render the id for a JSONAPI Resource as normal JSON
	presenters.JobResource
}

JobRenderer wraps the JSONAPI Job Resource and adds rendering functionality

func (JobPresenter) FriendlyCreatedAt added in v1.10.16

func (p JobPresenter) FriendlyCreatedAt() string

FriendlyCreatedAt returns the created at timestamp of the spec which matches the type in RFC3339 format.

func (JobPresenter) FriendlyTasks added in v1.10.16

func (p JobPresenter) FriendlyTasks() []string

FriendlyTasks returns the tasks

func (JobPresenter) GetTasks added in v1.10.16

func (p JobPresenter) GetTasks() ([]string, error)

GetTasks extracts the tasks from the dependency graph

func (*JobPresenter) RenderTable added in v1.10.16

func (p *JobPresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

func (JobPresenter) ToRows added in v1.10.16

func (p JobPresenter) ToRows() [][]string

ToRows returns the job as a multiple rows per task

type JobPresenters added in v1.10.16

type JobPresenters []JobPresenter

func (JobPresenters) RenderTable added in v1.10.16

func (ps JobPresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type MemoryCookieStore

type MemoryCookieStore struct {
	Cookie *http.Cookie
}

MemoryCookieStore keeps a single cookie in memory

func (*MemoryCookieStore) Retrieve

func (m *MemoryCookieStore) Retrieve() (*http.Cookie, error)

Retrieve returns any Saved cookies.

func (*MemoryCookieStore) Save

func (m *MemoryCookieStore) Save(cookie *http.Cookie) error

Save stores a cookie.

type NodePresenter added in v1.10.17

type NodePresenter struct {
	presenters.NodeResource
}

func (NodePresenter) RenderTable added in v1.10.17

func (p NodePresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

func (*NodePresenter) ToRow added in v1.10.17

func (p *NodePresenter) ToRow() []string

type NodePresenters added in v1.10.17

type NodePresenters []NodePresenter

func (NodePresenters) RenderTable added in v1.10.17

func (ps NodePresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type OCRKeyBundlePresenter added in v1.10.16

type OCRKeyBundlePresenter struct {
	JAID // Include this to overwrite the presenter JAID so it can correctly render the ID in JSON
	presenters.OCRKeysBundleResource
}

func (*OCRKeyBundlePresenter) RenderTable added in v1.10.16

func (p *OCRKeyBundlePresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

func (*OCRKeyBundlePresenter) ToRow added in v1.10.16

func (p *OCRKeyBundlePresenter) ToRow() []string

type OCRKeyBundlePresenters added in v1.10.16

type OCRKeyBundlePresenters []OCRKeyBundlePresenter

func (OCRKeyBundlePresenters) RenderTable added in v1.10.16

func (ps OCRKeyBundlePresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type P2PKeyPresenter added in v1.10.16

type P2PKeyPresenter struct {
	JAID
	presenters.P2PKeyResource
}

func (*P2PKeyPresenter) RenderTable added in v1.10.16

func (p *P2PKeyPresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

func (*P2PKeyPresenter) ToRow added in v1.10.16

func (p *P2PKeyPresenter) ToRow() []string

type P2PKeyPresenters added in v1.10.16

type P2PKeyPresenters []P2PKeyPresenter

func (P2PKeyPresenters) RenderTable added in v1.10.16

func (ps P2PKeyPresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

type PasswordPrompter

type PasswordPrompter interface {
	Prompt() string
}

PasswordPrompter is an interface primarily used for DI to obtain a password from the User.

func NewPasswordPrompter

func NewPasswordPrompter() PasswordPrompter

NewPasswordPrompter returns the production password change request prompter

type Prompter

type Prompter interface {
	Prompt(string) string
	PasswordPrompt(string) string
	IsTerminal() bool
}

Prompter implements the Prompt function to be used to display at the console.

func NewTerminalPrompter

func NewTerminalPrompter() Prompter

NewTerminalPrompter prompts the user via terminal.

type Renderer

type Renderer interface {
	Render(interface{}, ...string) error
}

Renderer implements the Render method.

type RendererJSON

type RendererJSON struct {
	io.Writer
}

RendererJSON is used to render JSON data.

func (RendererJSON) Render

func (rj RendererJSON) Render(v interface{}, _ ...string) error

Render writes the given input as a JSON string.

type RendererTable

type RendererTable struct {
	io.Writer
}

RendererTable is used for data to be rendered as a table.

func (RendererTable) Render

func (rt RendererTable) Render(v interface{}, headers ...string) error

Render returns a formatted table of text for a given Job or presenter and relevant information.

type Runner

type Runner interface {
	Run(chainlink.Application) error
}

Runner implements the Run method.

type SessionCookieAuthenticator

type SessionCookieAuthenticator struct {
	// contains filtered or unexported fields
}

SessionCookieAuthenticator is a concrete implementation of CookieAuthenticator that retrieves a session id for the user with credentials from the session request.

func (*SessionCookieAuthenticator) Authenticate

func (t *SessionCookieAuthenticator) Authenticate(sessionRequest sessions.SessionRequest) (*http.Cookie, error)

Authenticate retrieves a session ID via a cookie and saves it to disk.

func (*SessionCookieAuthenticator) Cookie

func (t *SessionCookieAuthenticator) Cookie() (*http.Cookie, error)

Cookie Returns the previously saved authentication cookie.

type SessionCookieAuthenticatorConfig added in v1.10.17

type SessionCookieAuthenticatorConfig interface {
	ClientNodeURL() string
	InsecureSkipVerify() bool
}

type SessionRequestBuilder

type SessionRequestBuilder interface {
	Build(flag string) (sessions.SessionRequest, error)
}

SessionRequestBuilder is an interface that returns a SessionRequest, abstracting how session requests are generated, whether they be from the prompt or from a file.

func NewFileSessionRequestBuilder

func NewFileSessionRequestBuilder() SessionRequestBuilder

NewFileSessionRequestBuilder pulls credentials from a file to generate a SessionRequest.

func NewPromptingSessionRequestBuilder

func NewPromptingSessionRequestBuilder(prompter Prompter) SessionRequestBuilder

NewPromptingSessionRequestBuilder uses a prompter, often via terminal, to solicit information from a user to generate the SessionRequest.

type TableRenderer added in v1.10.16

type TableRenderer interface {
	RenderTable(rt RendererTable) error
}

type TerminalKeyStoreAuthenticator

type TerminalKeyStoreAuthenticator struct {
	Prompter Prompter
}

TerminalKeyStoreAuthenticator contains fields for prompting the user and an exit code.

type VRFKeyPresenter added in v1.10.16

type VRFKeyPresenter struct {
	JAID // Include this to overwrite the presenter JAID so it can correctly render the ID in JSON
	presenters.VRFKeyResource
}

func (*VRFKeyPresenter) RenderTable added in v1.10.16

func (p *VRFKeyPresenter) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

func (*VRFKeyPresenter) ToRow added in v1.10.16

func (p *VRFKeyPresenter) ToRow() []string

type VRFKeyPresenters added in v1.10.16

type VRFKeyPresenters []VRFKeyPresenter

func (VRFKeyPresenters) RenderTable added in v1.10.16

func (ps VRFKeyPresenters) RenderTable(rt RendererTable) error

RenderTable implements TableRenderer

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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