Sha256: bf1624f578ee1c5707b1962be5e27558e09f68f0f4f19cc45ecc2474358d3e58

Contents?: true

Size: 1.86 KB

Versions: 1

Compression:

Stored size: 1.86 KB

Contents

### Copyright 2017 Pixar

###
###    Licensed under the Apache License, Version 2.0 (the "Apache License")
###    with the following modification; you may not use this file except in
###    compliance with the Apache License and the following modification to it:
###    Section 6. Trademarks. is deleted and replaced with:
###
###    6. Trademarks. This License does not grant permission to use the trade
###       names, trademarks, service marks, or product names of the Licensor
###       and its affiliates, except as required to comply with Section 4(c) of
###       the License and to reproduce the content of the NOTICE file.
###
###    You may obtain a copy of the Apache License at
###
###        http://www.apache.org/licenses/LICENSE-2.0
###
###    Unless required by applicable law or agreed to in writing, software
###    distributed under the Apache License with the above modification is
###    distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
###    KIND, either express or implied. See the Apache License for the specific
###    language governing permissions and limitations under the Apache License.
###
###

module Chook

  # see server.rb
  class Server < Sinatra::Base

    post '/handle_webhook_event' do
      # enforce http basic auth if needed
      protect_via_basic_auth!

      # rewind to ensure read-pointer is at the start
      request.body.rewind #
      raw_json = request.body.read

      event = Chook::HandledEvent.parse_event raw_json
      if event.nil?
        logger.error "Empty JSON from #{request.ip}"
        result = 400
      else

        event.logger.info "START From #{request.ip}, WebHook '#{event.webhook_name}' (id: #{event.webhook_id})"

        event.logger.debug "JSON: #{raw_json}"

        result = event.handle

        event.logger.info "END #{result}"
      end
      result
    end # post

  end # class

end # module

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
chook-1.1.1 lib/chook/server/routes/handle_webhook_event.rb