opensips-mi 0.0.2 → 0.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +8 -8
- data/README.md +3 -0
- data/lib/opensips/mi/command.rb +16 -5
- data/lib/opensips/mi/transport/datagram.rb +1 -8
- data/lib/opensips/mi/transport/xmlrpc.rb +3 -10
- data/lib/opensips/mi/version.rb +1 -1
- metadata +3 -3
    
        checksums.yaml
    CHANGED
    
    | @@ -1,15 +1,15 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            !binary "U0hBMQ==":
         | 
| 3 3 | 
             
              metadata.gz: !binary |-
         | 
| 4 | 
            -
                 | 
| 4 | 
            +
                ZThhYmE0OGQxNWQ4ZTg2MGI0OWU3YTA2NmE1MjllZDJmYjU0YjIyYQ==
         | 
| 5 5 | 
             
              data.tar.gz: !binary |-
         | 
| 6 | 
            -
                 | 
| 6 | 
            +
                MTQ4ZTAyYzViMWE2OGI3YmYzMTRhN2Y4Y2RhYWE3YWFmOTczMTc5Yw==
         | 
| 7 7 | 
             
            !binary "U0hBNTEy":
         | 
| 8 8 | 
             
              metadata.gz: !binary |-
         | 
| 9 | 
            -
                 | 
| 10 | 
            -
                 | 
| 11 | 
            -
                 | 
| 9 | 
            +
                YWJmODcxMzQyNWM4MmEwNmYzOTkwYzg0MGI3NTJjY2JkZmE5MzZlYjA3OTNi
         | 
| 10 | 
            +
                NmU1YWI0Yjg0NmNlZDI1MmM4NDRjODFhNTRjNTExZDRmYTA0NmEwYjc3YzRi
         | 
| 11 | 
            +
                MjljMDJkOWJiZTJlZWI3MzMzYjY1ZTc3NDNlNTk5MjUzYmE2YjM=
         | 
| 12 12 | 
             
              data.tar.gz: !binary |-
         | 
| 13 | 
            -
                 | 
| 14 | 
            -
                 | 
| 15 | 
            -
                 | 
| 13 | 
            +
                ZjUwNzE0ZTU2ODJjMTgwMTQ3NzgwZjgyODM5NjA3MWU4MjZjMjUyZGU4MjBk
         | 
| 14 | 
            +
                ZmFlYjZkYmRkMjFkYTdhYmE4YWJmYzYzMzMyNGZhOTE1ZmMzYTllNDgzNzBl
         | 
| 15 | 
            +
                YTc5MGY4MmIyZTlhNGVmNGU1NzhlZWE0M2VkYjI5ZDY2ZTkyNDg=
         | 
    
        data/README.md
    CHANGED
    
    | @@ -1,4 +1,7 @@ | |
| 1 1 | 
             
            # Opensips::Mi
         | 
