Skip to content
Snippets Groups Projects
  1. Feb 27, 2017
    • Jørgen H's avatar
      res_pjsip: Fix crash when contact has no status · 0595c31d
      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
      0595c31d
  2. Feb 24, 2017
  3. Feb 23, 2017
    • George Joseph's avatar
      pjproject_bundled: Update for pjproject 2.6 · 9c05ddbd
      George Joseph authored
       * Removed all 2.5.5 functional patches.
       * Updated usages of pj_release_pool to be "safe".
       * Updated configure options to disable webrtc.
       * Updated config_site.h to disable webrtc in pjmedia.
       * Added Richard Mudgett's recent resolver patches.
      
      Change-Id: Ib400cc4dfca68b3d07ce14d314e829bfddc252c7
      9c05ddbd
    • George Joseph's avatar
      build: Execute ldconfig to build cache. (take two) · bee55aaf
      George Joseph authored
      On some platforms a multiarch approach is used for libraries.
      The build system does not take this into account and still
      places libraries into the lib directory if no --libdir is
      specified to configure. On initial startup this results in
      libasteriskssl.so not being found, as it is not in the multiarch
      lib directory.  To make matters worse, options were being passed
      to ldconfig on both Linux and FreeBSD that actually prevented
      the rebuild of the cache.
      
       * Fedora has a /usr/share/config.site that automatically tells
         autoconf to use /usr/lib64 but CentOS does not. This logic was
         copied to configure.ac and modified so systems like Ubuntu,
         which still use /usr/lib for 64-bit systems, aren't affected.
      
      Now that we have them in the correct directory...
      
      In order for the system loader to find libasteriskssl and
      libasteriskpj, one of 3 things has to happen...
      
        - The linker cache must be rebuilt including the directory
          where the libasterisk* libraries were installed.  Only root
          can rebuild the cache.  This was busted.
        - We have to link the asterisk binary with an rpath pointing
          to the directrory where the libasterisk* libraries were
          installed.  This makes things very complicated and will happen
          over the collective dead bodies of everyone who's had to
          package a distribution with an rpath.
        - Finally, you can start asterisk with LD_LIBRARY_PATH set to the
          directrory where the libasterisk* libraries were installed.
      
      There are no other options. So...
      
       * The invokation of ldconfig has been moved from main/Makefile
         to ASTTOPDIR/Makefile, the options have been removed, and
         DESTDIR/ASTLIBDIR appended.  If you aren't root, you will be
         warned after the "Asterisk Installation Compete" banner that
         you must re-run 'make install' as root, manually run
         'ldconfig DESTDIR/ASTLIBDIR' as root, or run asterisk with
         LD_LIBRARY_PATH.
      
      ASTERISK-26705
      
      Change-Id: I2a64b7c33a7d3e9bde20f47e3d3ab771977af982
      bee55aaf
    • Sean Bright's avatar
      res_config_pgsql: Fix thread safety problems · da0cadd1
      Sean Bright authored
      * A missing AST_LIST_UNLOCK() in find_table()
      
      * The ESCAPE_STRING() macro uses pgsqlConn under the hood and we were
        not consistently locking before calling it.
      
      * There were a handful of other places where pgsqlConn was accessed
        directly without appropriate locking.
      
      Change-Id: Iea63f0728f76985a01e95b9912c3c5c6065836ed
      da0cadd1
    • Joshua Colp's avatar
  4. Feb 22, 2017
  5. Feb 21, 2017
    • Sean Bright's avatar
      pbx_dundi: DUNDi weight parameter not processed correctly · 0654bf63
      Sean Bright authored
      The DUNDi weight field is not always converted from network byte order
      to host byte order. This can result in incorrect weight values and
      incorrect selection of DUNDi destinations.
      
      ASTERISK-18731 #close
      Reported by: Peter Racz
      Patches:
      	dundi_weight.patch (license #6290) patch uploaded by Peter Racz
      
      Change-Id: Iba3e1a700ff539db57211a7bbc26f7b22ea9a1be
      0654bf63
    • Joshua Colp's avatar
      Merge changes from topic 'ASTERISK-26580' into 13 · ef105410
      Joshua Colp authored
      * changes:
        res_config_ldap: Don't try to delete non-existent attributes
        res_config_ldap: Remove extraneous line numbers from log messages
        res_config_ldap: Make memory allocation more consistent
        res_config_ldap: Fix configuration inheritance from _general
      ef105410
    • zuul's avatar
    • Joshua Colp's avatar
    • Sean Bright's avatar
      realtime: Fix ast_load_realtime_multientry handling · d5522de5
      Sean Bright authored
      ast_load_realtime_multientry() returns an ast_config structure whose
      ast_categorys are keyed with the empty strings. Several modules were
      giving semantic meaning to the category names causing problems at
      runtime.
      
      * app_directory: Treated the category name as the mailbox name, and
        would fail to direct calls to the appropriate extension after an
        entry was chosen.
      
      * app_queue: Queues, queue members, and queue rules were all affected
        and needed to be updated.
      
      * pbx_realtime: Pattern matching would never succeed because the
        extension entered by the user was always compared to the empty
        string.
      
      Change-Id: Ie7e44986344b0b76ea8f6ddb5879f5040c6ca8a7
      d5522de5
    • Sean Bright's avatar
      realtime: Centralize some common realtime backend code · 5eb78752
      Sean Bright authored
      All of the realtime backends create artificial ast_categorys to pass
      back into the core as query results. These categories have no filename
      or line number information associated with them and the backends differ
      slightly on how they create them. So create a couple helper macros to
      help make things more consistent.
      
      Also updated the call sites to remove redundant error messages about
      memory allocation failure.
      
      Note that res_config_ldap sets the category filename to the 'table name'
      but that is not read by anything in the core, so I've dropped it.
      
      Change-Id: I3a1fd91e0c807dea1ce3b643b0a6fe5be9002897
      5eb78752
    • zuul's avatar
      f29ea24d
    • Joshua Colp's avatar
      build: Execute ldconfig to build cache. · d9043095
      Joshua Colp authored
      On some platforms a multiarch approach is used for libraries.
      The build system does not take this into account and still
      places libraries into the lib directory if no --libdir is
      specified to configure. On initial startup this results in
      libasteriskssl.so not being found, as it is not in the multiarch
      lib directory.
      
      This change does the minimally invasive thing and executes
      ldconfig so that the libraries in the lib directory are found
      and their location cached. By doing so Asterisk starts up fine.
      
      If DESTDIR is specified, however, the old logic is executed as
      the install process may not have permission to alter the ldconfig
      cache.
      
      ASTERISK-26705
      
      Change-Id: If4eca46ac510c6fea5568256280ffdb3888d7bb4
      d9043095
    • Richard Mudgett's avatar
      res_pjsip_authenticator_digest.c: Fix sorcery's immutable contract violation. · 3b606093
      Richard Mudgett authored
      The inbound authentication object is supposed to be immutable when it is
      stored in sorcery.  However, the immutable property is violated if the
      authentication object does not have a realm set.
      
      The immutable contract violation has a different effect depending upon
      what sorcery back end is used.  If it is the config file back end you
      would get the same object back until res_pjsip is reloaded.  If it is the
      real-time or AstDB back end you would get a new object on each query.  If
      it is cached you would get the same object back until it is refreshed from
      the database.
      
      Once an inbound authentication object has its realm set it may or may not
      get updated again if the default_realm changes.
      
      If the same authentication object is used for inbound and outbound
      authentication then the immutable violation can make it very hard to
      determine why the outbound authentication now fails.  The only diagnostic
      message is a complaint about no realms matching when it had worked
      earlier.  It fails because of the difference in behaviour for an empty
      realm setting between inbound and outbound authentication objects.
      
      * Fixed the sorcery object immutable violation by creating a new object
      and setting the default_realm on it instead.  The new object is a shallow
      copy for speed.
      
      * The auth_store thread storage no longer holds an auth ref.  It
      interferes with the shallow copy and never needed a ref anyway.
      
      ASTERISK-26799 #close
      
      Change-Id: I2328a52f61b78ed5fbba38180b7f183ee7e08956
      3b606093
    • Richard Mudgett's avatar
      res_pjsip: Update artificial auth whenever default_realm changes. · 6208962b
      Richard Mudgett authored
      There was code attempting to update the artificial authentication object
      whenever the default_realm changed.  However, once the artificial
      authentication object was created it would never get updated.  The
      artificial authentication object would require a system restart for a
      change to the default_realm to take effect.
      
      ASTERISK-26799
      
      Change-Id: Id59036e9529c2d3ed728af2ed904dc36e7094802
      6208962b
    • Richard Mudgett's avatar
      res_pjsip: Update authentication realm documentation. · 9f11da85
      Richard Mudgett authored
      Using the same auth section for inbound and outbound authentication is not
      recommended.  There is a difference in meaning for an empty realm setting
      between inbound and outbound authentication uses.
      
      An empty inbound auth realm represents the global section's default_realm
      value when the authentication object is used to challenge an incoming
      request.  An empty outgoing auth realm is treated as a don't care wildcard
      when the authentication object is used to respond to an incoming
      authentication challenge.
      
      ASTERISK-26799
      
      Change-Id: Id3952f7cfa1b6683b9954f2c5d2352d2f11059ce
      9f11da85
    • zuul's avatar
    • zuul's avatar
  6. Feb 20, 2017
    • Richard Mudgett's avatar
      pjproject: Fixes to resolve DNS SRV crashes. · 47381331
      Richard Mudgett authored
      * Re #1945 (misc): Don't trigger SRV complete callback when there is a
      parse error.
      
      * srv_resolver.c: Don't try to send query if already considered resolved.
      
      ** In resolve_hostnames() don't try to resolve a query that is already
      considered resolved.
      
      ** In resolve_hostnames() fix DNS typo in comments.
      
      ** In build_server_entries() move a common expression assigning to cnt
      earlier.
      
      * sip_transport.c: Fix tdata object name to actually contain the pointer.
      
      It helps if the logs referencing a tdata object buffer actually have a
      name that includes the correct pointer as part of the name.  Also since
      the tdata has its own pool it helps if any logs referencing the pool have
      the same name as the tdata object.  This change brings tdata logging in
      line with how tsx objects are named.
      
      ASTERISK-26669 #close
      ASTERISK-26738 #close
      
      Change-Id: I56af2ded25476b3e870ca586ee69ed6954ef75af
      47381331
    • Richard Mudgett's avatar
      pjsip_distributor.c: Update some debug messages to get transaction name. · d58fdae8
      Richard Mudgett authored
      * Removed overloaded unmatched response ignore.  We obviously sent the
      request so we shouldn't ignore it because it isn't new work.
      
      ASTERISK-26669
      ASTERISK-26738
      
      Change-Id: I55fb5cadc83a8e6699b347c6dc7fa32c5a617d37
      d58fdae8
    • Richard Mudgett's avatar
      res_pjsip: Record the serializer earlier on the tdata. · eb9ae4f7
      Richard Mudgett authored
      When PJPROJECT needs to do a DNS resolution and there is not a cached
      entry available, the SIP request message goes out on the PJSIP monitor
      thread instead of the original serializer thread.  Thus when the response
      comes back it does not get processed by the original sending serializer.
      
      This patch records the serializer on tdata before passing a request
      message to PJPROJECT where it can in Asterisk code.  There are several
      places in PJPROJECT for outbound registration and publishing support that
      would need to record the serializer.  Unfortunately, without replacing the
      PJPROJECT DNS resolver as was done in v14 we cannot fix those without
      modifying PJPROJECT.
      
      Even if we backported the DNS resolver from v14, the outbound registration
      refresh timer does not go out on a serializer thread but the PJSIP monitor
      thread.  Fortunately, Asterisk's outbound publish support doesn't use the
      auto refresh timer that would also not go out under the serializer thread.
      
      This patch is v13 only.
      
      ASTERISK-26669
      ASTERISK-26738
      
      Change-Id: I9997b9ed6dbcebd2c37d6a67dc6dcee9c78914a4
      eb9ae4f7
    • Richard Mudgett's avatar
      pjproject: Increase SENDER_WIDTH column size for 64-bit system logs. · 57f19d6e
      Richard Mudgett authored
      ASTERISK-26669
      ASTERISK-26738
      
      Change-Id: Ibae6fc8cae69a1f04df0c577c4c11200499d6fe0
      57f19d6e
    • zuul's avatar
Loading