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
- dfa52c4 docs: Updating documentation and license boilerplates in all files by Alexander Afanasyev · 10 years ago
- 2a7f720 exceptions: Make Tlv::Error a base class for all packet-processing exceptions by Alexander Afanasyev · 10 years ago
- 4b8c6a2 src: Correcting coding style of security related code. by Yingdi Yu · 10 years ago
- fdbfc6d src: Improving consistency and correcting code style by Alexander Afanasyev · 10 years ago
- fc40d87 security: Add doxygen comments by Yingdi Yu · 11 years ago
- e2dcdfd build: Experimental support to build using precompiled headers by Alexander Afanasyev · 11 years ago
- 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/security/public-key.hpp]
- 61ec272 renaming: ndn-cpp to ndn-cpp-dev by Yingdi Yu · 11 years ago[Renamed from include/ndn-cpp/security/public-key.hpp]
- 4f32463 security: renaming PolicyManager classess to SecPolicy___ and re-organize security file layout by Yingdi Yu · 11 years ago[Renamed (94%) from include/ndn-cpp/security/certificate/public-key.hpp]
- 54467af build: Fixing gcc compilation by Alexander Afanasyev · 11 years ago
- bf1a67a security: Porting security elements to the updated framework by Alexander Afanasyev · 11 years ago
- 0ea6e08 security: CryptoPP functions are used directly to encode/decode DER/BER by Alexander Afanasyev · 11 years ago
- 10a8c38 security: documentation: Fix doc comment for PublicKey constructor and getDigest. by Jeff Thompson · 11 years ago
- 0799671 DER encoding: implement PublicKey::toDer(). by Jeff Thompson · 11 years ago
- e589c3f Code style: Replace tab with space. by Jeff Thompson · 11 years ago
- 31b5c2f encoding: Move oid support from security/certificate to encoding. by Jeff Thompson · 11 years ago
- 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 from ndn-cpp/security/certificate/public-key.hpp]
- c057343 security: Added PublicKey and OID classes. by Jeff Thompson · 11 years ago