Skip to content
Snippets Groups Projects
  1. Apr 04, 2017
    • Richard Mudgett's avatar
      res_pjsip_sdp_rtp.c: Don't alter global addr variable. · f2ee8ac2
      Richard Mudgett authored
      * create_rtp(): Fix unexpected alteration of global address_rtp if a
      transport is bound to an address.
      
      * create_rtp(): Fix use of uninitialized memory if the endpoint RTP media
      address is invalid or the transport has an invalid address.
      
      ASTERISK-26851
      
      Change-Id: Icde42e65164a88913cb5c2601b285eebcff397b7
      f2ee8ac2
  2. Apr 03, 2017
    • Richard Mudgett's avatar
      res_pjsip: Fix transport ref leak. · a889621b
      Richard Mudgett authored
      We were leaking a transport ref in multihomed_on_rx_message() which
      resulted in the FRACK about excessive ref counts.
      
      ASTERISK-26916 #close
      
      Change-Id: I7a96658a9614a060565bb9ad51cb1c9c11ee145f
      a889621b
  3. Apr 01, 2017
  4. Mar 29, 2017
  5. Mar 28, 2017
    • George Joseph's avatar
      res_pjsip_config_wizard: Add 2 new parameters to help with proxy config · 2fe52174
      George Joseph authored
      Two new parameters have been added to the pjsip config wizard.
      
       * Setting 'sends_line_with_registrations' to true will cause the wizard
         to skip the creation of an identify object to match incoming request
         to the endpoint and instead add the line and endpoint parameters to
         the outbound registration object.
      
       * Setting 'outbound_proxy' is a shortcut for adding individual
         endpoint/outbound_proxy, aor/outbound_proxy and
         registration/outbound_proxy parameters.
      
      Change-Id: I678e5f80765734c056620528a6d40d82736ceeb0
      (cherry picked from commit a827892f)
      (cherry picked from commit 27344675)
      2fe52174
  6. Mar 27, 2017
    • Richard Mudgett's avatar
      Add DTLS sanity check. · 3d8899ba
      Richard Mudgett authored
      Change-Id: Ib32612cf6c7ce9213a11b9cba82f630f8cd3564b
      3d8899ba
    • Sean Bright's avatar
      res_musiconhold: Don't chdir() when scanning MoH files · d22c6789
      Sean Bright authored
      There doesn't appear to be any reason that we are chdir'ing in
      moh_scan_files, and in the event of an Asterisk crash, the core files
      may not get written because we have changed into a read-only directory.
      
      ASTERISK-23996 #close
      Reported by: Walter Doekes
      
      Change-Id: Iac806dce01b3335963fbd62d4b4da9a65c614354
      d22c6789
  7. Mar 24, 2017
    • Sean Bright's avatar
      res_xmpp: Use incremental backoff when a read error occurs · d5a8799c
      Sean Bright authored
      If a read error occurs, we immediately attempt a reconnect without any
      delay. Instead, let's sleep and backoff up to 60 seconds before we try
      again.
      
      ASTERISK-24712 #close
      Reported by: Matthias Urlichs
      
      Change-Id: I6fe10ef4734837727437beab715e336777f13f48
      d5a8799c
    • Sean Bright's avatar
      res_pjsip_sdp_rtp: Set hangup cause for RTP timeouts · d08c69a9
      Sean Bright authored
      chan_sip sets the hangup cause code to AST_CAUSE_REQUESTED_CHAN_UNAVAIL
      (44) when a channel is hung up due to an RTP timeout. So do the same
      when it happens with PJSIP for parity.
      
      Change-Id: I3546ebbde6460c22a27c9da1bf321711b5961ab8
      d08c69a9
  8. Mar 23, 2017
    • Sean Bright's avatar
      res_xmpp: Correct implementation of JABBER_STATUS & JabberStatus · 98a88e9f
      Sean Bright authored
      The documentation for JABBER_STATUS (and the deprecated JabberStatus
      app) indicate that a return value of 7 indicates that the specified
      buddy was not in the roster. It also indicates that you can specify a
      "bare" JID (one without a resource). Unfortunately the actual behavior
      does not match the documented behavior.
      
      Assuming that our roster includes the buddy online and available
      "valid@example.org/Valid" and does *not* include the buddy
      "invalid@example.org", the JABBER_STATUS() function returns the
      following before this patch:
      
      +------------------------------+------------+--------------------------+
      | Buddy                        | Status     | Result                   |
      +------------------------------+------------+--------------------------+
      | valid@example.org            |  Online    |  7 (Not in roster)       |
      | valid@example.org/Valid      |  Online    |  1 (Online)              |
      | valid@example.org/Invalid    |  N/A       |  7 (Not in roster)       |
      | invalid@example.org          |  N/A       |  Error logged, no return |
      | invalid@example.org/Valid    |  N/A       |  Error logged, no return |
      +------------------------------+------------+--------------------------+
      
      And after this patch:
      
      +------------------------------+------------+--------------------------+
      | Buddy                        | Status     | Result                   |
      +------------------------------+------------+--------------------------+
      | valid@example.org            |  Online    |  1 (Online)              |
      | valid@example.org/Valid      |  Online    |  1 (Online)              |
      | valid@example.org/Invalid    |  N/A       |  6 (Offline)             |
      | invalid@example.org          |  N/A       |  7 (Not in roster)       |
      | invalid@example.org/Valid    |  N/A       |  7 (Not in roster)       |
      +------------------------------+------------+--------------------------+
      
      This brings the behavior in line with the documentation.
      
      ASTERISK-23510 #close
      Reported by: Anthony Critelli
      
      Change-Id: I9c3241035363ef4a6bdc21fabfd8ffcd9ec657bf
      98a88e9f
    • Sean Bright's avatar
      res_xmpp: Try to provide useful errors messages from OpenSSL · be94105d
      Sean Bright authored
      If any errors occur during the TLS connection setup, we currently dump a
      fairly generic error message. So instead we try to pull in something
      useful from OpenSSL to report instead.
      
      ASTERISK-24712
      Reported by: Matthias Urlichs
      
      Change-Id: I288500991a9681f447d92913b11fedaf426087f4
      be94105d
    • Sean Bright's avatar
      res_xmpp: Fix ref counting issue · ee81ee1f
      Sean Bright authored
      The only remaining reference to the endpoint is in the endpoints
      container, and because it is unlinked in ast_endpoint_shutdown, we don't
      have to explicitly cleanup the endpoint ourselves.
      
      Change-Id: I912a2692e52d3e2ed445b32d8ae3f9004bc2f2e8
      ee81ee1f
    • Sean Bright's avatar
      res_xmpp: Correctly check return value of SSL_connect · 94939814
      Sean Bright authored
      SSL_connect returns non-zero for both success and some error conditions
      so simply negating is inadequate.
      
      Change-Id: Ifbf882896e598703b6c615407fa456d3199f95b1
      94939814
    • Sean Bright's avatar
      res_xmpp: Don't crash when trying to send a message without a connection · 7657c279
      Sean Bright authored
      If we never establish a connection to our Jabber server, iksemel never sets up
      its internal transport pointer, so attempting to send a message dereferences a
      NULL pointer and causes a crash.
      
      ASTERISK-21855 #close
      Reported by: Jeremy Kister
      
      Change-Id: I204a568894e4a53ab929783ecc594a000f04d79c
      7657c279
    • Sean Bright's avatar
      res_xmpp: Include client name in connection related error messages · 0136ec12
      Sean Bright authored
      ASTERISK-25622 #close
      Reported by: Sean Darcy
      
      Change-Id: I8472cb7bfb58d411a3cfbd482da98cae2d94d1e9
      0136ec12
  9. Mar 22, 2017
    • Richard Begg's avatar
      res_pjsip_session: Enable RFC3578 overlap dialing support. · 6b7697ed
      Richard Begg authored
      Support for RFC3578 overlap dialling (i.e. 484 Response to partially matched
      destinations) as currently provided by chan_sip is missing from res_pjsip.
      This patch adds a new endpoint attribute (allow_overlap) [defaults to yes]
      which when set to yes enables 484 responses to partial destination
      matches rather than the current 404.
      
      ASTERISK-26864
      
      Change-Id: Iea444da3ee7c7d4f1fde1d01d138a3d7b0fe40f6
      6b7697ed
  10. Mar 21, 2017
    • Sean Bright's avatar
      res_hep: Capture actual transport type in use · d4fcf196
      Sean Bright authored
      Rather than hard-coding UDP, allow consumers of the HEP API to specify
      which protocol is in use. Update the PJSIP provider to pass in the
      current protocol type.
      
      ASTERISK-26850 #close
      
      Change-Id: I54bbb0a001cfe4c6a87ad4b6f2014af233349978
      d4fcf196
    • Sean Bright's avatar
      res_pjsip_messaging: Check URI type before dereferencing · 6b4b8778
      Sean Bright authored
      We aren't validating that the URI we just parsed is a SIP/SIPS one before
      trying to access the user, host, and port members of a possibly uninitialized
      structure.
      
      Also update the MessageSend documentation to indicate what 'from' formats are
      accepted.
      
      ASTERISK-26484 #close
      Reported by: Vinod Dharashive
      
      Change-Id: I476b5cc5f18a7713d0ee945374f2a1c164857d30
      6b4b8778
  11. Mar 19, 2017
  12. Mar 16, 2017
    • Richard Mudgett's avatar
      res_pjsip_asterisk.c: Fix compile error if libsrtp is not installed. · 82982a19
      Richard Mudgett authored
      struct ast_rtcp does not define the dtls member if SRTP is not enabled.
      
      ASTERISK-26732
      
      Change-Id: Id15ea212e04490e012f2cf4a56818b4dd948875e
      82982a19
    • Richard Mudgett's avatar
      res_pjsip_sdp_rtp.c: Fix cut-n-paste error · 49b1f1ca
      Richard Mudgett authored
      We were inadvertenly referencing the cos_video option to determine if we
      should set the tos_audio and cos_audio value on the RTP instance.
      
      Change-Id: Ia7964f486801d39dc6f5dae570baff079e1595b0
      49b1f1ca
    • Matt Jordan's avatar
      res/res_pjsip_session: Only check localnet if it is defined · e6dc28b7
      Matt Jordan authored
      If local_net is not defined on a transport, transport_state->localnet
      will be NULL. ast_apply_ha will, be default, return AST_SENSE_ALLOW in
      this case, causing the external_media_address, if set, to be skipped.
      
      This patch causes us to only check if we are sending within a network if
      local_net is defined.
      
      ASTERISK-26879 #close
      
      Change-Id: Ib661c31a954cabc9c99f1f25c9c9a5c5b82cbbfb
      e6dc28b7
    • Richard Begg's avatar
      res_pjsip_sdp_rtp: RTP instance does not use same IP as explicit transport · 44568fc7
      Richard Begg authored
      Currently a wildcard address is used for the local RTP socket, which
      will not always result in the same address as used by the SIP socket
      (e.g. if explicit transport addresses are configured).
      Use the transport's host address when binding new local RTP sockets if
      available.
      
      ASTERISK-26851
      
      Change-Id: I098c29c9d1f79a4f970d72ba894874ac75954f1a
      44568fc7
    • George Joseph's avatar
      res_pjsip: Symmetric transports · 5013d8f5
      George Joseph authored
      A new transport parameter 'symmetric_transport' has been added.
      
      When a request from a dynamic contact comes in on a transport with
      this option set to 'yes', the transport name will be saved and used
      for subsequent outgoing requests like OPTIONS, NOTIFY and INVITE.
      It's saved as a contact uri parameter named 'x-ast-txp' and will
      display with the contact uri in CLI, AMI, and ARI output.  On the
      outgoing request, if a transport wasn't explicitly set on the
      endpoint AND the request URI is not a hostname, the saved transport
      will be used and the 'x-ast-txp' parameter stripped from the
      outgoing packet.
      
      * config_transport was modified to accept and store the new parameter.
      
      * config_transport/transport_apply was updated to store the transport
        name in the pjsip_transport->info field using the pjsip_transport->pool
        on UDP transports.
      
      * A 'multihomed_on_rx_message' function was added to
        pjsip_message_ip_updater that, for incoming requests, retrieves the
        transport name from pjsip_transport->info and retrieves the transport.
        If transport->symmetric_transport is set, an 'x-ast-txp' uri parameter
        containing the transport name is added to the incoming Contact header.
      
      * An 'ast_sip_get_transport_name' function was added to res_pjsip.
        It takes an ast_sip_endpoint and a pjsip_sip_uri and returns a
        transport name if endpoint->transport is set or if there's an
        'x-ast-txp' parameter on the uri and the uri host is an ipv4 or
        ipv6 address.  Otherwise it returns NULL.
      
      * An 'ast_sip_dlg_set_transport' function was added to res_pjsip
        which takes an ast_sip_endpoint, a pjsip_dialog, and an optional
        pjsip_tpselector.  It calls ast_sip_get_transport_name() and if
        a non-NULL is returned, sets the selector and sets the transport
        on the dialog.  If a selector was passed in, it's updated.
      
      * res_pjsip/ast_sip_create_dialog_uac and ast_sip_create_dialog_uas
        were modified to call ast_sip_dlg_set_transport() instead of their
        original logic.
      
      * res_pjsip/create_out_of_dialog_request was modified to call
        ast_sip_get_transport_name() and pjsip_tx_data_set_transport()
        instead of its original logic.
      
      * Existing transport logic was removed from endpt_send_request
        since that can only be called after a create_out_of_dialog_request.
      
      * res_pjsip/ast_sip_create_rdata was converted to a wrapper around
        a new 'ast_sip_create_rdata_with_contact' function which allows
        a contact_uri to be specified in addition to the existing
        parameters.  (See below)
      
      * res_pjsip_pubsub/internal_pjsip_evsub_send_request was eliminated
        since all it did was transport selection and that is now done in
        ast_sip_create_dialog_uac and ast_sip_create_dialog_uas.
      
      * 'contact_uri' was added to subscription_persistence.  This was
        necessary because although the parsed rdata contact header has the
        x-ast-txp parameter added (if appropriate),
        subscription_persistence_update stores the raw packet which
        doesn't have it.  subscription_persistence_recreate was then
        updated to call ast_sip_create_rdata_with_contact with the
        persisted contact_uri so the recreated subscription has the
        correct transport info to send the NOTIFYs.
      
      * res_pjsip_session/internal_pjsip_inv_send_msg was eliminated since
        all it did was transport selection and that is now done in
        ast_sip_create_dialog_uac.
      
      * pjsip_message_ip_updater/multihomed_on_tx_message was updated
        to remove all traces of the x-ast-txp parameter from the
        outgoing headers.
      
      NOTE:  This change does NOT modify the behavior of permanent
      contacts specified on an aor.  To do so would require that the
      permanent contact's contact uri be updated with the x-ast-txp
      parameter and the aor sorcery object updated.  If we need to
      persue this, we need to think about cloning permanent contacts into
      the same store as the dynamic ones on an aor load so they can be
      updated without disturbing the originally configured value.
      
      You CAN add the x-ast-txp parameter to a permanent contact's uri
      but it would be much simpler to just set endpoint->transport.
      
      Change-Id: I4ee1f51473da32ca54b877cd158523efcef9655f
      5013d8f5
    • Joshua Colp's avatar
      res_rtp_asterisk: Fix crash when RTCP is not present when DTLS is stopped. · 68749a9f
      Joshua Colp authored
      This change removes an assumption that when DTLS is stopped
      an RTCP session will be present on the RTP session. This is not
      always the case.
      
      ASTERISK-26732
      
      Change-Id: Ib9f7c09ce0b005efe362dbcc8795202b18f94611
      68749a9f
  13. Mar 15, 2017
    • Mark Michelson's avatar
      Add rtcp-mux support · 10fa49e3
      Mark Michelson authored
      This commit adds support for RFC 5761: Multiplexing RTP Data and Control
      Packets on a Single Port. Specifically, it enables the feature when
      using chan_pjsip.
      
      A new option, "rtcp_mux" has been added to endpoint configuration in
      pjsip.conf. If set, then Asterisk will attempt to use rtcp-mux with
      whatever it communicates with. Asterisk follows the rules set forth in
      RFC 5761 with regards to falling back to standard RTCP behavior if the
      far end does not indicate support for rtcp-mux.
      
      The lion's share of the changes in this commit are in
      res_rtp_asterisk.c. This is because it was pretty much hard wired to
      have an RTP and an RTCP transport. The strategy used here is that when
      rtcp-mux is enabled, the current RTCP transport and its trappings (such
      as DTLS SSL session) are freed, and the RTCP session instead just
      mooches off the RTP session. This leads to a lot of specialized if
      statements throughout.
      
      ASTERISK-26732 #close
      Reported by Dan Jenkins
      
      Change-Id: If46a93ba1282418d2803e3fd7869374da8b77ab5
      10fa49e3
    • Torrey Searle's avatar
      res/res_pjsip_refer: call xfer w/o extension · dc4cdafd
      Torrey Searle authored
      When transfering to a URI without an extension, ensure that the
      s extension of the dialplan is entered
      
      ASTERISK-26869 #close
      
      Change-Id: I07403df66cf93f09e00a40ab5b41bfc6f72b1525
      dc4cdafd
    • Joshua Colp's avatar
      res_pjsip_endpoint_identifier_ip: Don't output error if no header_match. · 0b8a57af
      Joshua Colp authored
      This change ensures that if no header_match option is set on an
      identify an error message is not output stating the option is set
      to an invalid value.
      
      ASTERISK-26863
      
      Change-Id: I239bc6d2319dd3da24ba96a38d4d6e9b5526d62a
      0b8a57af
    • Matt Jordan's avatar
      res_pjsip_endpoint_identifier_ip: Add an option to match requests by header · 1475604e
      Matt Jordan authored
      This patch adds a new features to the endpoint identifier module,
      'match_header'. When set, inbound requests are matched by a provided SIP
      header: value pair. This option works in conjunction with the existing
      'match' configuration option, such that if any 'match*' attribute
      matches an inbound request, the request is associated with the specified
      endpoint.
      
      Since this module now identifies by more than just IP address,
      appropriate renaming of the module and/or variables can be done in a
      non-release branch.
      
      ASTERISK-26863 #close
      
      Change-Id: Icfc14835c962f92e35e67bbdb235cf0589de5453
      (cherry picked from commit 30f52d79)
      1475604e
  14. Mar 14, 2017
    • George Joseph's avatar
      RFC sdp: Initial SDP creation · 8470c2bd
      George Joseph authored
      * Added additional fields to ast_sdp_options.
      * Re-organized ast_sdp.
      * Updated field names to correspond to RFC4566 terminology.
      * Created allocs/frees for SDP children.
      * Created getters/setters for SDP children where appropriate.
      * Added ast_sdp_create_from_state.
      * Refactored res_sdp_translator_pjmedia for changes.
      
      Change-Id: Iefbd877af7f5a4d3c74deead1bff8802661b0d48
      8470c2bd
    • Matt Jordan's avatar
      res_pjsip_endpoint_identifier_ip: Clean up a spaces/tabs issue · 2d7e68c0
      Matt Jordan authored
      Tabs > spaces. Always.
      
      Change-Id: I899ff662361c7ab0327173bd7851a67b53dd65f1
      2d7e68c0
  15. Mar 09, 2017
  16. Mar 08, 2017
    • Joshua Colp's avatar
      res_pjsip_transport_websocket: Add support for IPv6. · 4e3b0ced
      Joshua Colp authored
      This change adds a PJSIP patch (which has been contributed upstream)
      to allow the registration of IPv6 transport types.
      
      Using this the res_pjsip_transport_websocket module now registers
      an IPv6 Websocket transport and uses it for the corresponding
      traffic.
      
      ASTERISK-26685
      
      Change-Id: Id1f9126f995b31dc38db8fdb58afd289b4ad1647
      4e3b0ced
  17. Mar 07, 2017
    • Mark Michelson's avatar
      res_http_websocket: Fix faulty read logic. · 5d0371d7
      Mark Michelson authored
      When doing some WebRTC testing, I found that the websocket would
      disconnect whenever I attempted to place a call into Asterisk. After
      looking into it, I pinpointed the problem to be due to the iostreams
      change being merged in.
      
      Under certain circumstances, a call to ast_iostream_read() can return a
      negative value. However, in this circumstance, the websocket code was
      treating this negative return as if it were a partial read from the
      websocket. The expected length would get adjusted by this negative
      value, resulting in the expected length being too large.
      
      This patch simply adds an if check to be sure that we are only updating
      the expected length of a read when the return from a read is positive.
      
      ASTERISK-26842 #close
      Reported by Mark Michelson
      
      Change-Id: Ib4423239828a013d27d7bc477d317d2f02db61ab
      5d0371d7
  18. Mar 01, 2017
    • Jørgen H's avatar
      res_pjsip WebRTC/websockets: Fix usage of WS vs WSS. · 7922f26c
      Jørgen H authored
      According to the RFC[1] WSS should only be used in the Via header
      for secure Websockets.
      
      * Use WSS in Via for secure transport.
      
      * Only register one transport with the WS name because it would be
      ambiguous.  Outgoing requests may try to find the transport by name and
      pjproject only finds the first one registered.  This may mess up unsecure
      websockets but the impact should be minimal.  Firefox and Chrome do not
      support anything other than secure websockets anymore.
      
      * Added and updated some debug messages concerning websockets.
      
      * security_events.c: Relax case restriction when determining security
      transport type.
      
      * The res_pjsip_nat module has been updated to not touch the transport
      on Websocket originating messages.
      
      [1] https://tools.ietf.org/html/rfc7118
      
      ASTERISK-26796 #close
      
      Change-Id: Ie3a0fb1a41101a4c1e49d875a8aa87b189e7ab12
      7922f26c
    • Sean Bright's avatar
      res_config_pgsql: Make 'require' return consistent with other backends · 1dacf317
      Sean Bright authored
      res_config_pgsql should match the behavior of other realtime backend
      drivers so that queue_log can disable adaptive logging.
      
      ASTERISK-25628 #close
      Reported by: Dmitry Wagin
      
      Change-Id: Ic1fb1600c7ce10fdfb1bcdc43c5576b7e0014372
      1dacf317
  19. Feb 28, 2017
  20. Feb 27, 2017
    • Jørgen H's avatar
      res_pjsip: Fix crash when contact has no status · ee0a123f
      Jørgen H authored
      This change fixes an assumption in res_pjsip that a contact will
      always have a status. There is a race condition where this is
      not true and would crash. The status will now be unknown when
      this situation occurs.
      
      ASTERISK-26623 #close
      
      Change-Id: Id52d3ca4d788562d236da49990a319118f8d22b5
      ee0a123f
    • George Joseph's avatar
      res_pjsip_outbound_registration: Subscribe to network change events · 22242fef
      George Joseph authored
      Outbound registration now subscribes to network change events
      published by res_stun_monitor and refreshes all registrations
      when an event happens.
      
      The 'pjsip send (un)register' CLI commands were updated to accept
      '*all' as an argument to operate on all registrations.
      
      The 'PJSIP(Un)Register' AMI commands were also updated to
      accept '*all'.
      
      ASTERISK-26808 #close
      
      Change-Id: Iad58a9e0aa5d340477fca200bf293187a6ca5a25
      22242fef
Loading