108 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # matrix.sh
 | |
| 
 | |
| matrix.sh is a bash script to send messages to a matrix chat.
 | |
| 
 | |
| ## Features
 | |
| * Interactively log in to a server.
 | |
| * Select a default chat to use.
 | |
| * Send text messages.
 | |
| * Optionally enable parsing of HTML tags.
 | |
| * Directly pipe command output to the script and get it automatically
 | |
| wrapped in <pre> tags.
 | |
| * Send files, optionally as audio, image or video.
 | |
| 
 | |
| ## Installation
 | |
| * Download matrix.sh, either by using `git clone` or something like `wget
 | |
|   ...` and put it somewhere in your path or whatever.
 | |
| * Install dependencies:
 | |
|     * `curl`
 | |
|     * `jq`
 | |
| 
 | |
|     Something like `sudo apt-get install curl jq`.
 | |
| * Use it to log in. See Usage.
 | |
| 
 | |
| ## Usage
 | |
| ### Logging in
 | |
| Use `login`. The script will try to resolve delegation via the
 | |
| `/.well-known/matrix/server` path. If that doesn't work, you'll get an error
 | |
| message.
 | |
| 
 | |
| Your login token will be saved to the file `.matrix.sh` in your home folder.
 | |
| If it already exists, it will be overwritten. Since the contents of this
 | |
| file allow accessing your homeserver, you should keep it's contents secret.
 | |
| Therefore, it will be created with access mode 600.
 | |
| 
 | |
| ```
 | |
| $ ./matrix.sh login
 | |
| Address of the homeserver the account lives on: matrix.org
 | |
| Username on the server (just the local part, so e.g. 'bob'): bob
 | |
| bob's password:
 | |
| 
 | |
| Success. Access token saved to ~/.matrix.sh
 | |
| You should now use ./matrix.sh -s to select a default room.
 | |
| ```
 | |
| 
 | |
| ### Selecting a default room
 | |
| You can select a default room which will be used if you don't provide a
 | |
| room_id at runtime.
 | |
| 
 | |
| It will show all joined rooms as well as rooms you are invited to. Selecting
 | |
| one of the latter will also accept the invitation and join that room.
 | |
| 
 | |
| ```
 | |
| $ ./matrix.sh select-default-room
 | |
| Getting Rooms...
 | |
| Joined rooms:
 | |
|   !GCHxYlasvdh778dsOx:matrix.org - Me and my server
 | |
|   !OEassajhhkasLULVAa:matrix.org - <Unnamed>
 | |
| 
 | |
| Rooms I'm invited to:
 | |
|   !2o587thjlgjHUIUHni:matrix.org - <Unnamed>
 | |
| 
 | |
| Which room do you want to use?
 | |
| Enter the room_id (the thing at the beginning of the line):
 | |
| !2o587thjlgjHUIUHni:matrix.org
 | |
| 
 | |
| Saved default room to ~/.matrix.sh
 | |
| ```
 | |
| 
 | |
| ### Sending messages
 | |
| #### Sending a normal text message:
 | |
| ```
 | |
| $ ./matrix.sh send "Hello World"
 | |
| ```
 | |
| 
 | |
| #### Sending a text message with markup:
 | |
| ```
 | |
| $ ./matrix.sh send --html "This is <strong>very important</strong>."
 | |
| ```
 | |
| 
 | |
| #### Piping command output:
 | |
| ```
 | |
| $ echo "Hello" | ./matrix.sh send
 | |
| ```
 | |
| 
 | |
| #### Code formatting:
 | |
| You can use `--pre` to send messages formatted as code. This will also escape
 | |
| HTML tags.
 | |
| ```
 | |
| $ ls -l | ./matrix.sh send --pre
 | |
| ```
 | |
| 
 | |
| #### Sending files:
 | |
| ```
 | |
| $ ./matrix.sh send --file=upload.zip
 | |
| ```
 | |
| Additionally use `--audio`, `-image` or `--video` to send files as audio, images or
 | |
| video, respectively:
 | |
| ```
 | |
| $ ./matrix.sh send --file=IMG1234.jpg --image
 | |
| ```
 | |
| 
 | |
| #### Providing a room:
 | |
| You can use `--room=<room_id>` to provide a room_id. This supersedes the default room.
 | |
| ```
 | |
| $ ./matrix.sh send --room_id='!OEassajhhkasLULVAa:matrix.org' "Hello World"
 | |
| ```
 | |
| (Note: bash doesn't like exclamation marks in double quoted strings. So we
 | |
| use single quotes for the room id.)
 |