ndn-cxx v0.1.0 Release Notes
============================

Version 0.1.0 is the initial release of ndn-cxx, an NDN C++ library with eXperimental eXtensions.

Originally based on [ndn-cpp library](https://github.com/named-data/ndn-cpp) the ndn-cxx library
adopts a slightly different design philosophy (including an extensive use of Boost libraries to
facilitate development, as well as the use of Crypto++ library to support cryptographic operations),
and includes a number of extensions that aim to simplify NDN application development.

The current features include:

-   **Base**
    -   Fully asynchronous, event-driven communication model, which is implemented using
        [Boost.Asio](http://www.boost.org/doc/libs/1_48_0/doc/html/boost_asio.html)
    -   Single-threaded, but thread-safe Face operations

        > A single Face object can be safely used in multiple threads to express Interests and
        > publish Data packets

    -   Explicit time management for NDN operations using
        [Boost.Chrono](http://www.boost.org/doc/libs/1_48_0/doc/html/chrono.html)
    -   Simplified and extended [NDN API](doxygen/annotated.html)
    -   Extensive set of unit-tests based on [Boost.Test
        framework](http://www.boost.org/doc/libs/1_48_0/libs/test/doc/html/index.html)
        -   Continuous integration using an in-house installation of Jenkins build bots and the
            hosted [Travis CI](https://travis-ci.org/named-data/ndn-cxx) continuous integration
            service compile and verify correctness of the library for each commit

-   **Wire format**
    -   Full support of [NDN-TLV packet format v0.1](http://named-data.net/doc/NDN-TLV/0.1/)
    -   Pure C++ implementation of wire encoding/decoding with simple access to wire format of all
        NDN packet abstractions via `wireEncode` and `wireDecode` methods

        > In many cases, NDN packet abstractions are just "indices" to the wire format

-   **Communication with the forwarder**
    -   Enable connecting to local forwarder via UNIX and TCP transports and to remote forwarders
        using TCP transport
    -   Full support for communication with [Named Data Networking Forwarding Daemon
        (NFD)](https://github.com/named-data/NFD)
        -   Full support for [NFD management
            protocols](http://redmine.named-data.net/projects/nfd/wiki/Management) to NFD status
            information, create and manage NFD Faces, receive NFD Face status change notifications,
            update StrategyChoice for namespaces, and manage routes in RIB
        -   Support for
            [LocalControlHeader](http://redmine.named-data.net/projects/nfd/wiki/LocalControlHeader)
            to implement special NDN applications that need low-level control of NDN packet
            forwarding
-   **Security support**
    -   A set of security primitives to allowing implementation of secure NDN applications in a
        simplified manner
        -   **KeyChain**: provides simple interfaces of packet signing, and key and certificate
            management
        -   **ValidatorConfig**: validator that implements trust model defined in a configuration
            file
        -   **CommandInterestGenerator** and **CommandInterestValidator**: convenient helpers to
            produce and validate command interests, while preventing potential replay attacks
    -   Several implementations of trusted platform modules to securely manage private keys
        -   **SecTpmOsx**: TPM based on OSX KeyChain (OSX-specific)
        -   **SecTpmFile**: TPM that uses file-based access control to protect keys (cross-platform)
    -   Extensive set of security command-line tools to manage security identities and certificates
        -   Generating private/public keys
        -   Issuing certificates
        -   Exporting/importing identities
        -   Managing default security settings
-   **Miscellaneous tools**
    -   Scheduler to support delayed time operations
    -   NDN regular expressions
    -   Simple config file to alter various aspects of the library
    -   **tlvdump**: a simple tool to visualize TLV-encoded blocks
  1. b67090a build+tests: Fixing c++11 mode compilation and correcting integrated test with faces by Alexander Afanasyev · 10 years ago
  2. e66bf2a face: Specify signing certificate/identity in setInterestFilter/unsetInterestFilter by Yingdi Yu · 10 years ago
  3. dfa52c4 docs: Updating documentation and license boilerplates in all files by Alexander Afanasyev · 10 years ago
  4. 691c3ce face: Adding new constructors that accept reference to io_service object by Alexander Afanasyev · 10 years ago
  5. fdbfc6d src: Improving consistency and correcting code style by Alexander Afanasyev · 10 years ago
  6. c07b3a2 util, transport: add configuration file support and make default unix socket configurable by Steve DiBenedetto · 10 years ago
  7. 7dced46 face: making Face::shutdown call asynchronous by Alexander Afanasyev · 10 years ago
  8. aa0e7da all: Refactoring work with time using boost::chrono by Alexander Afanasyev · 10 years ago
  9. 52afb3f face: When there are no more events to process, pausing transport instead of closing it by Alexander Afanasyev · 11 years ago
  10. 42c8185 face: Multiple matching for setInterestFilter and expressInterest callbacks by Alexander Afanasyev · 11 years ago
  11. 505646e face: Updating the way to select Controller by Alexander Afanasyev · 11 years ago
  12. 7682ccb face: Allow specifying specific Controller in constructor by Alexander Afanasyev · 11 years ago
  13. 6d48bc1 management: Finalizing LocalControlHeader implementation by Alexander Afanasyev · 11 years ago
  14. f9fa52f management: Add support to local control header. by Yingdi Yu · 11 years ago
  15. f39c537 face: Making class variables names more consistent by Alexander Afanasyev · 11 years ago
  16. 8460afb face: Mark Face class as noncopyable by Alexander Afanasyev · 11 years ago
  17. f7ca320 face: Making environment-based selection of the daemon (ndnd-tlv vs. nfd) by Alexander Afanasyev · 11 years ago
  18. 12dfbad face: Fixing small bug: after unregistering prefix, close transport if by Alexander Afanasyev · 11 years ago
  19. 0222fba api: Major API change. OnInterest/OnData callbacks now use just references, not shared pointers by Alexander Afanasyev · 11 years ago
  20. c8823bc face: Refactored code to set interest filter by Alexander Afanasyev · 11 years ago
  21. 0d92081 face: Expose ioService from Node and Face. by Yingdi Yu · 11 years ago
  22. 09c613f src: Another round of source updates: moving all headers close to implementation files by Alexander Afanasyev · 11 years ago[Renamed from include/ndn-cpp-dev/face.hpp]
  23. 20d2c58 transport: Implementing TcpTransport by Alexander Afanasyev · 11 years ago
  24. b790d95 face+node: Improving async operations by Alexander Afanasyev · 11 years ago
  25. 61ec272 renaming: ndn-cpp to ndn-cpp-dev by Yingdi Yu · 11 years ago[Renamed from include/ndn-cpp/face.hpp]
  26. f75a0aa node: Extending processEvents API to allow processing thread management flexibility by Alexander Afanasyev · 11 years ago
  27. a557d5a face: Extending Face interface to support ``put`` call by Alexander Afanasyev · 11 years ago
  28. e2e0d75 face+transport: Cleanup and preparation for implementation of fully async Face operations by Alexander Afanasyev · 11 years ago
  29. 0b688dc face+transport: Eliminating concept of ConnectionInfo by Alexander Afanasyev · 11 years ago
  30. de2f6b5 face: Renaming (remove)registerPrefix to (unset)interestFilter by Alexander Afanasyev · 11 years ago
  31. e0dc339 Face: In Face constructor, use shared_ptr instead of default make_shared. by Jeff Thompson · 11 years ago
  32. 978c152 Face: In expressInterest, add optional wireFormat argument. by Jeff Thompson · 11 years ago
  33. 25b4e61 make: Global change: Move all public headers to include folder. Change source to including public headers using #include <ndn-cpp/*>. Split some header files to minimize exposing C .h files. by Jeff Thompson · 11 years ago[Renamed (98%) from ndn-cpp/face.hpp]
  34. 62992e4 Face: Make pendingInterestId and registeredPrefixId uint64_t. by Jeff Thompson · 11 years ago
  35. b629ddb Face: Changed the default port to 6363. Refs #1050. by Jeff Thompson · 11 years ago
  36. 1109514 Added support for removePendingInterest and removeRegisteredPrefix. by Jeff Thompson · 11 years ago
  37. 1f8a31a ForwardingFlags: Added ForwardingFlags class and use it in registerPrefix and ForwardingEntry instead of int flags. by Jeff Thompson · 11 years ago
  38. 07b6ebe Face: In registerPrefix, make the default flags 3, and actually use them. by Jeff Thompson · 11 years ago
  39. 6d7369b Remove keyChain, signerName and byKeyName from registerPrefix. by Jeff Thompson · 11 years ago
  40. 590ec23 In Face.registerPrefix, need to pass keyChain, signerName, etc. so that it can sign the Data packet with the ForwardingEntry. by Jeff Thompson · 11 years ago
  41. 0050abe Code style: Put function return type on a line by itself. by Jeff Thompson · 11 years ago
  42. 7687dc0 All source files: Added UC Copyright. Added jefft0 email address. by Jeff Thompson · 11 years ago
  43. 1656e6a Code style: Declare (Type& value) instead of (Type &value) by Jeff Thompson · 11 years ago
  44. fb29cda Move the default parameters for methods from Node to Face. by Jeff Thompson · 11 years ago
  45. 86507bc Added preliminary code for registerPrefix. by Jeff Thompson · 11 years ago
  46. 4fe4551 Added expressInterest which takes the Interest directly. by Jeff Thompson · 11 years ago
  47. 7aec025 Major change: in expressInterest, remove the Closure class and use function objects for onData and onTimeout. by Jeff Thompson · 11 years ago
  48. 10e3438 Change Transport connect to use the new ConnectionInfo object. by Jeff Thompson · 11 years ago
  49. bf50a1a Added Node class, and move most functionality from Face to Node. Make connect take a Node, not a Face. by Jeff Thompson · 11 years ago
  50. c7e0744 Change receiveIsReady and processEvents to return immediately, with comment warnings that the caller needs to sleep to avoid using 100% CPU. by Jeff Thompson · 11 years ago
  51. fe08e5a Added doc comments. by Jeff Thompson · 11 years ago
  52. 432c8be Added support for processEvents to Transport and Face. Removed tempReceive. by Jeff Thompson · 11 years ago
  53. c49cb32 In getTransport, need to return a const shared_ptr by Jeff Thompson · 11 years ago
  54. 2a4724b In expressInterest, just take a pointer to the Closure, not a shared_ptr by Jeff Thompson · 11 years ago
  55. a0d18c9 Code style: replace tabs with spaces by Jeff Thompson · 11 years ago
  56. 5341219 Major code style change to rename all files to lower case. by Jeff Thompson · 11 years ago
  57. 517ffa8 Added shutdown method by Jeff Thompson · 11 years ago
  58. b9e3c8e Major update to rename NDN class to Face by Jeff Thompson · 11 years ago[Renamed (88%) from ndn-cpp/NDN.hpp]
  59. 56ec9e2 Major update to rename ContentObject to Data everywhere. by Jeff Thompson · 11 years ago
  60. ab13ac7 Added NDN.getTransport by Jeff Thompson · 11 years ago
  61. cdf7e25 Added expressInterest overload without interestTemplate by Jeff Thompson · 11 years ago
  62. 1242b1f In the constructor, default port to 9595 by Jeff Thompson · 11 years ago
  63. b7d059d In the constructor, make the transport default to UdpTransport by Jeff Thompson · 11 years ago
  64. 4a48e67 In NDN constructor, put host and port args first. by Jeff Thompson · 11 years ago
  65. 9657bda Don't pass a Closure to the NDN constructor by Jeff Thompson · 11 years ago
  66. 0cb7aee Pass the NDN object to connect. Added TcpTransport::tempReceive() by Jeff Thompson · 11 years ago
  67. beb8b7d Pass host and port to NDN constructor and Transport::connect by Jeff Thompson · 11 years ago
  68. c172be3 Added initial expressInterest by Jeff Thompson · 11 years ago
  69. b982b6d Added Closure class by Jeff Thompson · 11 years ago
  70. aa4e6db Added initial NDN class by Jeff Thompson · 11 years ago