1// Package bridge contains the high-level public functions to use and manage bridges
 2package bridge
 3
 4import (
 5	"github.com/git-bug/git-bug/bridge/core"
 6	"github.com/git-bug/git-bug/bridge/github"
 7	"github.com/git-bug/git-bug/bridge/gitlab"
 8	"github.com/git-bug/git-bug/bridge/jira"
 9	"github.com/git-bug/git-bug/bridge/launchpad"
10	"github.com/git-bug/git-bug/cache"
11	"github.com/git-bug/git-bug/repository"
12)
13
14func init() {
15	core.Register(&github.Github{})
16	core.Register(&gitlab.Gitlab{})
17	core.Register(&launchpad.Launchpad{})
18	core.Register(&jira.Jira{})
19}
20
21// Targets return all known bridge implementation target
22func Targets() []string {
23	return core.Targets()
24}
25
26// LoginMetaKey return the metadata key used to store the remote bug-tracker login
27// on the user identity. The corresponding value is used to match identities and
28// credentials.
29func LoginMetaKey(target string) (string, error) {
30	return core.LoginMetaKey(target)
31}
32
33// Instantiate a new Bridge for a repo, from the given target and name
34func NewBridge(repo *cache.RepoCache, target string, name string) (*core.Bridge, error) {
35	return core.NewBridge(repo, target, name)
36}
37
38// LoadBridge instantiate a new bridge from a repo configuration
39func LoadBridge(repo *cache.RepoCache, name string) (*core.Bridge, error) {
40	return core.LoadBridge(repo, name)
41}
42
43// Attempt to retrieve a default bridge for the given repo. If zero or multiple
44// bridge exist, it fails.
45func DefaultBridge(repo *cache.RepoCache) (*core.Bridge, error) {
46	return core.DefaultBridge(repo)
47}
48
49// ConfiguredBridges return the list of bridge that are configured for the given
50// repo
51func ConfiguredBridges(repo repository.RepoConfig) ([]string, error) {
52	return core.ConfiguredBridges(repo)
53}
54
55// Remove a configured bridge
56func RemoveBridge(repo repository.RepoConfig, name string) error {
57	return core.RemoveBridge(repo, name)
58}