class GitPivotalTrackerIntegration::Command::Configuration

A class that exposes configuration that commands can use

Constants

KEY_API_TOKEN
KEY_PROJECT_ID
KEY_STORY_ID

Public Instance Methods

api_token() click to toggle source

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.

@return [String] The user’s Pivotal Tracker API token

# File lib/git-pivotal-tracker-integration/command/configuration.rb, line 30
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
project_id() click to toggle source

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.

@return [String] The repository’s Pivotal Tracker project id

# File lib/git-pivotal-tracker-integration/command/configuration.rb, line 48
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) click to toggle source

Returns the story associated with the current development branch

@param [PivotalTracker::Project] project the project the story belongs to @return [PivotalTracker::Story] the story associated with the current development branch

# File lib/git-pivotal-tracker-integration/command/configuration.rb, line 71
def story(project)
  story_id = GitPivotalTrackerIntegration::Util::Git.get_config KEY_STORY_ID, :branch
  project.stories.find story_id.to_i
end
story=(story) click to toggle source

Stores the story associated with the current development branch

@param [PivotalTracker::Story] story the story associated with the current development branch @return [void]

# File lib/git-pivotal-tracker-integration/command/configuration.rb, line 80
def story=(story)
  GitPivotalTrackerIntegration::Util::Git.set_config KEY_STORY_ID, story.id, :branch
end