author | convert-repo |
Sun, 07 May 2017 21:55:09 +0000 | |
changeset 100 | 41f4b0b43f3b |
parent 98 | dd260cff924e |
child 102 | 84ad56b643c8 |
permissions | -rw-r--r-- |
0 | 1 |
# madonctl |
2 |
||
3 |
Golang command line interface for the Mastodon API |
|
4 |
||
5 |
[![license](https://img.shields.io/badge/license-MIT-blue.svg?style=flat)](https://raw.githubusercontent.com/McKael/madonctl/master/LICENSE) |
|
2 | 6 |
[![Build Status](https://travis-ci.org/McKael/madonctl.svg?branch=master)](https://travis-ci.org/McKael/madonctl) |
0 | 7 |
|
8 |
`madonctl` is a [Go](https://golang.org/) CLI tool to use the Mastondon REST API. |
|
9 |
||
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
10 |
It is built on top of [madon](https://github.com/McKael/madon), my Golang implementation of the API. |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
11 |
|
0 | 12 |
## Installation |
13 |
||
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
14 |
### From source |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
15 |
|
37
9bc03db114c3
Add server statistics with gomif (using instances.mastodon.xyz API)
Mikael Berthe <mikael@lilotux.net>
parents:
32
diff
changeset
|
16 |
To install the application from source (you need to have Go >= 1.7), just type: |
0 | 17 |
|
54 | 18 |
go get -u github.com/McKael/madonctl |
0 | 19 |
|
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
20 |
and you should be able to run `madonctl`. |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
21 |
|
54 | 22 |
For upgrades, don't forget the `-u` option to ensure the dependencies |
23 |
(especially [madon](https://github.com/McKael/madon)) are updated as well. |
|
21 | 24 |
|
25 |
Travis automated testing is run for Go versions 1.7 and 1.8. |
|
26 |
||
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
27 |
### Download |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
28 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
29 |
Check the [Release page](https://github.com/McKael/madonctl/releases) for some pre-built binaries. |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
30 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
31 |
More pre-built binaries are available from the [Homepage](https://lilotux.net/~mikael/pub/madonctl/) (development version and builds for a few other platforms). |
0 | 32 |
|
33 |
## Usage |
|
34 |
||
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
35 |
### Configuration |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
36 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
37 |
In order to use madonctl, you need to specify the instance name or URL, and |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
38 |
usually provide an account login/password (or a token). |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
39 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
40 |
These settings can be passed as command line arguments or environment variables, |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
41 |
but the easiest way is to use a configuration file. |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
42 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
43 |
Note that you can generate a configuration file for your settings with |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
44 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
45 |
`madonctl config dump -i mastodon.social -L username@domain -P password` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
46 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
47 |
(You can redirect the output to a configuration file.) |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
48 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
49 |
If you only provide the Mastodon instance, it will generate a configuration file with an application ID/secret for this instance and you will have to add the user credentials. |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
50 |
|
79
bca27c55be9f
Add default visibility setting
Mikael Berthe <mikael@lilotux.net>
parents:
75
diff
changeset
|
51 |
Note that every variable from the configration file can also be set with an environment variable (e.g. `export MADONCTL_INSTANCE='https://mamot.fr'`). |
bca27c55be9f
Add default visibility setting
Mikael Berthe <mikael@lilotux.net>
parents:
75
diff
changeset
|
52 |
|
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
53 |
### Usage |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
54 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
55 |
The complete list of commands is available in the online help (`madonctl help`, `madonctl command --help`...) |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
56 |
or in the [manpages](https://lilotux.net/~mikael/pub/madonctl/manual/html/). The [Homepage](https://lilotux.net/~mikael/pub/madonctl/) also contains a plain list of commands. |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
57 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
58 |
### Examples |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
59 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
60 |
To post a simple "toot": |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
61 |
``` sh |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
62 |
% madonctl toot "Hello, World" |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
63 |
``` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
64 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
65 |
You can change the toot visibility, add a Content Warning (a.k.a. spoiler) or send a media file: |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
66 |
``` sh |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
67 |
% madonctl toot --visibility direct "@McKael Hello, you" |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
68 |
% madonctl toot --visibility private --spoiler CW "The answer was 42" |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
69 |
% madonctl post --file image.jpg Selfie # Send a media file |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
70 |
``` |
79
bca27c55be9f
Add default visibility setting
Mikael Berthe <mikael@lilotux.net>
parents:
75
diff
changeset
|
71 |
Note: The default toot visibility can be set in the configuration file with |
bca27c55be9f
Add default visibility setting
Mikael Berthe <mikael@lilotux.net>
parents:
75
diff
changeset
|
72 |
the `default_visibility` setting or with the environment variable (example |
bca27c55be9f
Add default visibility setting
Mikael Berthe <mikael@lilotux.net>
parents:
75
diff
changeset
|
73 |
`export MADONCTL_DEFAULT_VISIBILITY=unlisted`). |
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
74 |
|
17 | 75 |
Send (text) file content as new message: |
76 |
``` |
|
77 |
% madonctl toot --text-file message.txt |
|
78 |
``` |
|
79 |
||
72 | 80 |
... or read message from standard input: |
81 |
``` |
|
82 |
% echo "Hello from #madonctl" | madonctl toot --stdin |
|
83 |
``` |
|
84 |
||
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
85 |
Some account-related commands: |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
86 |
``` sh |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
87 |
% madonctl accounts blocked # List blocked accounts |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
88 |
% madonctl accounts muted # List muted accounts |
31 | 89 |
% madonctl accounts notifications --list --all # List really all notifications |
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
90 |
% madonctl accounts notifications --list --clear # List and clear notifications |
19
4c81f4393773
Add notification --dismiss to clear a single notification
Mikael Berthe <mikael@lilotux.net>
parents:
17
diff
changeset
|
91 |
% madonctl accounts notifications --notification-id 1234 # Display notification |
4c81f4393773
Add notification --dismiss to clear a single notification
Mikael Berthe <mikael@lilotux.net>
parents:
17
diff
changeset
|
92 |
% madonctl accounts notifications --dismiss --notification-id 1234 # Mastodon 1.3+ |
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
93 |
``` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
94 |
|
32 | 95 |
Note: By default, madonctl will send a single query. If you want all available |
96 |
results you should use the `--all` flag. If you use a `--limit` value, |
|
97 |
madonctl might send several queries until the number of results reaches this |
|
98 |
value. |
|
99 |
||
7
df3e9e068778
Update documentation wrt accounts update
Mikael Berthe <mikael@lilotux.net>
parents:
5
diff
changeset
|
100 |
Update your account information: |
df3e9e068778
Update documentation wrt accounts update
Mikael Berthe <mikael@lilotux.net>
parents:
5
diff
changeset
|
101 |
``` sh |
df3e9e068778
Update documentation wrt accounts update
Mikael Berthe <mikael@lilotux.net>
parents:
5
diff
changeset
|
102 |
% madonctl accounts update --display-name "John" # Update display name |
df3e9e068778
Update documentation wrt accounts update
Mikael Berthe <mikael@lilotux.net>
parents:
5
diff
changeset
|
103 |
% madonctl accounts update --note "Newcomer" # Update user note (bio) |
df3e9e068778
Update documentation wrt accounts update
Mikael Berthe <mikael@lilotux.net>
parents:
5
diff
changeset
|
104 |
% madonctl accounts update --note "" # Clear note |
df3e9e068778
Update documentation wrt accounts update
Mikael Berthe <mikael@lilotux.net>
parents:
5
diff
changeset
|
105 |
% madonctl accounts update --avatar me.png # Update avatar |
df3e9e068778
Update documentation wrt accounts update
Mikael Berthe <mikael@lilotux.net>
parents:
5
diff
changeset
|
106 |
``` |
df3e9e068778
Update documentation wrt accounts update
Mikael Berthe <mikael@lilotux.net>
parents:
5
diff
changeset
|
107 |
|
31 | 108 |
See your own posts: |
109 |
``` sh |
|
110 |
% madonctl accounts statuses # See last posts |
|
111 |
% madonctl accounts statuses --all # See all statuses |
|
112 |
% madonctl accounts --user-id Gargron@mastodon.social -l5 # Last 5 statuses |
|
113 |
``` |
|
114 |
||
115 |
You can specify the (instance-specific) account ID number (--account-id) or |
|
116 |
the user ID (--user-id). In the later case, madonctl will search for the |
|
117 |
user so it must match exactly the ID known to your instance (without the |
|
118 |
@domain suffix if the user is on the same instance). |
|
119 |
||
120 |
Display accounts you're following or your followers: |
|
121 |
``` sh |
|
122 |
% madonctl accounts following # See last following |
|
123 |
% madonctl accounts following --all # See all followed accounts |
|
124 |
% madonctl accounts followers --limit 30 # Last 30 followers |
|
125 |
``` |
|
126 |
||
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
127 |
Add/remove a favourite, boost a status... |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
128 |
``` sh |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
129 |
% madonctl status --status-id 416671 favourite # Fave a status |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
130 |
% madonctl status --status-id 416671 boost # Boost a status |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
131 |
``` |
0 | 132 |
|
5
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
133 |
Search for an account (only accounts known to your instance): |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
134 |
``` sh |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
135 |
% madonctl accounts search gargron |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
136 |
``` |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
137 |
|
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
138 |
Follow an account with known ID: |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
139 |
``` sh |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
140 |
% madonctl accounts follow --account-id 1234 |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
141 |
``` |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
142 |
|
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
143 |
Follow a remote account: |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
144 |
``` sh |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
145 |
% madonctl accounts follow --remote Gargron@mastodon.social |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
146 |
``` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
147 |
|
5
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
148 |
Read timelines: |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
149 |
``` sh |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
150 |
% madonctl timeline # Display home timeline |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
151 |
% madonctl timeline public # Display federated timeline |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
152 |
% madonctl timeline public --local # Display public local timeline |
24 | 153 |
|
154 |
% madonctl timeline --limit 3 # Display 3 latest home timeline messages |
|
5
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
155 |
``` |
d70f8e8f3d2e
Add examples with accounts and timelines
Mikael Berthe <mikael@lilotux.net>
parents:
4
diff
changeset
|
156 |
|
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
157 |
Use the streaming API and fetch timelines and notifications: |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
158 |
``` sh |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
159 |
% madonctl stream # Stream home timeline and notifications |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
160 |
% madonctl stream local # Stream local timeline |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
161 |
% madonctl stream public # Stream federated timeline |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
162 |
``` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
163 |
|
75
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
164 |
You can also use hashtag streams: |
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
165 |
``` sh |
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
166 |
% madonctl stream :mastodon # Stream for hastag 'mastodon' |
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
167 |
% madonctl stream :madonctl,golang # Stream for several hashtags |
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
168 |
``` |
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
169 |
|
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
170 |
Please note that madonctl will use one socket per stream, so the number of |
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
171 |
concurrent hashtags is currently limited to 4 for "politeness". |
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
172 |
|
447ac88b67c6
Update README documentation wrt streams
Mikael Berthe <mikael@lilotux.net>
parents:
72
diff
changeset
|
173 |
|
98
dd260cff924e
Minor documentation updates
Mikael Berthe <mikael@lilotux.net>
parents:
92
diff
changeset
|
174 |
(Almost) All commands have a customisable output: |
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
175 |
``` sh |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
176 |
% madonctl accounts show # Display an account |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
177 |
% madonctl accounts show -o yaml # Display an account, in yaml |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
178 |
% madonctl accounts show -o json # Display an account, in json |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
179 |
% madonctl stream local -o json # Stream local timeline and output to JSON |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
180 |
``` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
181 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
182 |
You can also use Go (Golang) templates: |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
183 |
``` sh |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
184 |
% madonctl accounts --account-id 1 followers --template '{{.acct}}{{"\n"}}' |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
185 |
``` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
186 |
|
92 | 187 |
Number of users on current instance (madonctl 0.5+) (statistics from instances.mastodon.xyz API): |
37
9bc03db114c3
Add server statistics with gomif (using instances.mastodon.xyz API)
Mikael Berthe <mikael@lilotux.net>
parents:
32
diff
changeset
|
188 |
``` |
9bc03db114c3
Add server statistics with gomif (using instances.mastodon.xyz API)
Mikael Berthe <mikael@lilotux.net>
parents:
32
diff
changeset
|
189 |
madonctl instance --stats --template '{{printf "%v\n" .users}}' |
9bc03db114c3
Add server statistics with gomif (using instances.mastodon.xyz API)
Mikael Berthe <mikael@lilotux.net>
parents:
32
diff
changeset
|
190 |
``` |
9bc03db114c3
Add server statistics with gomif (using instances.mastodon.xyz API)
Mikael Berthe <mikael@lilotux.net>
parents:
32
diff
changeset
|
191 |
|
92 | 192 |
You can write and use [themes](templates) as well (madonctl 0.6+): |
193 |
``` |
|
194 |
madonctl --theme=ansi timeline |
|
195 |
``` |
|
196 |
||
4
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
197 |
There are many more commands, you can find them in the online help or the manpage. |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
198 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
199 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
200 |
### Shell completion |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
201 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
202 |
If you want shell completion, you can generate scripts with the following command: \ |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
203 |
`madonctl completion bash` (or zsh) |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
204 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
205 |
Then, just source the script in your shell. |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
206 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
207 |
For example, I have this line in my .zshrc: |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
208 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
209 |
`source <(madonctl completion zsh)` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
210 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
211 |
### Commands output |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
212 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
213 |
The output can be set to json, yaml or to a Go template for all commands.\ |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
214 |
If you are familiar with Kubernetes' kubectl, it is very similar. |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
215 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
216 |
For example, you can display your user token with:\ |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
217 |
`madonctl config whoami --template '{{.access_token}}'`\ |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
218 |
or the application ID with:\ |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
219 |
`madonctl config dump --template '{{.ID}}'` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
220 |
|
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
221 |
All the users that have favorited a given status:\ |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
222 |
`madonctl status --status-id 101194 favourited-by --template '{{.username}}{{"\n"}}'` |
a3b95e2f0b0b
Update README - add some documentation
Mikael Berthe <mikael@lilotux.net>
parents:
2
diff
changeset
|
223 |
|
24 | 224 |
For more complex templates, one can use the `--template-file` option.\ |
225 |
See the [templates](templates) folder. |
|
0 | 226 |
|
227 |
## References |
|
228 |
||
229 |
- [madon](https://github.com/McKael/madon), the Go library for Mastodon API |
|
230 |
- [Mastodon API documentation](https://github.com/tootsuite/documentation/blob/master/Using-the-API/API.md) |
|
231 |
- [Mastodon repository](https://github.com/tootsuite/mastodon) |