1. 21 Mar, 2019 3 commits
    • JC Brand's avatar
      Document `_converse.ChatBox.prototype.sendMessage` as an API method · 27557d6a
      JC Brand authored
      Until now, we've only been explicitly documenting the `_converse.api`
      namespace and only considered the methods under it as forming the API
      contract (which determines how we do semver releases).
      
      It appears as if we've reached a point where trying to keep everything
      under the `_converse.api` namespace no longer makes sense. Certain
      methods are applicable to particular models and trying to shoehorn them
      into the `_converse.api` namespace seems clunky and non-intuitive.
      
      I've therefore decided to slightly refactor `sendMessage` to let it take
      two simple parameters and to document it with JSDoc so that it's
      presented as an API method, albeit only available on a chat model.
      
      updates #1496
      updates #1504
      27557d6a
    • JC Brand's avatar
      Use `_converse.api.send` to forward messages · 675692df
      JC Brand authored
      675692df
    • JC Brand's avatar
      Upgrade to Strophe 1.3.2 · d8755132
      JC Brand authored
      d8755132
  2. 19 Mar, 2019 1 commit
  3. 15 Mar, 2019 6 commits
  4. 12 Mar, 2019 1 commit
    • JC Brand's avatar
      Don't send out receipts or markers for MAM messages · 5b4ce87a
      JC Brand authored
      Eventually we need to add better support for receipts and markers of MAM
      messages.
      
      We'll need to do the following:
      
      * First check whether the MAM page already contains the receipts or markers, to avoid duplication
      * Only ever in catchup mode
      * Only after full catchup to ensure that the receipt is not in a different page than the message
      5b4ce87a
  5. 09 Mar, 2019 2 commits
    • Meitar M's avatar
      Allow `http:` image URLs if Converse.js is loaded on an insecure origin. · 76bff83c
      Meitar M authored
      Currently, in order for Converse.js to recognize a pasted URL as an
      image, it must be an URL whose protocol is `https:` (`https` in the
      URI.js library's notation). This is sensible, but means that any
      non-HTTPS image URL is not recognized as a valid URL (and thus will not
      be rendered inline, even if `show_images_inline` is set to `true`).
      
      It is important to always check for HTTPS URLs when in a secure context
      (i.e., the initial page load was requested via HTTPS) in order to ensure
      that non-secured content does not mix with secured content. However, the
      inverse is not true: if the original page was loaded over HTTP, then
      enforcing HTTPS for images adds arguably no meaningful protection while
      also breaking the `show_images_inline` feature for the edge cases where
      Converse.js is deployed without HTTPS and a user pastes an HTTP URL.
      
      This patch changes the behavior of the `isImageURL` method such that the
      requirement for the pasted URL's protocol to be `https:` is enforced
      only when the `window.location.protocol` itself is also `https:`. By
      doing this, we ensure that secure origins (i.e., when Converse.js is
      loaded over HTTPS initially) are still secured and cannot have non-HTTPS
      content introduced to the page via a pasted non-HTTPS URL, however it
      also allows non-HTTPS origins to render both HTTP and HTTPS image URLs.
      76bff83c
    • Christoph Scholz's avatar
      ed9d2a25
  6. 07 Mar, 2019 7 commits
  7. 06 Mar, 2019 3 commits
  8. 05 Mar, 2019 5 commits
  9. 04 Mar, 2019 2 commits
  10. 03 Mar, 2019 2 commits
  11. 01 Mar, 2019 5 commits
  12. 27 Feb, 2019 3 commits