Project

General

Profile

Actions

Feature #4777

closed

Develop API for typed name components in naming convention

Added by Junxiao Shi about 6 years ago. Updated about 5 years ago.

Status:
Closed
Priority:
Normal
Assignee:
Category:
Base
Target version:
Start date:
Due date:
% Done:

100%

Estimated time:
6.00 h

Description

Change/extend Name and name::Component APIs to support typed name components for segment number, version number, timestamp, and sequence number.


Related issues 2 (0 open2 closed)

Blocked by NDN Specifications - Feature #4577: Naming conventions: use typed name components instead of markersClosedJunxiao Shi

Actions
Blocks ndn-cxx - Task #5044: Switch default naming convention encoding to TYPEDClosedEric Newberry

Actions
Actions #1

Updated by Junxiao Shi about 6 years ago

  • Blocked by Feature #4577: Naming conventions: use typed name components instead of markers added
Actions #2

Updated by Junxiao Shi about 6 years ago

  • Tags set to Packet03Transition
  • Status changed from New to In Progress
Actions #3

Updated by Junxiao Shi about 6 years ago

  • % Done changed from 0 to 10

https://gerrit.named-data.net/#/c/ndn-cxx/+/5043/ patchset1 has the design. I'm using "version" as a demonstration.

Actions #4

Updated by Junxiao Shi about 6 years ago

https://gerrit.named-data.net/#/c/ndn-cxx/+/5043/ patchset1 has a convention argument in each API, which could cause difficulty for eventual removal.

patchset3 is an alternate design that only offers global settings for encoding and decoding conventions. While it is easier for eventual removal, every part of an application would have to adopt the same convention at least for encoding. Suppose for some reason PSync wants REV2 (to talk to other nodes using new convention) and management client wants REV1 (to talk to legacy application), an application using both would have to switch the global encoding convention setting back-and-forth, and won't work at all if it's multi-threaded.

Actions #5

Updated by Junxiao Shi almost 6 years ago

  • Status changed from In Progress to Code review
  • % Done changed from 10 to 60
Actions #6

Updated by Junxiao Shi almost 6 years ago

  • Status changed from Code review to Closed
  • % Done changed from 60 to 100
Actions #7

Updated by Davide Pesavento about 5 years ago

  • Blocks Task #5044: Switch default naming convention encoding to TYPED added
Actions #8

Updated by Junxiao Shi about 5 years ago

https://gerrit.named-data.net/c/ndn-cxx/+/5820 attempts to print name components matching known naming conventions in an alternate format.
Before we could do that, there should be a way to print name component in <type-number>=<escaped-value> format.

URI string is used programmatically in at least two places:

  • ValidatorConfig config section matches URI strings with regular expressions. Changing URI breaks existing configs.
  • ndncert /CA/_PROBE/INFO packet contains JSON text that contains URI string of the CA, which could contain typed name components (version and segment are unlikely to appear, but it's possible for the CA prefix to contain a sequence number, for example). NDN packet format does not require every node to support alternate URI format (except for types 0x01, 0x02, and 0x08), so making this change will break backwards compatibility.

The API could look like:

name.toUri(); // prints generic format
name.toUri(false); // prints generic format
name.toUri(true); // prints alternate format

It's very important to print generic format in the default setting, in order to maintain backwards compatibility.

Actions #9

Updated by Davide Pesavento about 5 years ago

I don't disagree with adding a boolean flag to toUri(). However, as decided at today's NFD call, that shouldn't block merging the aforementioned change.

OTOH, I do disagree with the default value of false for that flag, which would mean "do not use the alternate encoding". Name components with type 1, 2, and 8 are already using the alternate encoding today, and have been doing that for a very long time. Changing that would break a lot more things compared to switching the typed name components used in naming conventions to the new alternate format (I think we can assume that most, if not all, apps are still using the marker-based conventions). Moreover, the alternate URI format is a lot more human-friendly so it should be the default.

Actions #10

Updated by Junxiao Shi about 5 years ago

https://gerrit.named-data.net/c/ndn-cxx/+/5880 enables selection between canonical vs alternate URI representations.
Apart from a boolean flag, the default is controlled by NDN_NAME_ALT_URI environment variable: if it's set to '0', use canonical URI; otherwise, use alternate URI.
The reason for introducing NDN_NAME_ALT_URI is that, it would take a lot of effort to add URI representation choice to every app, but setting an environment variable is much easier in a deployment.

Actions

Also available in: Atom PDF