mirror of
https://github.com/ysoftdevs/terraform-provider-bitbucketserver.git
synced 2026-04-18 06:49:44 +02:00
Added enable_git_lfs flag for repositories
This commit is contained in:
@@ -67,6 +67,11 @@ func resourceRepository() *schema.Resource {
|
|||||||
Optional: true,
|
Optional: true,
|
||||||
Default: false,
|
Default: false,
|
||||||
},
|
},
|
||||||
|
"enable_git_lfs": {
|
||||||
|
Type: schema.TypeBool,
|
||||||
|
Optional: true,
|
||||||
|
Default: false,
|
||||||
|
},
|
||||||
"clone_ssh": {
|
"clone_ssh": {
|
||||||
Type: schema.TypeString,
|
Type: schema.TypeString,
|
||||||
Computed: true,
|
Computed: true,
|
||||||
@@ -112,12 +117,18 @@ func resourceRepositoryUpdate(d *schema.ResourceData, m interface{}) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
err = handleRepositoryGitLFSChanges(client, project, repoSlug, d)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
return resourceRepositoryRead(d, m)
|
return resourceRepositoryRead(d, m)
|
||||||
}
|
}
|
||||||
|
|
||||||
func resourceRepositoryCreate(d *schema.ResourceData, m interface{}) error {
|
func resourceRepositoryCreate(d *schema.ResourceData, m interface{}) error {
|
||||||
client := m.(*BitbucketServerProvider).BitbucketClient
|
client := m.(*BitbucketServerProvider).BitbucketClient
|
||||||
repo, project := newRepositoryFromResource(d)
|
repo, project := newRepositoryFromResource(d)
|
||||||
|
repoSlug := determineSlug(d)
|
||||||
|
|
||||||
bytedata, err := json.Marshal(repo)
|
bytedata, err := json.Marshal(repo)
|
||||||
|
|
||||||
@@ -135,16 +146,48 @@ func resourceRepositoryCreate(d *schema.ResourceData, m interface{}) error {
|
|||||||
|
|
||||||
d.SetId(string(fmt.Sprintf("%s/%s", project, repo.Name)))
|
d.SetId(string(fmt.Sprintf("%s/%s", project, repo.Name)))
|
||||||
|
|
||||||
|
err = handleRepositoryGitLFSChanges(client, project, repoSlug, d)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
return resourceRepositoryRead(d, m)
|
return resourceRepositoryRead(d, m)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func handleRepositoryGitLFSChanges(client *BitbucketClient, project string, repoSlug string, d *schema.ResourceData) error {
|
||||||
|
enableGitLFS := d.Get("enable_git_lfs").(bool)
|
||||||
|
if (d.IsNewResource() && enableGitLFS) || d.HasChange("enable_git_lfs") {
|
||||||
|
if enableGitLFS {
|
||||||
|
_, err := client.Put(fmt.Sprintf("/rest/git-lfs/admin/projects/%s/repos/%s/enabled",
|
||||||
|
project,
|
||||||
|
repoSlug,
|
||||||
|
), nil)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
_, err := client.Delete(fmt.Sprintf("/rest/git-lfs/admin/projects/%s/repos/%s/enabled",
|
||||||
|
project,
|
||||||
|
repoSlug,
|
||||||
|
))
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func resourceRepositoryRead(d *schema.ResourceData, m interface{}) error {
|
func resourceRepositoryRead(d *schema.ResourceData, m interface{}) error {
|
||||||
id := d.Id()
|
id := d.Id()
|
||||||
if id != "" {
|
if id != "" {
|
||||||
idparts := strings.Split(id, "/")
|
idparts := strings.Split(id, "/")
|
||||||
if len(idparts) == 2 {
|
if len(idparts) == 2 {
|
||||||
d.Set("project", idparts[0])
|
_ = d.Set("project", idparts[0])
|
||||||
d.Set("slug", idparts[1])
|
_ = d.Set("slug", idparts[1])
|
||||||
} else {
|
} else {
|
||||||
return fmt.Errorf("incorrect ID format, should match `project/slug`")
|
return fmt.Errorf("incorrect ID format, should match `project/slug`")
|
||||||
}
|
}
|
||||||
@@ -177,21 +220,27 @@ func resourceRepositoryRead(d *schema.ResourceData, m interface{}) error {
|
|||||||
return decodeerr
|
return decodeerr
|
||||||
}
|
}
|
||||||
|
|
||||||
d.Set("name", repo.Name)
|
_ = d.Set("name", repo.Name)
|
||||||
if repo.Slug != "" && repo.Name != repo.Slug {
|
if repo.Slug != "" && repo.Name != repo.Slug {
|
||||||
d.Set("slug", repo.Slug)
|
_ = d.Set("slug", repo.Slug)
|
||||||
}
|
}
|
||||||
d.Set("description", repo.Description)
|
_ = d.Set("description", repo.Description)
|
||||||
d.Set("forkable", repo.Forkable)
|
_ = d.Set("forkable", repo.Forkable)
|
||||||
d.Set("public", repo.Public)
|
_ = d.Set("public", repo.Public)
|
||||||
|
|
||||||
for _, clone_url := range repo.Links.Clone {
|
for _, clone_url := range repo.Links.Clone {
|
||||||
if clone_url.Name == "http" {
|
if clone_url.Name == "http" {
|
||||||
d.Set("clone_https", clone_url.Href)
|
_ = d.Set("clone_https", clone_url.Href)
|
||||||
} else {
|
} else {
|
||||||
d.Set("clone_ssh", clone_url.Href)
|
_ = d.Set("clone_ssh", clone_url.Href)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gifLFS, err := client.Get(fmt.Sprintf("/rest/git-lfs/admin/projects/%s/repos/%s/enabled",
|
||||||
|
project,
|
||||||
|
repoSlug,
|
||||||
|
))
|
||||||
|
_ = d.Set("enable_git_lfs", err == nil && gifLFS.StatusCode == 200)
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|||||||
@@ -71,6 +71,38 @@ func TestAccBitbucketRepository_namewithspaces(t *testing.T) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestAccBitbucketRepository_gitlfs(t *testing.T) {
|
||||||
|
var repo Repository
|
||||||
|
|
||||||
|
key := fmt.Sprintf("%v", rand.New(rand.NewSource(time.Now().UnixNano())).Int())
|
||||||
|
testAccBitbucketRepositoryConfig := fmt.Sprintf(`
|
||||||
|
resource "bitbucketserver_project" "test" {
|
||||||
|
key = "TEST%v"
|
||||||
|
name = "Test%v"
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "bitbucketserver_repository" "test_repo" {
|
||||||
|
project = bitbucketserver_project.test.key
|
||||||
|
name = "test-repo-for-repository-test"
|
||||||
|
enable_git_lfs = true
|
||||||
|
}
|
||||||
|
`, key, key)
|
||||||
|
|
||||||
|
resource.Test(t, resource.TestCase{
|
||||||
|
PreCheck: func() { testAccPreCheck(t) },
|
||||||
|
Providers: testAccProviders,
|
||||||
|
CheckDestroy: testAccCheckBitbucketRepositoryDestroy,
|
||||||
|
Steps: []resource.TestStep{
|
||||||
|
{
|
||||||
|
Config: testAccBitbucketRepositoryConfig,
|
||||||
|
Check: resource.ComposeTestCheckFunc(
|
||||||
|
testAccCheckBitbucketRepositoryExists("bitbucketserver_repository.test_repo", &repo),
|
||||||
|
),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func testAccCheckBitbucketRepositoryDestroy(s *terraform.State) error {
|
func testAccCheckBitbucketRepositoryDestroy(s *terraform.State) error {
|
||||||
client := testAccProvider.Meta().(*BitbucketServerProvider).BitbucketClient
|
client := testAccProvider.Meta().(*BitbucketServerProvider).BitbucketClient
|
||||||
rs, ok := s.RootModule().Resources["bitbucketserver_repository.test_repo"]
|
rs, ok := s.RootModule().Resources["bitbucketserver_repository.test_repo"]
|
||||||
|
|||||||
@@ -23,6 +23,7 @@ resource "bitbucketserver_repository" "test" {
|
|||||||
* `description` - Optional. Description of the repository.
|
* `description` - Optional. Description of the repository.
|
||||||
* `forkable` - Optional. Enable/disable forks of this repository. Default `true`
|
* `forkable` - Optional. Enable/disable forks of this repository. Default `true`
|
||||||
* `public` - Optional. Determine if this repository is public. Default `false`
|
* `public` - Optional. Determine if this repository is public. Default `false`
|
||||||
|
* `enable_git_lfs` - Optional. Enable git-lfs for this repository. Default `false`
|
||||||
|
|
||||||
## Attribute Reference
|
## Attribute Reference
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user