Skip to content
Snippets Groups Projects
  1. Feb 22, 2017
    • Sean Bright's avatar
      res_config_ldap: Various code improvements · e57961db
      Sean Bright authored
      The initial motivation for this patch was to properly handle memory
      allocation failures - we weren't checking the return values from the
      various LDAP library allocation functions.
      
      In the process, because update_ldap() and update2_ldap() were
      substantially the same code, they've been consolidated.
      
      Change-Id: Iebcfe404177cc6860ee5087976fe97812221b822
      e57961db
  2. Feb 21, 2017
    • Sean Bright's avatar
      realtime: Centralize some common realtime backend code · 6e6c96d7
      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
      6e6c96d7
    • Richard Mudgett's avatar
      res_pjsip_authenticator_digest.c: Fix sorcery's immutable contract violation. · 6f15500c
      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
      6f15500c
    • Richard Mudgett's avatar
      res_pjsip: Update artificial auth whenever default_realm changes. · 6400f5f3
      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
      6400f5f3
    • Richard Mudgett's avatar
      res_pjsip: Update authentication realm documentation. · 0b660c99
      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
      0b660c99
  3. Feb 20, 2017
    • Richard Mudgett's avatar
      pjsip_distributor.c: Update some debug messages to get transaction name. · 54812f18
      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
      54812f18
    • George Joseph's avatar
      pjproject cli: Add object count after object lists · ffa7d697
      George Joseph authored
      When listing a container, we now print the number of objects
      in the container at the end of the list.
      
      Change-Id: I791cbc3ee9da9a2af9adc655164b5d32953df812
      ffa7d697
    • Sean Bright's avatar
      res_config_ldap: Don't try to delete non-existent attributes · e84353b8
      Sean Bright authored
      OpenLDAP will raise an error when we try to delete an LDAP attribute
      that doesn't exist. We need to filter out LDAP_MOD_DELETE requests
      based on which attributes the current LDAP entry actually has. There
      is of course a small window of opportunity for this to still fail,
      but it is much less likely now.
      
      Change-Id: I3fe1b04472733e43151563aaf9f8b49980273e6b
      e84353b8
    • Sean Bright's avatar
      res_config_ldap: Remove extraneous line numbers from log messages · 9f392574
      Sean Bright authored
      Extraneous line numbers were being output in many log messages. These
      have been removed.
      
      Change-Id: Ice9efa3d252ee87f37fa8f5ea852fda482675431
      9f392574
    • Sean Bright's avatar
      res_config_ldap: Make memory allocation more consistent · ef094439
      Sean Bright authored
      The code in update_ldap() and update2_ldap() was using both Asterisk's
      memory allocation routines as well as OpenLDAP's. I've changed it so
      that everything that is passed to OpenLDAP's functions are allocated
      with their routines.
      
      Change-Id: Iafec9c1fd8ea49ccc496d6316769a6a426daa804
      ef094439
    • Sean Bright's avatar
      res_config_ldap: Fix configuration inheritance from _general · dd3efdf5
      Sean Bright authored
      The "_general" configuration section allows administrators to provide
      both general configuration options (host, port, url, etc.) as well as a
      global realtime-to-LDAP-attribute mapping that is a fallback if one of
      the later sections do not override it. This neglected to exclude the
      general configuration options from the mapping. As an example, during
      my testing, chan_sip requested 'port' from realtime, and because I did
      not have it defined, it pulled in the 'port' configuration option from
      "_general." We now filter those out explicitly.
      
      Change-Id: I1fc61560bf96b8ba623063cfb7e0a49c4690d778
      dd3efdf5
    • Sean Bright's avatar
      res_config_ldap: Fix erroneous LDAP_MOD_REPLACE in LDAP modify · d6d86f1c
      Sean Bright authored
      We always treat the first change of our modification batch as a
      replacement when it sometimes is actually a delete. So we have to pass
      the correct arguments to the OpenLDAP library.
      
      ASTERISK-26580 #close
      Reported by: Nicholas John Koch
      Patches:
      	res_config_ldap.c-11.24.1.patch (license #6833) patch uploaded
      	by Nicholas John Koch
      
      Change-Id: I0741d25de07c9539f1edc6eff3696165dfb64fbe
      d6d86f1c
  4. Feb 18, 2017
  5. Feb 17, 2017
    • Mark Michelson's avatar
      Add SDP translator and PJMEDIA implementation. · 5a130b2e
      Mark Michelson authored
      This creates the following:
      * Asterisk's internal representation of an SDP
      * An API for translating SDPs from one format to another
      * An implementation of a translator for PJMEDIA
      
      Change-Id: Ie2ecd3cbebe76756577be9b133e84d2ee356d46b
      5a130b2e
  6. Feb 16, 2017
    • Sean Bright's avatar
      realtime: Fix LIKE escaping in SQL backends · e93f2a51
      Sean Bright authored
      The realtime framework allows for components to look up values using a
      LIKE clause with similar syntax to SQL's. pbx_realtime uses this
      functionality to search for pattern matching extensions that start with
      an underscore (_).
      
      When passing an underscore to SQL's LIKE clause, it will be interpreted
      as a wildcard matching a single character and therefore needs to be
      escaped. It is (for better or for worse) the responsibility of the
      component that is querying realtime to escape it with a backslash before
      passing it in. Some RDBMs support escape characters by default, but the
      SQL92 standard explicitly says that there are no escape characters
      unless they are specified with an ESCAPE clause, e.g.
      
      	SELECT * FROM table WHERE column LIKE '\_%' ESCAPE '\'
      
      This patch instructs 3 backends - res_config_mysql, res_config_pgsql,
      and res_config_sqlite3 - to use the ESCAPE clause where appropriate.
      
      Looking through documentation and source tarballs, I was able to
      determine that the ESCAPE clause is supported in:
      
      MySQL 5.0.15   (released 2005-10-22 - earliest version available from
                      archives)
      PostgreSQL 7.1 (released 2001-04-13)
      SQLite 3.1.0   (released 2005-01-21)
      
      The versions of the relevant libraries that we depend on to access MySQL
      and PostgreSQL will not work on versions that old, and I've added an
      explicit check in res_config_sqlite3 to only use the ESCAPE clause when
      we have a sufficiently new version of SQLite3.
      
      res_config_odbc already handles the escape characters appropriately, so
      no changes were required there.
      
      ASTERISK-15858 #close
      Reported by: Humberto Figuera
      
      ASTERISK-26057 #close
      Reported by: Stepan
      
      Change-Id: I93117fbb874189ae819f4a31222df7c82cd20efa
      e93f2a51
    • Sean Bright's avatar
      res_config_sqlite3: Properly create missing columns when necessary · 30aaeec5
      Sean Bright authored
      There were two specific issues resolved here:
      
      1) The code that iterated over the required fields
         (via ast_realtime_require) was broken for the RQ_INTEGER1 field
         type. Iteration would stop when the first RQ_INTEGER1 (0) field
         was encountered.
      
      2) sqlite3_changes() was used to try and count the number of rows
         returned by a SELECT statement. sqlite3_changes() only counts
         affected rows, so this was always returning the value from the
         most recent data modification statement. We now separate read-only
         queries from data modification queries and count rows appropriately
         in both cases.
      
      ASTERISK-23457 #close
      Reported by: Scott Griepentrog
      
      Change-Id: I91ed20494efc3fcfbc2a96ac7646999a49814884
      30aaeec5
  7. Feb 15, 2017
    • George Joseph's avatar
      res_pjsip_pubsub: Correctly implement persisted subscriptions · 4bdf5d32
      George Joseph authored
      This patch fixes 2 original issues and more that those 2 exposed.
      
      * When we send a NOTIFY, and the client either doesn't respond or
        responds with a non OK, pjproject only calls our
        pubsub_on_evsub_state callback, no others.  Since
        pubsub_on_evsub_state (which does the sub_tree cleanup) does not
        expect to be called back without the other callbacks being called
        first, it just returns leaving the sub_tree orphaned.  Now
        pubsub_on_evsub_state checks the event for PJSIP_EVENT_TSX_STATE
        which is what pjproject will set to tell us that it was the
        transaction that timed out or failed and not the subscription
        itself timing our or being terminated by the client. If is
        TSX_STATE, pubsub_on_evsub_state now does the proper cleanup
        regardless of the state of the subscription.
      
      * When a client renews a subscription, we don't update the
        persisted subscription with the new expires timestamp.  This causes
        subscription_persistence_recreate to prune the subscription if/when
        asterisk restarts.  Now, pubsub_on_rx_refresh calls
        subscription_persistence_update to apply the new expires timestamp.
        This exposed other issues however...
      
      * When creating a dialog from rdata (which sub_persistence_recreate
        does from the packet buffer) there must NOT be a tag on the To
        header (which there will be when a client refreshes a
        subscription).  If there is one, pjsip_dlg_create_uas will fail.
        To address this, subscription_persistence_update now accepts a flag
        that indicates that the original packet buffer must not be updated.
        New subscribes don't set the flag and renews do.  This makes sure
        that when the rdata is recreated on asterisk startup, it's done
        from the original subscribe packet which won't have the tag on To.
      
      * When creating a dialog from rdata, we were setting the dialog's
        remote (SUBSCRIBE) cseq to be the same as the local (NOTIFY) cseq.
        When the client tried to resubscribe after a restart with the
        correct cseq, we'd reject the request with an Invalid CSeq error.
      
      * The acts of creating a dialog and evsub by themselves when
        recreating a subscription does NOT restart pjproject's subscription
        timer.  The result was that even if we did correctly recreate the
        subscription, we never removed it if the client happened to go away
        or send a non-OK response to a NOTIFY.  However, there is no
        pjproject function exposed to just set the timer on an evsub that
        wasn't created by an incoming subscribe request.  To address this,
        we create our own timer using ast_sip_schedule_task.  This timer is
        used only for re-establishing subscriptions after a restart.
      
        An earlier approach was to add support for setting pjproject's
        timer (via a pjproject patch) and while that patch is still included
        here, we don't use that call at the moment.
      
      While addressing these issues, additional debugging was added and
      some existing messages made more useful.  A few formatting changes
      were also made to 'pjsip show scheduled tasks' to make displaying
      the subscription timers a little more friendly.
      
      ASTERISK-26696
      ASTERISK-26756
      
      Change-Id: I8c605fc1e3923f466a74db087d5ab6f90abce68e
      4bdf5d32
    • Sean Bright's avatar
      res_rtp_asterisk: Use PJ_ICE_MAX_CAND instead of hard-coding 16 · 11886dea
      Sean Bright authored
      pjsip limits the total number of ICE candidates to PJ_ICE_MAX_CAND,
      which is a compile-time constant. Instead of hard-coding 16 when we
      enumerate local interfaces, use PJ_ICE_MAX_CAND so that we can
      potentially collect more interfaces if the compile time options are
      changed.
      
      Tangentially related to ASTERISK~24464
      
      Change-Id: I1b85509e39e33b1fed63c86261fc229ba14bbabd
      11886dea
  8. Feb 13, 2017
    • Sean Bright's avatar
      cli: Fix various CLI documentation and completion issues · 3f943737
      Sean Bright authored
      * app_minivm: Use built-in completion facilities to complete optional
      arguments.
      
      * app_voicemail: Use built-in completion facilities to complete
      optional arguments.
      
      * app_confbridge: Add missing colons after 'Usage' text.
      
      * chan_alsa: Use built-in completion facilities to complete optional
      arguments.
      
      * chan_sip: Use built-in completion facilities to complete optional
      arguments. Add completions for 'load' for 'sip show user', 'sip show
      peer', and 'sip qualify peer.'
      
      * chan_skinny: Correct and extend completions for 'skinny reset' and
      'skinny show line.'
      
      * func_odbc: Correct completions for 'odbc read' and 'odbc write'
      
      * main/astmm: Use built-in completion facilities to complete arguments
      for 'memory' commands.
      
      * main/bridge: Correct completions for 'bridge kick.'
      
      * main/ccss: Use built-in completion facilities to complete arguments
      for 'cc cancel' command.
      
      * main/cli: Add 'all' completion for 'channel request hangup.' Correct
      completions for 'core set debug channel.' Correct completions for 'core
      show calls.'
      
      * main/pbx_app: Remove redundant completions for 'core show
      applications.'
      
      * main/pbx_hangup_handler: Remove unused completions for 'core show
      hanguphandlers all.'
      
      * res_sorcery_memory_cache: Add completion for 'reload' argument of
      'sorcery memory cache stale' and properly implement.
      
      Change-Id: Iee58c7392f6fec34ad9d596109117af87697bbca
      3f943737
    • George Joseph's avatar
      stream: Add media stream topology definition and API · 8b72ec31
      George Joseph authored
      This change adds the media stream topology definition and API for
      accessing and using it.
      
      Some refactoring of the stream was also done.
      
      ASTERISK-26786
      
      Change-Id: Ic930232d24d5ad66dcabc14e9b359e0ff8e7f568
      8b72ec31
  9. Feb 12, 2017
  10. Feb 10, 2017
    • Sean Bright's avatar
      manager: Restore Originate failure behavior from Asterisk 11 · 09107730
      Sean Bright authored
      In Asterisk 11, if the 'Originate' AMI command failed to connect the provided
      Channel while in extension mode, a 'failed' extension would be looked up and
      run. This was, I believe, unintentionally removed in 51b6c496. This patch
      restores that behavior.
      
      This also adds an enum for the various 'synchronous' modes in an attempt to
      make them meaningful.
      
      ASTERISK-26115 #close
      Reported by: Nasir Iqbal
      
      Change-Id: I8afbd06725e99610e02adb529137d4800c05345d
      09107730
  11. Feb 08, 2017
  12. Feb 07, 2017
    • Joshua Colp's avatar
      res_stasis_device_state: Protect the adding/removing of subscriptions. · b79cc620
      Joshua Colp authored
      The adding and removing of device state subscriptions did not protect
      fully against simultaneous manipulation. In particular the subscribe
      case allowed a small window where two subscriptions could be added for
      the same device state instead of just one.
      
      This change makes the code hold the subscriptions lock for the entirety
      of each operation to ensure that two are not occurring at the same time.
      
      ASTERISK-26770
      
      Change-Id: I3e7f8eb9d09de440c9024d2dd52029f6f20e725b
      b79cc620
  13. Feb 06, 2017
  14. Feb 02, 2017
    • Richard Mudgett's avatar
      res_agi: Prevent an AGI from eating frames it should not. (Re-do) · 97c30847
      Richard Mudgett authored
      A dialplan intercept routine is equivalent to an interrupt routine.  As
      such, the routine must be done quickly and you do not have access to the
      media stream.  These restrictions are necessary because the media stream
      is the responsibility of some other code and interfering with or delaying
      that processing is bad.  A possible future dialplan processing
      architecture change may allow the interception routine to run in a
      different thread from the main thread handling the media and remove the
      execution time restriction.
      
      * Made res_agi.c:run_agi() running an AGI in an interception routine run
      in DeadAGI mode.  No touchy channel frames.
      
      ASTERISK-25951
      
      ASTERISK-26343
      
      ASTERISK-26716
      
      Change-Id: I638f147ca7a7f2590d7194a8ef4090eb191e4e43
      97c30847
  15. Feb 01, 2017
    • Richard Mudgett's avatar
      res_resolver_unbound.c: Fix frequent ref leak caught by excessive ref trap. · 7d9b50a7
      Richard Mudgett authored
      ASTERISK-26765
      
      Change-Id: I27eb97df7f8d7e624b0b9a61c0fcee4718c86d8d
      7d9b50a7
    • Mark Michelson's avatar
      Update qualifies when AOR configuration changes. · bbed75c3
      Mark Michelson authored
      Prior to this change, qualifies would only update in the following
      cases:
      * A reload of res_pjsip.so was issued.
      * A dynamic contact was re-registered after its AOR's qualify_frequency
        had been changed
      This does not work well if you are using realtime for your AORs. You can
      update your database to have a new qualify_frequency, but the permanent
      contacts on that AOR will not have their qualifies updated. And the
      dynamic contacts on that AOR will not have their qualifies updated until
      the next registration, which could be a long time.
      
      This change seeks to fix this problem by making it so that whenever AOR
      configuration is applied, the contacts pertaining to that AOR have their
      qualifies updated.
      
      Additions from this patch:
      * AOR sorcery objects now have an apply handler that calls into a newly
        added function in the OPTIONS code. This causes all contacts
        associated with that AOR to re-schedule qualifies.
      * When it is time to qualify a contact, the OPTIONS code checks to see
        if the AOR can still be retrieved. If not, then qualification is
        canceled on the contact.
      
      Alterations from this patch:
      * The registrar code no longer updates contact's qualify_frequence and
        qualify_timeout. There is no point to this since those values already
        get updated when the AOR changes.
      * Reloading res_pjsip.so no longer calls the OPTIONS initialization
        function. Reloading res_pjsip.so results in re-loading AORs, which
        results in re-scheduling qualifies.
      
      Change-Id: I2e7c3316da28f389c45954f24c4e9389abac1121
      bbed75c3
    • Joshua Colp's avatar
      res_pjsip: Handle invocation of callback on outgoing request when error occurs. · aeea634b
      Joshua Colp authored
      There are some error cases in PJSIP when sending a request that will
      result in the callback for the request being invoked.  The code did not
      handle this case and assumed on every error case that the callback was not
      invoked.
      
      The code has been changed to check whether the callback has been invoked
      and if so to absorb the error and treat it as a success.
      
      ASTERISK-26679
      ASTERISK-26699
      
      Change-Id: I563982ba204da5aa1428989a11c06dd9087fea91
      aeea634b
    • Sean Bright's avatar
      res_rtp_asterisk: Swap byte-order when sending signed linear · 7a16524a
      Sean Bright authored
      Before Asterisk 13, signed linear was converted into network byte order by a
      smoother before being sent over the network. We restore this behavior by
      forcing the creation of a smoother when slinear is in use and setting the
      appropriate flags so that the byte order conversion is always done.
      
      ASTERISK-24858 #close
      Reported-by: Frankie Chin
      
      Change-Id: I868449617d1a7819578f218c8c6b2111ad84f5a9
      7a16524a
  16. Jan 27, 2017
    • George Joseph's avatar
      debug_utilities: Add ast_logescalator · ef4deb8e
      George Joseph authored
      The escalator works by creating a set of startup commands in cli.conf
      that set up logger channels and issue the debug commands for the
      subsystems specified.  If asterisk is running when it is executed,
      the same commands will be issued to the running instance.  The original
      cli.conf is saved before any changes are made and can be restored by
      executing '$prog --reset'.
      
      The log output will be stored in...
      $astlogdir/message.$uniqueid
      $astlogdir/debug.$uniqueid
      $astlogdir/dtmf.$uniqueid
      $astlogdir/fax.$uniqueid
      $astlogdir/security.$uniqueid
      $astlogdir/pjsip_history.$uniqueid
      $astlogdir/sip_history.$uniqueid
      
      Some minor tweaks were made to chan_sip, and res_pjsip_history
      so their history output could be send to a log channel as packets
      are captured.
      
      A minor tweak was also made to manager so events are output to verbose
      when "manager set debug on" is issued.
      
      Change-Id: I799f8e5013b86dc5282961b27383d134bf09e543
      ef4deb8e
  17. Jan 26, 2017
  18. Jan 25, 2017
    • Mark Michelson's avatar
      Add reload options to CLI/AMI stale object commands. · d32bd638
      Mark Michelson authored
      Marking an object as stale in a memory cache is supposed to prime the
      cache so that the next time the item is retrieved, the stale item is
      deleted from the cache and a background task is run to re-populate the
      cache with a fresh version of the object.
      
      The problem is, there are some object types out there for which there is
      no natural reason that they would be retrieved from the backend with any
      regularity. Outbound PJSIP registrations are a good example of this. At
      startup, they are read, and an object-specific state is created that
      refers to the initially-retrieved object for all time.
      
      Adding the "reload" option to the CLI/AMI commands gives the cache the
      opportunity to manually re-retrieve the object from the backend, both
      storing the new object in the cache and applying the new object's
      configuration to the module that uses that object.
      
      Change-Id: Ieb1fe7270ceed491f057ec5cbf0e097bde96c5c8
      d32bd638
    • Richard Mudgett's avatar
      T.140: Fix format ref and memory leaks. · 20aed30d
      Richard Mudgett authored
      * channel.c:ast_sendtext(): Fix T.140 SendText memory leak.
      
      * format_compatibility.c: T.140 RED and T.140 were swapped.
      
      * res_rtp_asterisk.c:rtp_red_init(): Fix ast_format_t140_red ref leak.
      
      * res_rtp_asterisk.c:rtp_red_init(): Fix data race after starting periodic
      scheduled red_write().
      
      * res_rtp_asterisk.c: Some other minor misc tweaks.
      
      Change-Id: Ifa27a2e0f8a966b1cf628607c86fc4374b0b88cb
      20aed30d
  19. Jan 24, 2017
    • Joshua Colp's avatar
      res_pjsip_endpoint_identifier_ip: Ensure error defaults to 0. · ee2b0f2e
      Joshua Colp authored
      When configuring a match using a netmask the error variable was
      not defaulting to 0. For some people this would cause the code
      to think an error occurred when adding the match when in reality
      it added perfectly fine.
      
      ASTERISK-26693
      
      Change-Id: I850c250813742bddde65c84e739093c9e01dfe56
      ee2b0f2e
    • Richard Mudgett's avatar
      stasis_bridge.c: Fix off-nominal stasis control ref leak. · e922979d
      Richard Mudgett authored
      Change-Id: Ib17218343a6596832060180e19386da9df150ac8
      e922979d
    • Richard Mudgett's avatar
      res_musiconhold.c: Fix format ref leak when parsing MOH config class. · 56854f22
      Richard Mudgett authored
      Change-Id: Ica8e8e2ce7604c2c61ec55bef07dc675361d2ea5
      56854f22
    • Richard Mudgett's avatar
      PJPROJECT logging: Fix detection of max supported log level. · 6f3e8c8e
      Richard Mudgett authored
      The mechanism used for detecting the maximum log level compiled into the
      linked pjproject did not work.  The API call simply stores the requested
      level into an integer and does no range checking.  Asterisk was assuming
      that there was range checking and limited the new value to the allowable
      range.  To get the actual maximum log level compiled into the linked
      pjproject we need to get and save off the initial set log level from
      pjproject.  This is the maximum log level supported.
      
      * Get and save off the initial log level setting before altering it to the
      desired level on startup.  This has to be done by a macro rather than
      calling a core function to avoid incorrectly linking pjproject.
      
      * Split the initial log level warning messages to warn if the linked
      pjproject cannot support the requested startup level and if it is too low
      to get the pjproject buildopts for "pjproject show buildopts".
      
      * Adjust the CLI "pjproject set log level" to check the saved max log
      level and to generate normal output messages instead of a warning message.
      
      ASTERISK-26743 #close
      
      Change-Id: I40aa76653e2a1dece66c3f8734594b4f0471cfb4
      6f3e8c8e
    • Richard Mudgett's avatar
      res_pjsip_pubsub.c: Implement "pjsip show subscriptions" commands. · 0ea3c371
      Richard Mudgett authored
      ASTERISK-23828 #close
      
      Change-Id: Ifb8a3b61f447aedc58a8e6b36a810f7566018567
      0ea3c371
Loading