refactor: cleanup and sync

* Fix Jenkins scripts and sync with ndn-cxx
* Sync waf-tools
* Remove ChronoSync submodule
* Remove commented/dead code and includes
* Use ScopedEventId and ScopedRegisteredPrefixHandle
* Set setCanBePrefix to true explicitly everywhere
* Fix macOS build, add GHA CI
* Use NDN_THROW for throwing errors
* Other smaller fixes

Change-Id: I615e0e239511b97101852e1d7c620a2071a18ff8
108 files changed
tree: 0338f1dfc1924ea9cdad685c4d4821c8ae2ded19
  1. .github/
  2. .jenkins.d/
  3. .waf-tools/
  4. contrib/
  5. debug-tools/
  6. docs/
  7. images/
  8. linux/
  9. security/
  10. src/
  11. test/
  12. .gitignore
  13. .jenkins
  14. demo.icns
  15. demo.qrc
  16. qt.conf
  17. README.md
  18. TODO
  19. waf
  20. wscript
README.md

ChronoChat

ChronoChat is a multiparty chat application that demostrates our synchronization primitive that we call ChronoSync.

Note that after you click to close ChronoChat, it will keep running on your system tray. To restore it to normal size window, you have to click on the system tray icon (normally on the upper right corner of your screen). Clicking on the dock won't work for now and is still on the to-do list (because I'm using qt for gui, not the native Cocoa framework).

Known Issues

  1. When you switch to a new room, you'll temporarily see yourself in two nodes for a minute or so. It won't affect others, just yourself. Hopefully it's not so disturbing.
  2. Sometimes you may not get the most up-to-date chat history.

Compilation steps

  1. On Ubuntu, configure NDN PPA repository and install NFD and ChronoSYnc if you don't have it yet, then install dependencies

     sudo apt-get install nfd libndn-cxx-dev libchronosync-dev
     sudo apt-get install libcrypto++-dev libboost-all-dev qt5-default
    
  2. Fetch source code

     git clone https://github.com/named-data/ChronoChat
    
  3. Configure and build ChronoChat

     ./waf configure
     ./waf
    

Congratulations! build/ChronoChat is ready to use. Do not forget to start NFD and configure FIB before using ChronoChat. For ease of debugging, you can generate trusted identities in your local TPM using debug-tools/create-cert.