1// Package bridge contains the high-level public functions to use and manage bridges
2package bridge
3
4import (
5 "github.com/MichaelMure/git-bug/bridge/core"
6 "github.com/MichaelMure/git-bug/bridge/github"
7 "github.com/MichaelMure/git-bug/bridge/gitlab"
8 "github.com/MichaelMure/git-bug/bridge/jira"
9 "github.com/MichaelMure/git-bug/bridge/launchpad"
10 "github.com/MichaelMure/git-bug/cache"
11 "github.com/MichaelMure/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// Instantiate a new Bridge for a repo, from the given target and name
27func NewBridge(repo *cache.RepoCache, target string, name string) (*core.Bridge, error) {
28 return core.NewBridge(repo, target, name)
29}
30
31// LoadBridge instantiate a new bridge from a repo configuration
32func LoadBridge(repo *cache.RepoCache, name string) (*core.Bridge, error) {
33 return core.LoadBridge(repo, name)
34}
35
36// Attempt to retrieve a default bridge for the given repo. If zero or multiple
37// bridge exist, it fails.
38func DefaultBridge(repo *cache.RepoCache) (*core.Bridge, error) {
39 return core.DefaultBridge(repo)
40}
41
42// ConfiguredBridges return the list of bridge that are configured for the given
43// repo
44func ConfiguredBridges(repo repository.RepoConfig) ([]string, error) {
45 return core.ConfiguredBridges(repo)
46}
47
48// Remove a configured bridge
49func RemoveBridge(repo repository.RepoConfig, name string) error {
50 return core.RemoveBridge(repo, name)
51}