| 2 | 
            +
            [](https://travis-ci.org/staskobzar/opensips-mi)
         | 
| 3 | 
            +
            [](https://codeclimate.com/github/staskobzar/opensips-mi)
         | 
| 4 | 
            +
            [](http://badge.fury.io/rb/opensips-mi)
         | 
| 2 5 |  | 
| 3 6 | 
             
            OpenSIPs management interface library. 
         | 
| 4 7 | 
             
            This library supports following management interfaces OpenSIPs modules:
         | 
    
        data/lib/opensips/mi/command.rb
    CHANGED
    
    | @@ -87,10 +87,8 @@ module Opensips | |
| 87 87 | 
             
                    headers = hf.map{|name,val| name.eql?("nl") ? "" : "#{name}: #{val}"}.join "\r\n"
         | 
| 88 88 | 
             
                    headers << "\r\n"
         | 
| 89 89 |  | 
| 90 | 
            -
                    # hack for xmlrpc which fails if headers are quoted
         | 
| 91 | 
            -
                     | 
| 92 | 
            -
                    #params = [method, ruri, next_hop, socket, "\"#{headers}\""]
         | 
| 93 | 
            -
                    params = [method, ruri, next_hop, socket, headers]
         | 
| 90 | 
            +
                    # set_header is a hack for xmlrpc which fails if headers are quoted
         | 
| 91 | 
            +
                    params = [method, ruri, next_hop, socket, set_header(headers)]
         | 
| 94 92 | 
             
                    params << body unless body.nil?
         | 
| 95 93 | 
             
                    # send it and return Response
         | 
| 96 94 | 
             
                    command 't_uac_dlg', params
         | 
| @@ -160,7 +158,20 @@ module Opensips | |
| 160 158 | 
             
                    uac_dlg "NOTIFY", uri, hf.merge(mbody)
         | 
| 161 159 | 
             
                  end
         | 
| 162 160 |  | 
| 163 | 
            -
                   | 
| 161 | 
            +
                  private
         | 
| 162 | 
            +
                    def set_header(header);"\"#{header}\"";end
         | 
| 163 | 
            +
             | 
| 164 | 
            +
                    def host_valid? params
         | 
| 165 | 
            +
                      raise ArgumentError,
         | 
| 166 | 
            +
                        'Missing socket host' if params[:host].nil?
         | 
| 167 | 
            +
                      raise ArgumentError,
         | 
| 168 | 
            +
                        'Missing socket port' if params[:port].nil?
         | 
| 169 | 
            +
                      Socket.getaddrinfo(params[:host], nil) rescue 
         | 
| 170 | 
            +
                        raise SocketError, "Invalid host #{params[:host]}" 
         | 
| 171 | 
            +
                      raise SocketError, 
         | 
| 172 | 
            +
                        "Invalid port #{params[:port]}" unless (1..(2**16-1)).include?(params[:port])
         | 
| 173 | 
            +
                      true
         | 
| 174 | 
            +
                    end
         | 
| 164 175 |  | 
| 165 176 | 
             
                end
         | 
| 166 177 | 
             
              end
         | 
| @@ -11,14 +11,7 @@ module Opensips | |
| 11 11 | 
             
                    end
         | 
| 12 12 |  | 
| 13 13 | 
             
                    def initialize(params)
         | 
| 14 | 
            -
                       | 
| 15 | 
            -
                        'Missing socket host' if params[:host].nil?
         | 
| 16 | 
            -
                      raise ArgumentError,
         | 
| 17 | 
            -
                        'Missing socket port' if params[:port].nil?
         | 
| 18 | 
            -
                      Socket.getaddrinfo(params[:host], nil) rescue 
         | 
| 19 | 
            -
                        raise SocketError, "Invalid host #{params[:host]}" 
         | 
| 20 | 
            -
                      raise SocketError, 
         | 
| 21 | 
            -
                        "Invalid port #{params[:port]}" unless (1..(2**16-1)).include?(params[:port])
         | 
| 14 | 
            +
                      host_valid? params
         | 
| 22 15 | 
             
                      @sock = UDPSocket.new
         | 
| 23 16 | 
             
                      @sock.connect params[:host], params[:port]
         | 
| 24 17 | 
             
                    end
         | 
| @@ -10,14 +10,7 @@ module Opensips | |
| 10 10 | 
             
                    end
         | 
| 11 11 |  | 
| 12 12 | 
             
                    def initialize(params)
         | 
| 13 | 
            -
                       | 
| 14 | 
            -
                        'Missing socket host' if params[:host].nil?
         | 
| 15 | 
            -
                      raise ArgumentError,
         | 
| 16 | 
            -
                        'Missing socket port' if params[:port].nil?
         | 
| 17 | 
            -
                      Socket.getaddrinfo(params[:host], nil) rescue 
         | 
| 18 | 
            -
                        raise SocketError, "Invalid host #{params[:host]}" 
         | 
| 19 | 
            -
                      raise SocketError, 
         | 
| 20 | 
            -
                        "Invalid port #{params[:port]}" unless (1..(2**16-1)).include?(params[:port])
         | 
| 13 | 
            +
                      host_valid? params
         | 
| 21 14 | 
             
                      uri = "http://#{params[:host]}:#{params[:port]}/#{RPCSEG}"
         | 
| 22 15 | 
             
                      @client = XMLRPC::Client.new_from_uri(uri, nil, 3)
         | 
| 23 16 | 
             
                    rescue => e
         | 
| @@ -29,10 +22,10 @@ module Opensips | |
| 29 22 | 
             
                      response = ["200 OK"]
         | 
| 30 23 | 
             
                      response += @client.call(cmd, *params).split(?\n)
         | 
| 31 24 | 
             
                      response << ""
         | 
| 32 | 
            -
                      Opensips::MI::Response.new response
         | 
| 33 25 | 
             
                    rescue => e
         | 
| 34 26 | 
             
                      response = ["600 " << e.message]
         | 
| 35 | 
            -
             | 
| 27 | 
            +
                    ensure
         | 
| 28 | 
            +
                      return Opensips::MI::Response.new response
         | 
| 36 29 | 
             
                    end
         | 
| 37 30 |  | 
| 38 31 | 
             
                    def set_header(header);header;end
         | 
    
        data/lib/opensips/mi/version.rb
    CHANGED
    
    
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: opensips-mi
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0.0. | 
| 4 | 
            +
              version: 0.0.3
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Stas Kobzar
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2013-04- | 
| 11 | 
            +
            date: 2013-04-17 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: bundler
         | 
| @@ -114,7 +114,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement | |
| 114 114 | 
             
                  version: '0'
         | 
| 115 115 | 
             
            requirements: []
         | 
| 116 116 | 
             
            rubyforge_project: 
         | 
| 117 | 
            -
            rubygems_version: 2.0. | 
| 117 | 
            +
            rubygems_version: 2.0.2
         | 
| 118 118 | 
             
            signing_key: 
         | 
| 119 119 | 
             
            specification_version: 4
         | 
| 120 120 | 
             
            summary: OpenSIPs management interface
         |