Skip to content

Commit

Permalink
added a second datasource that can be used to access file infos only
Browse files Browse the repository at this point in the history
  • Loading branch information
volkc-basf committed Nov 13, 2019
1 parent 3c21e86 commit ced27f4
Show file tree
Hide file tree
Showing 3 changed files with 117 additions and 32 deletions.
34 changes: 3 additions & 31 deletions pkg/artifactory/datasource_artifactory_file.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ import (

func dataSourceArtifactoryFile() *schema.Resource {
return &schema.Resource{
Read: dataSourceArtifactRead,
Read: dataSourceFileRead,

Schema: map[string]*schema.Schema{
"repository": {
Expand Down Expand Up @@ -71,7 +71,7 @@ func dataSourceArtifactoryFile() *schema.Resource {
},
"output_path": {
Type: schema.TypeString,
Optional: true,
Required: true,
},
"force_overwrite": {
Type: schema.TypeBool,
Expand All @@ -82,7 +82,7 @@ func dataSourceArtifactoryFile() *schema.Resource {
}
}

func dataSourceArtifactRead(d *schema.ResourceData, m interface{}) error {
func dataSourceFileRead(d *schema.ResourceData, m interface{}) error {
c := m.(*artifactory.Artifactory)

repository := d.Get("repository").(string)
Expand Down Expand Up @@ -165,31 +165,3 @@ func VerifySha256Checksum(path string, expectedSha256 string) (bool, error) {

return hex.EncodeToString(hasher.Sum(nil)) == expectedSha256, nil
}

func packFileInfo(fileInfo *v1.FileInfo, d *schema.ResourceData) error {
hasErr := false
logErr := cascadingErr(&hasErr)

d.SetId(*fileInfo.DownloadUri)

logErr(d.Set("created", *fileInfo.Created))
logErr(d.Set("created_by", *fileInfo.CreatedBy))
logErr(d.Set("last_modified", *fileInfo.LastModified))
logErr(d.Set("modified_by", *fileInfo.ModifiedBy))
logErr(d.Set("last_updated", *fileInfo.LastUpdated))
logErr(d.Set("download_uri", *fileInfo.DownloadUri))
logErr(d.Set("mimetype", *fileInfo.MimeType))
logErr(d.Set("size", *fileInfo.Size))

if fileInfo.Checksums != nil {
logErr(d.Set("md5", *fileInfo.Checksums.Md5))
logErr(d.Set("sha1", *fileInfo.Checksums.Sha1))
logErr(d.Set("sha256", *fileInfo.Checksums.Sha256))
}

if hasErr {
return fmt.Errorf("failed to pack fileInfo")
}

return nil
}
112 changes: 112 additions & 0 deletions pkg/artifactory/datasource_artifactory_fileinfo.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,112 @@
package artifactory

import (
"context"
"fmt"
"github.com/atlassian/go-artifactory/v2/artifactory"
"github.com/atlassian/go-artifactory/v2/artifactory/v1"
"github.com/hashicorp/terraform/helper/schema"
)

func dataSourceArtifactoryFileInfo() *schema.Resource {
return &schema.Resource{
Read: dataSourceFileInfoRead,

Schema: map[string]*schema.Schema{
"repository": {
Type: schema.TypeString,
Required: true,
},
"path": {
Type: schema.TypeString,
Required: true,
},
"created": {
Type: schema.TypeString,
Computed: true,
},
"created_by": {
Type: schema.TypeString,
Computed: true,
},
"last_modified": {
Type: schema.TypeString,
Computed: true,
},
"modified_by": {
Type: schema.TypeString,
Computed: true,
},
"last_updated": {
Type: schema.TypeString,
Computed: true,
},
"download_uri": {
Type: schema.TypeString,
Computed: true,
},
"mimetype": {
Type: schema.TypeString,
Computed: true,
},
"size": {
Type: schema.TypeInt,
Computed: true,
},
"md5": {
Type: schema.TypeString,
Computed: true,
},
"sha1": {
Type: schema.TypeString,
Computed: true,
},
"sha256": {
Type: schema.TypeString,
Computed: true,
},
},
}
}

func dataSourceFileInfoRead(d *schema.ResourceData, m interface{}) error {
c := m.(*artifactory.Artifactory)

repository := d.Get("repository").(string)
path := d.Get("path").(string)

fileInfo, _, err := c.V1.Artifacts.FileInfo(context.Background(), repository, path)
if err != nil {
return err
}

return packFileInfo(fileInfo, d)
}

func packFileInfo(fileInfo *v1.FileInfo, d *schema.ResourceData) error {
hasErr := false
logErr := cascadingErr(&hasErr)

d.SetId(*fileInfo.DownloadUri)

logErr(d.Set("created", *fileInfo.Created))
logErr(d.Set("created_by", *fileInfo.CreatedBy))
logErr(d.Set("last_modified", *fileInfo.LastModified))
logErr(d.Set("modified_by", *fileInfo.ModifiedBy))
logErr(d.Set("last_updated", *fileInfo.LastUpdated))
logErr(d.Set("download_uri", *fileInfo.DownloadUri))
logErr(d.Set("mimetype", *fileInfo.MimeType))
logErr(d.Set("size", *fileInfo.Size))

if fileInfo.Checksums != nil {
logErr(d.Set("md5", *fileInfo.Checksums.Md5))
logErr(d.Set("sha1", *fileInfo.Checksums.Sha1))
logErr(d.Set("sha256", *fileInfo.Checksums.Sha256))
}

if hasErr {
return fmt.Errorf("failed to pack fileInfo")
}

return nil
}
3 changes: 2 additions & 1 deletion pkg/artifactory/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,8 @@ func Provider() terraform.ResourceProvider {
},

DataSourcesMap: map[string]*schema.Resource{
"artifactory_file": dataSourceArtifactoryFile(),
"artifactory_file": dataSourceArtifactoryFile(),
"artifactory_fileinfo": dataSourceArtifactoryFileInfo(),
},

ConfigureFunc: providerConfigure,
Expand Down

0 comments on commit ced27f4

Please sign in to comment.