-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathhelp.manual.txt
431 lines (364 loc) · 22.3 KB
/
help.manual.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
Welcome to "nostr-commander-rs", a Nostr CLI client. ─── On the first run use
--create-user to create a user. On further runs you can publish notes, send
private DM messages, etc. Alternatively, you can skip creating a user and do a
fire-and-forget publish like this: nostr-commander-rs --nsec
nsec1SomeStrangeString --add-relay "wss://some.relay.net/" --publish "test".
─── Have a look at the repo "https://github.com/8go/nostr-commander-rs/" and
see if you can contribute code to improve this tool. Safe!
Usage: nostr-commander-rs [OPTIONS]
Options:
--contribute
Please contribute
-v, --version [<CHECK>]
Print version number or check if a newer version exists on crates.io.
Details:: If used without an argument such as '--version' it will
print the version number. If 'check' is added ('--version check')
then the program connects to https://crates.io and gets the version
number of latest stable release. There is no "calling home" on every
run, only a "check crates.io" upon request. Your privacy is
protected. New release is neither downloaded, nor installed. It just
informs you
Possible values:
- check: Check if there is a newer version available
--usage
Prints a very short help summary. Details:: See also --help, --manual
and --readme
-h, --help
Prints short help displaying about one line per argument. Details::
See also --usage, --manual and --readme
--manual
Prints long help. Details:: This is like a man page. See also
--usage, --help and --readme
--readme
Prints README.md file, the documenation in Markdown. Details:: The
README.md file will be downloaded from Github. It is a Markdown file
and it is best viewed with a Markdown viewer. See also --usage,
--help and --manual
-d, --debug...
Overwrite the default log level. Details:: If not used, then the
default log level set with environment variable 'RUST_LOG' will be
used. If used, log level will be set to 'DEBUG' and debugging
information will be printed. '-d' is a shortcut for '--log-level
DEBUG'. If used once as in '-d' it will set and/or overwrite
--log-level to '--log-level debug'. If used twice as in '-d -d' it
will set and/or overwrite --log-level to '--log-level debug debug'.
And third or futher occurance of '-d' will be ignored. See also
'--log-level'. '-d' takes precedence over '--log-level'.
Additionally, have a look also at the option '--verbose'
--log-level <LOG_LEVEL>...
Set the log level by overwriting the default log level. Details:: If
not used, then the default log level set with environment variable
'RUST_LOG' will be used. If used with one value specified this value
is assigned to the log level of matrix-commander-rs. If used with two
values specified the first value is assigned to the log level of
matrix-commander-rs. The second value is asigned to the lower level
modules. More than two values should not be specified. --debug
overwrites -log-level. See also '--debug' and '--verbose'.
Alternatively you can use the RUST_LOG environment variable. An
example use of RUST_LOG is to use neither --log-level nor --debug,
and to set RUST_LOG="error,matrix_commander_rs=debug" which turns off
debugging on all lower level modules and turns debugging on only for
matrix-commander-rs
Possible values:
- none: None: not set, default
- error: Error: Indicates to print only errors
- warn: Warn: Indicates to print warnings and errors
- info: Info: Indicates to to print info, warn and errors
- debug: Debug: Indicates to to print debug and the rest
- trace: Trace: Indicates to to print everything
--verbose...
Set the verbosity level. Details:: If not used, then verbosity will
be set to low. If used once, verbosity will be high. If used more
than once, verbosity will be very high. Verbosity only affects the
debug information. So, if '--debug' is not used then '--verbose' will
be ignored
-c, --credentials <PATH_TO_FILE>
Specify a path to a file containing credentials. Details:: At
--create-user, information about the user, in particular its keys,
will be written to a credentials file. By default, this file is
"credentials.json". On further runs the credentials file is read to
permit acting as this established Nostr user. If this option is
provided, the provided path to a file will be used as credentials
file instead of the default one
[default:
/home/user/.local/share/nostr-commander-rs/credentials.json]
--create-user
Create a new user, i.e. a new key pair. Details:: This is usually
done only once at the beginning. If you ever want to wipe this user,
use '--delete-user' which deletes the key pair. Use this option in
combination with --name, --display_name, --about, --picture, --nip05,
and --nsec. Also highly recommended that you use this option together
with --add-relay. Add --nsec as option to import your existing nsec
private key, otherwise a new private key will be generated for you
--delete-user
Delete the current user, i.e. delete the current key pair. Details::
This will erase the key pair and other associated information like
user name, display name, etc. Afterwards one can create a new user
with '--create-user'
--name <USER_NAME>
Specify an optional user name. Details:: Used together with
'--create-user'. If this option is not set during '--create-user',
the information will be queried via the keyboard. If you want to set
it to empty and not be queried, provide an empty string ''
--display-name <DISPLAY_NAME>
Specify an optional display name. Details:: Used together with
'--create-user'. If this option is not set during '--create-user',
the information will be queried via the keyboard. If you want to set
it to empty and not be queried, provide an empty string ''
--about <DESCRIPTION>
Specify an optional description. Details:: Used together with
'--create-user'. If this option is not set during '--create-user',
the information will be queried via the keyboard. If you want to set
it to empty and not be queried, provide an empty string ''
--picture <URL>
Specify an optional picture or avatar. Details:: Used together with
'--create-user'. Provide a URL like 'https://example.com/avatar.png'.
If this option is not set during '--create-user', the information
will be queried via the keyboard. If you want to set it to empty and
not be queried, provide this URL 'none:'
--nip05 <NIP05_ID>
Specify an optional nip05 name. Details:: Used together with
'--create-user'. Provide a nip05 name like '[email protected]'. If
this option is not set during '--create-user', the information will
be queried via the keyboard. If you want to set it to empty and not
be queried, provide an empty string ''
--nsec <PRIVATE_KEY>
Provide one private key. Details:: It has the form
'nsec1SomeStrangeString'. Alternatively you can use the Hex form of
the private key. Since this is your private key, you must protect it.
Don't put this key into a script, into Github, etc. If --nsec is
provided it will be used instead of the private key in the
credentials file. This argument is used e.g. in combination with
argument --publish. If you are using --nsec without a credentials
file most likely you want to also use -ad-relay argument. If --nsec
is used without --create-user then the credentials file will not be
modified or will not be created
-p, --publish [<NOTE>...]
Publish one or multiple notes. Details:: Notes data must not be
binary data, it must be text. Input piped via stdin can additionally
be specified with the special character '-'. If you want to feed a
text message into the program via a pipe, via stdin, then specify the
special character '-'. If your message is literally a single letter
'-' then use an escaped '\-' or a quoted "\-". Depending on your
shell, '-' might need to be escaped. If this is the case for your
shell, use the escaped '\-' instead of '-' and '\\-' instead of '\-'.
However, depending on which shell you are using and if you are
quoting with double quotes or with single quotes, you may have to add
backslashes to achieve the proper escape sequences. If you want to
read the message from the keyboard use '-' and do not pipe anything
into stdin, then a message will be requested and read from the
keyboard. Keyboard input is limited to one line. The stdin indicator
'-' may appear in any position, i.e. --publish 'start' '-' 'end' will
send 3 messages out of which the second one is read from stdin. The
stdin indicator '-' may appear only once overall in all arguments.
'-' reads everything that is in the pipe in one swoop and sends a
single message. Similar to '-', another shortcut character is '_'.
The special character '_' is used for streaming data via a pipe on
stdin. With '_' the stdin pipe is read line-by-line and each line is
treated as a separate message and sent right away. The program waits
for pipe input until the pipe is closed. E.g. Imagine a tool that
generates output sporadically 24x7. It can be piped, i.e. streamed,
into nostr-commander, and nostr-commander stays active, sending all
input instantly. If you want to send the literal letter '_' then
escape it and send '\_'. '_' can be used only once. And either '-' or
'_' can be used
--publish-pow [<NOTE>...]
Publish one or multiple notes with proof-of-work (POW). Details:: Use
also '--pow-difficulty' to specify difficulty. See also '--publish'
to see how shortcut characters '-' (pipe) and '_' (streamed pipe) are
handled. Disabled since version nostr-commander-rs 0.2.0 (nostr-sdk
0.21)
--dm [<KEY+MSGS>...]
Send one or multiple DMs to one given user. Details:: DM messages
will be encrypted and preserve privacy. The single recipient is
specified via its public key, a string in the form of 'npub1...', a
Hex key, or an alias from one of your contacts. The first argument is
the recipient, all further arguments are texts to be sent. E.g. '-dm
"npub1SomeStrangeNumbers" "First msg" "Second msg"' or '--dm joe "How
about pizza tonight?"'. See also '--publish' to see how shortcut
characters '-' (pipe) and '_' (streamed pipe) are handled
--send-channel-message [<HASH+MSGS>...]
Send one or multiple messages to one given channel. Details:: The
single destination channel is specified via its hash. See here for a
channel list: https://damus.io/channels/. The first argument is the
channel hash, all further arguments are texts to be sent. E.g.
'-send_channel_message "SomeChannelHash" "First msg" "Second msg"'.
See also '--publish' to see how shortcut characters '-' (pipe) and
'_' (streamed pipe) are handled. Optionally you can provide a relay
to be used for the channel send by using --relay. See --relay. If
--relay has values the first value from --relay will be used as
relay. If --relay is not used, then the first relay in the relay list
in the credentials configuration file will be used
--add-relay [<RELAY_URI>...]
Add one or multiple relays. Details:: A relay is specified via a URI
that looks like 'wss://some.relay.org'. You can find relays by
looking at https://github.com/aljazceru/awesome-nostr#instances.
Sampler relay registries are: https://nostr-registry.netlify.app/,
https://nostr.info/, or https://nostr.watch/. Examples:
"wss://relay.damus.io", "wss://nostr.openchain.fr". See also
'--proxy'
--proxy <PROXY>
Specify a proxy for relays. Details:: Used by --add-relay. Note that
this proxy will be applied to all of the relays specified with
--add-relay. If you have 3 relays with 3 different proxies, then run
the --add-relay command 3 times with 1 relay and 1 proxy each time.
An example proxy for the Tor network looks something like
"127.0.0.1:9050". If you want to use Tor via a proxy, to assure that
no information leaks you must use only one relay, i.e. the Tor relay.
If more then one relays are configured, data will be communicated to
and from all relays. A possible relay that you can use together with
a Tor proxy is
"ws://jgqaglhautb4k6e6i2g34jakxiemqp6z4wynlirltuukgkft2xuglmqd.onion"
--remove-relay [<RELAY_URI>...]
Remove one or multiple relays from local config file. Details:: See
--add-relay
--tag <TAG>
Specify one or multiple tags to attach to notes or DMs. Details:: Not
yet implemented
--show-metadata
Display current metadata. Details:: shows data in your config file
--change-metadata
Modify existing metadata of the user. Details:: Use this option in
combination with --name, --display_name, --about, --picture, and
--nip05
--pow-difficulty <DIFFICULTY>
Specify optional proof-of-work (POW) difficulty. Details:: Use with
'--publish_pow' to specify difficulty. If not specified the default
will be used
[default: 20]
--show-public-key
Show public key. Details:: Displays your own public key. You can
share this with your friends or the general public
--show-secret-key
Show private, secret key. Details:: Protect this key. Do not share
this with anyone
--whoami
Print the user name used by "nostr-commander-rs". Details:: One can
get this information also by looking at the credentials file or by
using --show-metadata
-o, --output <OUTPUT_FORMAT>
Select an output format. Details:: This option decides on how the
output is presented. Currently offered choices are: 'text', 'json',
'json-max', and 'json-spec'. Provide one of these choices. The
default is 'text'. If you want to use the default, then there is no
need to use this option. If you have chosen 'text', the output will
be formatted with the intention to be consumed by humans, i.e.
readable text. If you have chosen 'json', the output will be
formatted as JSON. The content of the JSON object matches the data
provided by the nostr-sdk SDK. In some occassions the output is
enhanced by having a few extra data items added for convenience. In
most cases the output will be processed by other programs rather than
read by humans. Option 'json-max' is practically the same as 'json',
but yet another additional field is added. In most cases the output
will be processed by other programs rather than read by humans.
Option 'json-spec' only prints information that adheres 1-to-1 to the
Nostr Specification. Currently this type is not supported. If no data
is available that corresponds exactly with the Nostr Specification,
no data will be printed
[default: text]
Possible values:
- text: Text: Indicates to print human readable text, default
- json: Json: Indicates to print output in Json format
- json-max: Json Max: Indicates to to print the maximum anount of
output in Json format
- json-spec: Json Spec: Indicates to to print output in Json format,
but only data that is according to Nostr Specifications
-l, --listen
Listen to events, notifications and messages. Details:: This option
listens to events and messages forever. To stop, type Control-C on
your keyboard. You want to listen if you want to get the event ids
for published notices. Subscriptions do not automatically turn
listening on. If you want to listen to your subscriptions, you must
use --listen
--add-contact
Add one or more contacts. Details:: Must be used in combination with
--alias, --key, --relay. If you want to add N new contacts, use
--add-contact and provide exactly N entries in each of the 3 extra
arguments. E.g. --add-contact --alias jane joe --key
npub1JanesPublicKey npub1JoesPublicKey --relay
"wss://janes.relay.org" "wss://joes.relay.org". Aliases must be
unique. Alias can be seen as a nickname
--remove-contact
Remove one or more contacts. Details:: Must be used in combination
with --alias. For each entry in --alias the corresponding contact
will be removed. E.g. --remove-contact --alias jane joe
--show-contacts
Display current contacts. Details:: Prints your contact list
--alias [<ALIAS>...]
Provide one or multiple aliases (nicknames). Details:: This is used
in combination with arguments --add-contact and --remove-contact
--key [<KEY>...]
Provide one or multiple public keys. Details:: This is used in
combination with argument --add-contact. They have the form
'npub1SomeStrangeString'. Alternatively you can use the Hex form of
the public key
--relay [<RELAY>...]
Provide one or multiple relays. Details:: This is used in combination
with arguments --add-contact and --send_channel_message. Relays have
the form 'wss://some.relay.org'
--npub-to-hex [<KEY>...]
Convert one or multiple public keys from Npub to Hex. Details::
Converts public keys in Bech32 format ('npub1...') into the
corresponding 'hex' format. See also --hex-to-npub
--hex-to-npub [<KEY>...]
Convert one or multiple public keys from Hex to Npub. Details::
Converts public keys in 'hex' format into the corresponding Bech32
('npub1...') format. See also --npub-to-hex
--subscribe-pubkey [<KEY>...]
Subscribe to one or more public keys. Details:: Specify each public
key in form of 'npub1SomePublicKey'. Alternatively you can use the
Hex form of the public key. Use this option to subscribe to an
account, i.e. the key of an individual. See also --subscribe-channel
which are different
--subscribe-author [<KEY>...]
Subscribe to authors with to one or more public keys of accounts.
Details:: Specify each public key in form of 'npub1SomePublicKey'.
Alternatively you can use the Hex form of the public key. Use this
option to subscribe to a Nostr accounts (usually individuals).
Provide keys that represent accounts (see --get-pubkey-entity). See
also --subscribe-pubkey and --subscribe-channel which are different
--subscribe-channel [<HASH>...]
Subscribe to public channels with one or more hashes of channels.
Details:: Specify each hash in form of 'npub1SomePublicKey'.
Alternatively you can use the Hex form of the public key. Sometimes
the hash of a public channel is referred to as channel id, sometimes
also as public channel key. See here for a channel list:
https://damus.io/channels/. Provide hashes that represent public
channels (see --get-pubkey-entity). See also --subscribe-pubkey and
--subscribe-author which are different
--unsubscribe-pubkey [<KEY>...]
Unsubscribe from public key. Details:: Removes one or multiple public
keys from the public key subscription list. See --subscribe-pubkey
--unsubscribe-author [<KEY>...]
Unsubscribe from author. Details:: Removes one or multiple public
keys from the author subscription list. See --subscribe-author
--unsubscribe-channel [<KEY>...]
Unsubscribe from public channel. Details:: Removes one or multiple
public keys from the public channel subscription list. See
--subscribe-channel
--limit-number <NUMBER>
Limit the number of past messages to receive when subscribing.
Details:: By default there is no limit (0), i.e. all old messages
available to the relay will be received
[default: 0]
--limit-days <DAYS>
Limit the messages received to the last N days when subscribing.
Details:: By default there is no limit (0), i.e. all old messages
available to the relay will be received
[default: 0]
--limit-hours <HOURS>
Limit the messages received to the last N hours when subscribing.
Details:: By default there is no limit (0), i.e. all old messages
available to the relay will be received
[default: 0]
--limit-future-days <DAYS>
Limit the messages received to the next N days when subscribing.
Details:: Stop receiving N days in the future. By default there is no
limit (0), i.e. you will receive events forever
[default: 0]
--limit-future-hours <HOURS>
Limit the messages received to the last N hours when subscribing.
Details:: Stop receiving N hours in the future. By default there is
no limit (0), i.e. you will receive events forever
[default: 0]
PS: Also have a look at scripts/nostr-commander-tui.