I2P Address: [http://git.idk.i2p]

Skip to content
Snippets Groups Projects
Commit 3699f24f authored by zzz's avatar zzz
Browse files

proposal 112 update

parent 85bdf3e0
No related branches found
No related tags found
No related merge requests found
...@@ -5,7 +5,7 @@ Addressbook Subscription Feed Commands ...@@ -5,7 +5,7 @@ Addressbook Subscription Feed Commands
:author: zzz :author: zzz
:created: 2014-09-15 :created: 2014-09-15
:thread: http://zzz.i2p/topics/1704 :thread: http://zzz.i2p/topics/1704
:lastupdated: 2016-04-17 :lastupdated: 2016-04-26
:status: Open :status: Open
.. contents:: .. contents::
...@@ -24,7 +24,7 @@ Motivation ...@@ -24,7 +24,7 @@ Motivation
Right now, the hosts.txt subscription servers just send data in a hosts.txt Right now, the hosts.txt subscription servers just send data in a hosts.txt
format, which is as follows:: format, which is as follows::
foo.i2p=b64destination example.i2p=b64destination
There are several problems with this: There are several problems with this:
...@@ -74,7 +74,7 @@ This proposal adds two new types of lines: ...@@ -74,7 +74,7 @@ This proposal adds two new types of lines:
1. Add and Change commands:: 1. Add and Change commands::
foo.i2p=b64destination#!key1=val1#key2=val2 ... example.i2p=b64destination#!key1=val1#key2=val2 ...
2. Remove commands:: 2. Remove commands::
...@@ -110,9 +110,9 @@ Other common keys: ...@@ -110,9 +110,9 @@ Other common keys:
action action
A command A command
name name
The hostname, only present if not preceded by name=dest The hostname, only present if not preceded by example.i2p=b64dest
dest dest
The b64 destination, only present if not preceded by name=dest The b64 destination, only present if not preceded by example.i2p=b64dest
date date
In seconds since epoch In seconds since epoch
expires expires
...@@ -125,7 +125,7 @@ Commands ...@@ -125,7 +125,7 @@ Commands
All commands except the "Add" command must contain an "action=command" All commands except the "Add" command must contain an "action=command"
key/value. key/value.
For compatibility with older clients, most commands are preceded by name=dest, For compatibility with older clients, most commands are preceded by example.i2p=b64dest,
as noted below. For changes, these are always the new values. Any old values as noted below. For changes, these are always the new values. Any old values
are included in the key/value section. are included in the key/value section.
...@@ -134,7 +134,7 @@ not defined here. ...@@ -134,7 +134,7 @@ not defined here.
Add hostname Add hostname
```````````` ````````````
Preceded by name=dest Preceded by example.i2p=b64dest
YES, this is the new host name and destination. YES, this is the new host name and destination.
action action
NOT included, it is implied. NOT included, it is implied.
...@@ -143,11 +143,11 @@ sig ...@@ -143,11 +143,11 @@ sig
Example:: Example::
name=dest#!sig=b64sig example.i2p=b64dest#!sig=b64sig
Change hostname Change hostname
``````````````` ```````````````
Preceded by name=dest Preceded by example.i2p=b64dest
YES, this is the new host name and old destination. YES, this is the new host name and old destination.
action action
changename changename
...@@ -158,11 +158,11 @@ sig ...@@ -158,11 +158,11 @@ sig
Example:: Example::
name=dest#!action=changename#oldname=oldhostname#sig=b64sig example.i2p=b64dest#!action=changename#oldname=oldhostname#sig=b64sig
Change destination Change destination
`````````````````` ``````````````````
Preceded by name=dest Preceded by example.i2p=b64dest
YES, this is the old host name and new destination. YES, this is the old host name and new destination.
action action
changedest changedest
...@@ -175,11 +175,11 @@ sig ...@@ -175,11 +175,11 @@ sig
Example:: Example::
name=dest#!action=changedest#olddest=oldb64dest#oldsig=b64sig#sig=b64sig example.i2p=b64dest#!action=changedest#olddest=oldb64dest#oldsig=b64sig#sig=b64sig
Add hostname alias Add hostname alias
`````````````````` ``````````````````
Preceded by name=dest Preceded by example.i2p=b64dest
YES, this is the new (alias) host name and old destination. YES, this is the new (alias) host name and old destination.
action action
addname addname
...@@ -190,13 +190,13 @@ sig ...@@ -190,13 +190,13 @@ sig
Example:: Example::
name=dest#!action=addname#oldname=oldhostname#sig=b64sig example.i2p=b64dest#!action=addname#oldname=oldhostname#sig=b64sig
Add destination alias Add destination alias
````````````````````` `````````````````````
(Used for crypto upgrade) (Used for crypto upgrade)
Preceded by name=dest Preceded by example.i2p=b64dest
YES, this is the old host name and new (alternate) destination. YES, this is the old host name and new (alternate) destination.
action action
adddest adddest
...@@ -209,11 +209,11 @@ sig ...@@ -209,11 +209,11 @@ sig
Example:: Example::
name=dest#!action=adddest#olddest=oldb64dest#oldsig=b64sig#sig=b64sig example.i2p=b64dest#!action=adddest#olddest=oldb64dest#oldsig=b64sig#sig=b64sig
Add subdomain Add subdomain
````````````` `````````````
Preceded by name=dest Preceded by example.i2p=b64dest
YES, this is the new host subdomain name and destination. YES, this is the new host subdomain name and destination.
action action
addsubdomain addsubdomain
...@@ -228,11 +228,11 @@ sig ...@@ -228,11 +228,11 @@ sig
Example:: Example::
name=dest#!action=addsubdomain#oldname=oldhostname#olddest=oldb64dest#oldsig=b64sig#sig=b64sig example.i2p=b64dest#!action=addsubdomain#oldname=oldhostname#olddest=oldb64dest#oldsig=b64sig#sig=b64sig
Update metadata Update metadata
``````````````` ```````````````
Preceded by name=dest Preceded by example.i2p=b64dest
YES, this is the old host name and destination. YES, this is the old host name and destination.
action action
update update
...@@ -243,11 +243,11 @@ sig ...@@ -243,11 +243,11 @@ sig
Example:: Example::
name=dest#!action=update#k1=v1#k2=v2#sig=b64sig example.i2p=b64dest#!action=update#k1=v1#k2=v2#sig=b64sig
Remove hostname Remove hostname
``````````````` ```````````````
Preceded by name=dest Preceded by example.i2p=b64dest
NO, these are specified in the options NO, these are specified in the options
action action
remove remove
...@@ -260,11 +260,11 @@ sig ...@@ -260,11 +260,11 @@ sig
Example:: Example::
#!action=removeall#name=hostname#dest=b64destsig=b64sig #!action=removeall#name=example.i2p#dest=b64destsig=b64sig
Remove all with this destination Remove all with this destination
```````````````````````````````` ````````````````````````````````
Preceded by name=dest Preceded by example.i2p=b64dest
NO, these are specified in the options NO, these are specified in the options
action action
removeall removeall
...@@ -277,7 +277,7 @@ sig ...@@ -277,7 +277,7 @@ sig
Example:: Example::
#!action=removeall#name=hostname#dest=b64destsig=b64sig #!action=removeall#name=example.i2p#dest=b64destsig=b64sig
Signatures Signatures
...@@ -309,14 +309,20 @@ To generate a byte stream to create or verify the signature, serialize as follow ...@@ -309,14 +309,20 @@ To generate a byte stream to create or verify the signature, serialize as follow
- Remove the "sig" key - Remove the "sig" key
- If verifying with oldsig, also remove the "oldsig" key - If verifying with oldsig, also remove the "oldsig" key
- For Add or Change commands: - For Add or Change commands only,
- output name=b64dest (name must be lower-case) output example.i2p=b64dest
- If any keys remain, output "#!" - If any keys remain, output "#!"
- Sort the options by UTF-8 key, fail if duplicate keys - Sort the options by UTF-8 key, fail if duplicate keys
- For each key/value, output key=value, followed by (if not the last key/value) - For each key/value, output key=value, followed by (if not the last key/value)
a '#' a '#'
Notes
- Do not output a newline - Do not output a newline
- Output encoding is UTF-8 - Output encoding is UTF-8
- All destination and signature encoding is in Base 64 using the I2P alphabet
- Keys and values are case-sensitive
- Host names must be in lower-case
Compatibility Compatibility
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment