piotrmurach/github

View on GitHub
lib/github_api/client/repos/pub_sub_hubbub.rb

Summary

Maintainability
A
30 mins
Test Coverage
# encoding: utf-8

require_relative '../../api'

module Github
  class Client::Repos::PubSubHubbub < API
    HEADERS = {
      CONTENT_TYPE => 'application/x-www-form-urlencoded'
    }

    # Subscribe to existing topic/event through pubsubhubbub
    #
    # @param [Hash] params
    # @input params [String] :topic
    #   Required string. The URI of the GitHub repository to subscribe to.
    #   The path must be in the format of /:user/:repo/events/:event.
    # @input params [String] :callback
    #   Required string - The URI to receive the updates to the topic.
    #
    # @example
    #  github = Github.new oauth_token: 'token'
    #  github.repos.pubsubhubbub.subscribe
    #    'https://github.com/:user/:repo/events/push',
    #    'github://Email?address=peter-murach@gmail.com',
    #    verify: 'sync',
    #    secret: '...'
    #
    # @api public
    def subscribe(*args)
      params = arguments(args, required: [:topic, :callback]).params
      _merge_action!("subscribe", arguments.topic, arguments.callback, params)
      params['headers'] = HEADERS

      post_request("/hub", params)
    end

    # Unsubscribe from existing topic/event through pubsubhubbub
    #
    # @param [Hash] params
    # @input params [String] :topic
    #   Required string. The URI of the GitHub repository to
    #   unsubscribe from. The path must be in the format of
    #   /:user/:repo/events/:event.
    # @input params [String] :callback
    #   Required string. The URI to unsubscribe the topic from.
    #
    # @example
    #   github = Github.new oauth_token: 'token'
    #   github.repos.pubsubhubbub.unsubscribe
    #     'https://github.com/:user/:repo/events/push',
    #     'github://Email?address=peter-murach@gmail.com',
    #     verify: 'sync',
    #     secret: '...'
    #
    # @api public
    def unsubscribe(*args)
      params = arguments(args, required: [:topic, :callback]).params
      _merge_action!("unsubscribe", arguments.topic, arguments.callback, params)
      params['headers'] = HEADERS

      post_request("/hub", params)
    end

    # Subscribe repository to service hook through pubsubhubbub
    #
    # @param [Hash] params
    # @input params [String] :event
    #   Required hash key for the type of event. The default event is push.
    #
    # @example
    #   github = Github.new oauth_token: '...'
    #   github.repos.pubsubhubbub.subscribe_service 'user-name', 'repo-name',
    #    'campfire',
    #     subdomain: 'github',
    #     room: 'Commits',
    #     token: 'abc123',
    #     event: 'watch'
    #
    # @api public
    def subscribe_service(*args)
      params   = arguments(args, required: [:user, :repo, :service]).params
      event    = params.delete('event') || 'push'
      topic    = "#{site}/#{arguments.user}/#{arguments.repo}/events/#{event}"
      callback = "github://#{arguments.service}?#{params.serialize}"

      subscribe(topic, callback)
    end
    alias :subscribe_repository :subscribe_service
    alias :subscribe_repo :subscribe_service

    # Subscribe repository to service hook through pubsubhubbub
    #
    # @param [Hash] params
    # @input params [String] :event
    #   Optional hash key for the type of event. The default event is push.
    #
    # @example
    #   github = Github.new oauth_token: '...'
    #   github.repos.pubsubhubbub.unsubscribe_service 'user-name', 'repo-name',
    #     'campfire'
    #
    # @example
    #   github.repos.pubsubhubbub.unsubscribe_service
    #     user: 'user-name',
    #     repo: 'repo-name',
    #     service: 'service-name'
    #
    # @api public
    def unsubscribe_service(*args)
      params   = arguments(args, required: [:user, :repo, :service]).params
      event    = params.delete('event') || 'push'
      topic    = "#{site}/#{arguments.user}/#{arguments.repo}/events/#{event}"
      callback = "github://#{arguments.service}"

      unsubscribe(topic, callback)
    end
    alias :unsubscribe_repository :unsubscribe_service
    alias :unsubscribe_repo :unsubscribe_service

    private

    def _merge_action!(action, topic, callback, params) # :nodoc:
      options = {
        "hub.mode"     => action.to_s,
        "hub.topic"    => topic.to_s,
        "hub.callback" => callback,
        "hub.verify"   => params.delete('verify') || 'sync',
        "hub.secret"   => params.delete('secret') || ''
      }
      params.merge! options
    end
  end # Client::Repos::PubSubHubbub
end # Github