From 1d5dc36ace77947b58e5307668500e2a45be0ea3 Mon Sep 17 00:00:00 2001 From: Jan Sebastian Siwy Date: Wed, 18 Mar 2020 13:19:47 +0100 Subject: [PATCH] Add support to retrieve information about the currently authenticated user Copy https://github.com/terraform-providers/terraform-provider-github/pull/261 as the original repository behind this PR has been deleted --- github/data_source_github_user.go | 4 ++-- ...e_github_repository_vulnerability_alerts.go | 18 +++++++++--------- website/docs/d/user.html.markdown | 15 +++++++++++++-- 3 files changed, 24 insertions(+), 13 deletions(-) diff --git a/github/data_source_github_user.go b/github/data_source_github_user.go index 04e661326d..461fd64546 100644 --- a/github/data_source_github_user.go +++ b/github/data_source_github_user.go @@ -111,11 +111,11 @@ func dataSourceGithubUserRead(d *schema.ResourceData, meta interface{}) error { return err } - gpg, _, err := client.Users.ListGPGKeys(ctx, username, nil) + gpg, _, err := client.Users.ListGPGKeys(ctx, user.GetLogin(), nil) if err != nil { return err } - ssh, _, err := client.Users.ListKeys(ctx, username, nil) + ssh, _, err := client.Users.ListKeys(ctx, user.GetLogin(), nil) if err != nil { return err } diff --git a/github/resource_github_repository_vulnerability_alerts.go b/github/resource_github_repository_vulnerability_alerts.go index 019afa3d93..66237ad5bf 100644 --- a/github/resource_github_repository_vulnerability_alerts.go +++ b/github/resource_github_repository_vulnerability_alerts.go @@ -30,14 +30,14 @@ func resourceGithubRepositoryVulnerabilityAlertsCreate(d *schema.ResourceData, m return err } - client := meta.(*Organization).client + v3client := meta.(*Owner).v3client - orgName := meta.(*Organization).name + orgName := meta.(*Owner).name repoName := d.Get("repository").(string) log.Printf("[DEBUG] Creating repository vulnerability alerts: %s/%s", orgName, repoName) ctx := context.WithValue(context.Background(), ctxId, d.Id()) - _, err = client.Repositories.EnableVulnerabilityAlerts(ctx, orgName, repoName) + _, err = v3client.Repositories.EnableVulnerabilityAlerts(ctx, orgName, repoName) if err != nil { return err } @@ -53,17 +53,17 @@ func resourceGithubRepositoryVulnerabilityAlertsRead(d *schema.ResourceData, met return err } - client := meta.(*Organization).client + v3client := meta.(*Owner).v3client repoName := d.Id() if err != nil { return err } - orgName := meta.(*Organization).name + orgName := meta.(*Owner).name log.Printf("[DEBUG] Reading repository vulnerability alerts: %s/%s", orgName, repoName) ctx := context.WithValue(context.Background(), ctxId, d.Id()) - enabled, _, err := client.Repositories.GetVulnerabilityAlerts(ctx, orgName, repoName) + enabled, _, err := v3client.Repositories.GetVulnerabilityAlerts(ctx, orgName, repoName) if err != nil { return fmt.Errorf("Error reading repository vulnerability alerts: %v", err) } @@ -80,16 +80,16 @@ func resourceGithubRepositoryVulnerabilityAlertsDelete(d *schema.ResourceData, m return err } - client := meta.(*Organization).client + v3client := meta.(*Owner).v3client repoName := d.Id() if err != nil { return err } - orgName := meta.(*Organization).name + orgName := meta.(*Owner).name ctx := context.WithValue(context.Background(), ctxId, d.Id()) log.Printf("[DEBUG] Deleting repository vulnerability alerts%s/%s", orgName, repoName) - _, err = client.Repositories.DisableVulnerabilityAlerts(ctx, orgName, repoName) + _, err = v3client.Repositories.DisableVulnerabilityAlerts(ctx, orgName, repoName) return err } diff --git a/website/docs/d/user.html.markdown b/website/docs/d/user.html.markdown index b3c051b0ae..467765f945 100644 --- a/website/docs/d/user.html.markdown +++ b/website/docs/d/user.html.markdown @@ -1,6 +1,7 @@ --- layout: "github" page_title: "GitHub: github_user" +sidebar_current: "docs-github-datasource-user" description: |- Get information on a GitHub user. --- @@ -12,14 +13,25 @@ Use this data source to retrieve information about a GitHub user. ## Example Usage ```hcl +# Retrieve information about a GitHub user. data "github_user" "example" { username = "example" } + +# Retrieve information about the currently authenticated user. +data "github_user" "current" { + username = "" +} + +output "current_github_login" { + value = "${data.github_user.current.login}" +} + ``` ## Argument Reference - * `username` - (Required) The username. + * `username` - (Required) The username. Use an empty string `""` to retrieve information about the currently authenticated user. ## Attributes Reference @@ -41,4 +53,3 @@ data "github_user" "example" { * `following` - the number of following users. * `created_at` - the creation date. * `updated_at` - the update date. -