Skip to content
Snippets Groups Projects
  1. Feb 19, 2022
  2. Feb 15, 2022
    • Sébastien Blin's avatar
      swarm: verify all certificates changes · 53cf11bd
      Sébastien Blin authored
      In some cases, a user in the swarm can update its certificates.
      However, the new certificate MUST be checked and MUST be signed
      by the account.
      So, this patch validates two scenarios:
      + Check that a fetch error is sent to the client whenever an invalid
      certificate is detected in the original clone
      + Check that a fetch error is sent to the client whenever a
      certificate is replaced during the conversation.
      
      Change-Id: Ieb15fb6444dcf4541f00c511a9f4ba0c64617130
      53cf11bd
    • Sébastien Blin's avatar
      swarm: handle device's expiration · d2d18bde
      Sébastien Blin authored
      If a device expires, a migration will regenerate the device's
      certificate. In this case, the device certificate in swarms must
      be updated.
      So, the idea of this patch is to verify that the current certificate
      in the repository for this device is still correct. If the device or
      the member got invalidated, it tries to replace the current certificate
      (updated via the migration). So that the new commits will still be valid.
      
      Change-Id: I75b19b0edbb5601a758a73a4c4a44678d77295e1
      GitLab: #684
      d2d18bde
  3. Feb 07, 2022
  4. Feb 04, 2022
    • Sébastien Blin's avatar
      account_archive: re-work migrating process · 34af9c4a
      Sébastien Blin authored
      When a device is expired, the migration will update the certificate
      chain with the previous key. So, after a migration, the device's id
      must be unchanged.
      However, if a device is revoked, this should trigger a re-generation
      of the device with a new PrivateKey (so generates a new device).
      Add related unit tests.
      
      GitLab: #684 (this is some preparative work)
      Change-Id: I7ff0cff97b7285186539cfadc6e33b620ded5b27
      34af9c4a
  5. Feb 02, 2022
    • Sébastien Blin's avatar
      tests: fix ut_conversation · 57723b8c
      Sébastien Blin authored
      + testSetMessageDisplayed and testSetMessageDisplayedPreference were
      broken because the lastDisplayed behaviour was recently changed to
      support syncing across devices. Update the two related tests. Also,
      avoid to update the lastDisplayed on merge
      + testSyncWithoutPinnedCert was badly written causing some sporadic
      failures.
      
      Change-Id: I364818b4ececb0fa63e87441f55a7da76fe1feb6
      57723b8c
  6. Jan 28, 2022
    • Sébastien Blin's avatar
      swarm: sync read status across devices · 84c7c9de
      Sébastien Blin authored
      Because swarm is a synched history compatible with multi-devices,
      if a message from the swarm is read on one device it should be
      synchronized with other devices as much as possible.
      The idea of this patch is to add lastDisplayed sent in synched
      datas to allow clients to update the read status. However, there
      is several scenarios to take into account, because the history
      can be partially synched across devices.
      
      5 scenarios are supported:
      + if the last displayed sent by other devices is the same as the
      current one, there is nothing to do.
      + if there is no last displayed for the current device, the remote
      displayed message is used.
      + if the remote last displayed is not present in the repo, it means
      that the commit will be fetched later, so cache the result
      + if the remote is already fetched, we check that the local last
      displayed is before in the history to replace it
      + Finally if a message is announced from the same author, it means
      that we need to update the last displayed.
      
      If the last displayed message is updated, AccountMessageStatusChanged
      is triggered for the client.
      
      Doc: https://git.jami.net/savoirfairelinux/jami-project/-/wikis/technical/2.3.%20Swarm
      Change-Id: Iedd29129d72cbeb43499471bdfd492dd4d49dcb6
      84c7c9de
  7. Jan 26, 2022
    • Sébastien Blin's avatar
      jamiaccount: add test for migrations · d1bc9390
      Sébastien Blin authored
      Accounts can see their certificates expire. When it's the case, a
      migration is needed. However, several regressions can happen, because
      this behaviour can be tricky to test correctly. In this patch, a
      test is added to validate that the migration is done whenever the
      certificate expires.
      
      + OpenDHT needs to be bumped in order to be able to change the validity
      period of a certificate.
      + In ArchiveAccountManager, a method is added to change the validity
      of a certificate in the chain.
      + This patch also fixes a crash when a migration occurs directly on
      the archive (info_ was null causing a segfault).
      + Finally, cleanup some signatures unused in JamiAccount.
      
      GitLab: #684 (this is some preparative work)
      Change-Id: I901bc67fd63ce2ab26ded64662f8333d3a0eed50
      Unverified
      d1bc9390
  8. Jan 25, 2022
    • Sébastien Blin's avatar
      conversationrepository: fix isValidUserAtCommit · 9fa8bf16
      Sébastien Blin authored
      The method was bugguy, because the whole point here is to check
      if the conversation contains enough informations at this point to
      validate the user, not to compare with pinned certificate.
      Moreover, a user can sync the history from another device, without
      ever connecting to the original author, so the certificateStore
      will not have the device certificate in this case, so only uses
      from the repository.
      A test is added to reflect this.
      
      Change-Id: I3af5e7769174eedcb54e17181d4530593960c9c9
      9fa8bf16
    • Mohamed Chibani's avatar
      SIP call: re-invite without ice re-negotiation · 70a2a650
      Mohamed Chibani authored and Sébastien Blin's avatar Sébastien Blin committed
      When muting/un-muting the video, a re-invite is performed
      leading to a full media renegotiation and restart,  including
      ICE session if used.
      With these changes, the mute/unmute video will still require
      a re-invite (a new SDP to indicate the new media directions), but
      the ICE session is re-used and only the video is stopped/started
      accordingly.
      The behavior improves the UX by avoiding unnecessary audio disruptions
      and is more compliant with SIP/ICE specs (see RFC-5245 section 9.1.1.1
      for example)
      
      Gitlab: #671
      
      Change-Id: I13caf9a965af1d76e922fe5f6b86d5332b3296d6
      70a2a650
  9. Jan 12, 2022
  10. Jan 05, 2022
  11. Dec 17, 2021
  12. Dec 16, 2021
    • Mohamed Chibani's avatar
      SDP - set media direction according to mute state · a887b2de
      Mohamed Chibani authored and Sébastien Blin's avatar Sébastien Blin committed
      Currently, the media attribute in the SDP is always set to
      'sendrecv' regardless of the mute state of the media.
      In this patch, media direction will be set according to mute
      state of the media.
      Note that this only applies if the mute/unmute requires media
      renegotiation (SIP re-invite with new SDP session). Currently,
      this only the case for video media. For audio, mute/unmute is
      done locally without SIP re-invite.
      
      References:
      RFC-3264
      RFC-4317 (non-normative)
      
      Gitlab: #645
      
      Change-Id: I604331255bd25dfe732e192039a673a0980105fa
      a887b2de
  13. Dec 10, 2021
  14. Dec 09, 2021
    • Sébastien Blin's avatar
      conference: fix current protocol issues · 440a71b4
      Sébastien Blin authored
      This patch fix 3 little issues:
      + "device" was always empty. Uses the transport to fill the device
      field. This will be used in the next version of the protocol.
      + raiseHand was bugguy in two ways:
          + It was only usable by moderators
          + Somebody was able to change the raiseHand for other peers
      
      Change-Id: I32bf37c5063973a5a5962dd8984c87fb05d33a3d
      Unverified
      440a71b4
  15. Nov 29, 2021
    • Sébastien Blin's avatar
      multiplexed_socket: fix race condition on acceptation · 35e4cfce
      Sébastien Blin authored
      Because some callbacks can take a long time (accepting a SIP channel
      will starts to sync profiles, ask for new channel, etc), control packets
      are handled in their own thread. However, if the peer accepts a request,
      it can starts to use it and send data on it. When finished, it will close
      the socket and both peer will remove the channel.
      In some case, the channel can be removed before
      MultiplexedSocket::Impl::onAccept, causing upper layers to handle a
      bad channel. In this patch, we removes the channel only when upper layers
      know that the channel is accepted and ready to use. Also, onAccept()
      doesn't create wrong channels (which was a bug, where isInitiator() was
      in the wrong state).
      
      GitLab: #659
      Change-Id: I4f45feacc2624ce0135ace09f7e0188b56fcf81f
      35e4cfce
  16. Nov 25, 2021
    • Sébastien Blin's avatar
      swarm: fix racecondition with acceptTrustRequest · c6661d18
      Sébastien Blin authored
      AcceptTrustRequest should update conversation's module to directly
      return the syncing conversation. Moreover, configurationMutex_ should
      be recursive to allow sync between trust and conversation's requests.
      
      This fix ut_conversationRequest where the problem was that the
      conversation's requests were updated after ContactAdded, causing
      removeContact() to remove the conversation, but acceptTrustRequest
      re-adds it during the operation.
      
      Change-Id: If676dc58290f87c289a6e63eb9afa04d2cc25df5
      GitLab: #659
      c6661d18
  17. Nov 22, 2021
    • Mohamed Chibani's avatar
      multi-stream - remove legacy code · df9dba9b
      Mohamed Chibani authored and Sébastien Blin's avatar Sébastien Blin committed
      Remove obsolete code kept for backward compatibility.
      Add call transfer test case
      
      Gitlab: #470
      
      Change-Id: I81472b8308ec402911670e8658308a184b97206c
      df9dba9b
    • Sébastien Blin's avatar
      swarm: various fixes · 71b4d7a3
      Sébastien Blin authored and Adrien Béraud's avatar Adrien Béraud committed
      This patch fixes current unitTest
      + Fix testCreateConversationWithMessagesThenAddDevice messageReceived
      flag
      + Remove useless sleep in tests
      + in ut_conversation fix messageReceived flag
      + lock convInfo and convRequests to avoid invalid write operations
      + fix pending callbacks if connected via a DHT request
      + remove useless log
      
      Change-Id: If53ecf0c064e9c1424c11a4af1e13d31294e6be9
      71b4d7a3
  18. Nov 19, 2021
    • Sébastien Blin's avatar
      tests: fix ut_conference · caad9b34
      Sébastien Blin authored and Adrien Béraud's avatar Adrien Béraud committed
      The conference should be used in the tests after the first
      conferenceChanged, to be sure that every calls are binded to the
      conference.
      Then, before adding a call to the conference, it should be CURRENT
      from the host perspective, not the receiver. So, add "hostState"
      to store the state of the call from the host perspective.
      
      Change-Id: I9d27b4c0461ede05d27ea849de08c22e9fc3b249
      caad9b34
  19. Nov 16, 2021
  20. Nov 15, 2021
    • Sébastien Blin's avatar
      conversation_module: update pending fetch on errors · f8830b78
      Sébastien Blin authored
      Note: also cleanup warning for conversationRequest and fix test
      
      Change-Id: I4b14dd5983bdde2d479093a33ee3d6343fa8ed87
      GitLab: #659
      Unverified
      f8830b78
    • Sébastien Blin's avatar
      conference: fix crashes on leave · 41a7ef19
      Sébastien Blin authored
      This patch fix several problems:
      + participants_ must be protected and not iterated while accessed
      + getVideoMixer() do not generate a video mixer, this is only
      managed at one place.
      + Remove setConfId, enter/exitConf are here for this and this
      is causing the videoMixer to not be destroyed in time, because
      exitConference() was called after setConfId(""). This was causing
      crashes because the videoMixer will update for the last participant
      with the error: "The call is not bound to any conference"
      
      GitLab: #660
      Change-Id: Ic60bc7377b0315f7e2906ab03a7653381436180c
      41a7ef19
  21. Nov 12, 2021
  22. Nov 03, 2021
  23. Nov 01, 2021
  24. Oct 29, 2021
  25. Oct 28, 2021
  26. Oct 26, 2021
  27. Oct 25, 2021
  28. Oct 22, 2021
    • Sébastien Blin's avatar
      conversation_module: fix needsSyncingWith · a0a0f830
      Sébastien Blin authored
      If a conversation is not cloned, when detecting a new presence,
      needsSyncingWith MUST return true if one conversation needs to be
      cloned. Else, it will result in an infinite syncing.
      
      Change-Id: I3a9bcab9f8a845161ceac7d75d8842f8b338ed57
      Unverified
      a0a0f830
  29. Oct 21, 2021
  30. Oct 01, 2021
    • Sébastien Blin's avatar
      swarm: replay text messages when cloning an old conversation · c5d52986
      Sébastien Blin authored
      After removing and re-adding a contact, the second conversation
      will be deleted and the first conv will be recloned. However,
      some text messages can be present. In this case, we can re-add
      them.
      
      Change-Id: I7cafcf76b5d36769ea939729a2fbf6730853cafb
      c5d52986
    • Sébastien Blin's avatar
      data transfer: fix cancel in swarm · 0a350394
      Sébastien Blin authored
      cancel a file from the user should removes the file from the
      waiting map to avoid to relaunch the download on the next sync.
      
      Change-Id: I0696364d0131c8dde563b97b8b965e99d1f5686a
      Unverified
      0a350394
    • Sébastien Blin's avatar
      jamiaccount: cache compressed vcard given by the client in sendTrustRequest · 6ec4c687
      Sébastien Blin authored and Adrien Béraud's avatar Adrien Béraud committed
      For now, the daemon doesn't handle the profile of the account nor
      the compression. However, it does handle sendTrustRequest, which uses
      the DHT to transmit requests. DHT values must be small, else it will
      not be sent. So, this patch cache the compressed payload generated
      by the client and removes it as soon as the confirmation is received.
      This allow the daemon to retry to send request with the payload sent
      originally.
      
      Change-Id: I3fac542c6a53febdb7f1d0c516ec2d9ff5b317be
      6ec4c687
  31. Sep 30, 2021
    • Sébastien Blin's avatar
      test: split ut_conversation · 830d4857
      Sébastien Blin authored
      Change-Id: I14df750d459a0771f4e60923a1ecf3bfb938a78b
      830d4857
    • Sébastien Blin's avatar
      swarm: link trust requests and conversation's requests · f045eb97
      Sébastien Blin authored
      This is only to avoid to return weird states from the daemon to the
      client. But if a conversation is added through addContact,
      removeContact should be called to removes it. However, if
      removeConversation() is called, the conversationId in contact's
      details MUST be updated.
      Same for acceptConversationRequest, this should removes related
      trust requests
      
      Change-Id: I4b273075862cdcdffc7f13c1b5e581a2eebc411d
      f045eb97
Loading