Class: GitPivotalTrackerIntegration::Command::Configuration

Inherits:
Object
  • Object
show all
Defined in:
lib/git-pivotal-tracker-integration/command/configuration.rb

Overview

A class that exposes configuration that commands can use

Instance Method Summary collapse

Instance Method Details

#api_tokenString

Returns the user’s Pivotal Tracker API token. If this token has not been configured, prompts the user for the value. The value is checked for in the inherited Git configuration, but is stored in the global Git configuration so that it can be used across multiple repositories.

Returns:

  • (String)

    The user’s Pivotal Tracker API token



31
32
33
34
35
36
37
38
39
40
41
# File 'lib/git-pivotal-tracker-integration/command/configuration.rb', line 31

def api_token
  api_token = GitPivotalTrackerIntegration::Util::Git.get_config KEY_API_TOKEN, :inherited

  if api_token.empty?
    api_token = ask('Pivotal API Token (found at https://www.pivotaltracker.com/profile): ').strip
    GitPivotalTrackerIntegration::Util::Git.set_config KEY_API_TOKEN, api_token, :global
    puts
  end

  api_token
end

#githubObject



85
86
87
88
89
90
91
92
93
94
95
96
# File 'lib/git-pivotal-tracker-integration/command/configuration.rb', line 85

def github
  token = GitPivotalTrackerIntegration::Util::Git.get_config GITHUB_API_OAUTH_TOKEN

  if (token.empty?)
    token = ask("Github OAuth Token (help.github.com/articles/creating-an-access-token-for-command-line-use): ").strip
    GitPivotalTrackerIntegration::Util::Git.set_config(GITHUB_API_OAUTH_TOKEN, token, :local)
  end

  repo = GitPivotalTrackerIntegration::Util::Git.repo_name

  ::Github.new(:oauth_token => token)
end

#project_idString

Returns the Pivotal Tracker project id for this repository. If this id has not been configuration, prompts the user for the value. The value is checked for in the inherited Git configuration, but is stored in the local Git configuration so that it is specific to this repository.

Returns:

  • (String)

    The repository’s Pivotal Tracker project id



49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# File 'lib/git-pivotal-tracker-integration/command/configuration.rb', line 49

def project_id
  project_id = GitPivotalTrackerIntegration::Util::Git.get_config KEY_PROJECT_ID, :inherited

  if project_id.empty?
    project_id = choose do |menu|
      menu.prompt = 'Choose project associated with this repository: '

      PivotalTracker::Project.all.sort_by { |project| project.name }.each do |project|
        menu.choice(project.name) { project.id }
      end
    end

    GitPivotalTrackerIntegration::Util::Git.set_config KEY_PROJECT_ID, project_id, :local
    puts
  end

  project_id
end

#story(project) ⇒ PivotalTracker::Story

Returns the story associated with the current development branch

Parameters:

  • project (PivotalTracker::Project)

    the project the story belongs to

Returns:

  • (PivotalTracker::Story)

    the story associated with the current development branch



72
73
74
75
# File 'lib/git-pivotal-tracker-integration/command/configuration.rb', line 72

def story(project)
  story_id = GitPivotalTrackerIntegration::Util::Git.get_config KEY_STORY_ID, :branch
  project.stories.find story_id.to_i
end

#story=(story) ⇒ void

This method returns an undefined value.

Stores the story associated with the current development branch

Parameters:

  • story (PivotalTracker::Story)

    the story associated with the current development branch



81
82
83
# File 'lib/git-pivotal-tracker-integration/command/configuration.rb', line 81

def story=(story)
  GitPivotalTrackerIntegration::Util::Git.set_config KEY_STORY_ID, story.id, :branch
end