Scroll to navigation

GNUNET-NAMESTORE(1) General Commands Manual GNUNET-NAMESTORE(1)

NAME

gnunet-namestoremanipulate GNU Name System (GNS) zone data

SYNOPSIS

gnunet-namestore [-a | --add] [-c FILENAME | --config=FILENAME] [-d | --delete] [-D | --display] [-e TIME | --expiration=TIME] [-h | --help] [-i NICKNAME | --nick=NICKNAME] [-L LOGLEVEL | --loglevel=LOGLEVEL] [-m | --monitor] [-n NAME | --name=NAME] [-O | --list-orphans] [-o | --omit-private] [-P | --purge-orphans] [-p | --public] [-s | --shadow] [-S | --from-stdin] [-T | --include-maintenance] [-t TYPE | --type=TYPE] [-u URI | --uri=URI] [-v | --version] [-V VALUE | --value=VALUE] [-X | --purge-zone-records] [-z EGO | --zone=EGO] [-Z KEY | --zone-to-name=KEY]

DESCRIPTION

gnunet-namestore can be used to manipulate records in a GNS zone.

The options are as follows:

|
Desired operation is adding a record.
FILENAME | FILENAME
Use the configuration file FILENAME.
|
Desired operation is deleting records under the given name that match the specified type (-t) and value (-V). If type or value are not specified, it means that all types (or values) should be assumed to match (and possibly multiple or all values under the given label will be deleted). Specifying a label (-n) is mandatory. Note that matching by expiration time or flags is (currently) not supported.
|
Desired operation is listing of matching records.
TIME | TIME
Specifies expiration time of record to add; format is relative time, i.e "1 h" or "7 d 30 m". Supported units are "ms", "s", "min" or "minutes", "h" (hours), "d" (days) and "a" (years).
|
Print short help on options.
NICKNAME | NICKNAME
Set the desired NICKNAME for the zone. The nickname will be included in all (public) records and used as the suggested name for this zone.
LOGLEVEL | LOGLEVEL
Use LOGLEVEL for logging. Valid values are DEBUG, INFO, WARNING and ERROR.
|
Monitor changes to the zone on an ongoing basis (in contrast to -D, which merely displays the current records).
NAME | NAME
Label or name of the record to add/delete/display.
|
List orphaned records.
|
Filter private records. Use in combination with --display.
|
Delete orphaned records from namestore.
|
Create a record that is public (shared with other users that know the label).
|
Changes the output format of zones and records to recordline.
|
Create a record that is a shadow record. Shadow records are only used once all other records of the same type under the same label have expired.
|
Read recordlines from stdin until EOF is encountered. The format uses : A record in a recordline follows the format

NAME.EGO:
TYPE EXPIRATION [FLAGS] VALUE
... Multiple records may be provided for a name.

EXPIRATION is given in microseconds without a unit (e.g. 3600000000 for 3600 seconds).

FLAGS is a concatenation of record flags. Possible values for flags and their meaning are:


p: Public
s: Shadow
S: Supplemental
C: Critical
r: Relative expiration

TYPE and VALUE are used in the same way as for the "-t" and "-V" options. Example formats for recordlines can be output using the "-D" flag combined with "--recordline". An example record set in recordline format can be found in the examples. It is possible to specify multiple record sets. Can only be used in combination with "-a" to add the parsed record sets. Existing record sets under names will be replaced.

|
Show maintenance records such as TOMBSTONEs. Use in combination with --display.
TYPE | TYPE
Type of the record to add/delete/display ("A"; "AAAA"; "NS"; "PKEY"; "MX"; etc.).
URI | URI
Add PKEY record from gnunet://gns/-URI to our zone; the record type is always PKEY, if no expiration is given FOREVER is used
|
Print GNUnet version number.
VALUE | VALUE
Value to store or remove from the GNS zone. Specific format depends on the record type. A records expect a dotted decimal IPv4 address, AAAA records an IPv6 address, PKEY a public key in GNUnet's printable format, and CNAME and NS records should be a domain name.
|
Delete all records in a zone.
EGO | EGO
Specifies the name of the ego controlling the private key for the zone. If not provided, we will attempt to use the default identity set for the "namestore". Alternatively, a private key may be passed in Base32-encoding using the GNUNET_NAMESTORE_EGO_PRIVATE_KEY environment variable. The latter is useful to improve performance of tools like Ascension as it allows the command to skip IPC with the identity management subsystem.
KEY | KEY
Determine our GNS name for the given public key (reverse lookup of the KEY) in the given zone.

EXAMPLES

gnunet-namestore -z example -a -n www -t A -V "1.2.3.4" -e 1d -p

Add a public record for ego example with name www containing an IP address.

gnunet-namestore -z example -D

Show all records for ego example
.

gnunet-namestore -z example -D -r

Show all records for ego example in recordline format.

gnunet-namestore --add --from-stdin <<EOF
www.alice:
A 3600000000 [pr] 1.2.3.4
TXT 3600000001 [pr] Hello World


www.bob:
A 12345679000000 [pr] 4.3.2.1
EOF

Read record sets in recordline format from stdin.

SEE ALSO

gnunet-gns(1), gnunet-namestore-gtk(1)

The full documentation for GNUnet is maintained as a Texinfo manual. If the info(1) and gnunet programs are properly installed at your site, the command

info gnunet

should give you access to the complete handbook,

info gnunet-c-tutorial

will give you access to a tutorial for developers.

Depending on your installation, this information is also available in gnunet(7) and gnunet-c-tutorial(7).

BUGS

Report bugs by using https://bugs.gnunet.org or by sending electronic mail to <gnunet-developers@gnu.org>.

April 15, 2014 Debian