1
0

Add prog: SynoCtrl

This commit is contained in:
2019-03-19 17:18:55 +01:00
parent 34ccf6633a
commit 2ff82cd61e
3 changed files with 208 additions and 1 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 43 KiB

View File

@@ -0,0 +1,188 @@
# SynoCtrl [![Build status](https://ci.appveyor.com/api/projects/status/lk6vwv65v7cmy98b?svg=true)](https://ci.appveyor.com/project/Mikescher/synoctrl)
SynoCtrl is a command-line program to remotely control your Synology NAS
## Features
- Show Synology status (`synoctrl status-all [<name>] [--info] [options]`)
- Shutdown Synology NAS (`synoctrl shutdown [<name>] [options]`)
- Reboot Synology NAS (`synoctrl reboot [<name>] [options]`)
- Boot up Synology NAS via WOL (`synoctrl wol [<name>] [options]`)
- Send ping package (`synoctrl ping [<name>] [options]`)
- Get IP adress by MAC (`synoctrl getip [<name>] [options]`)
- Get MAC address by IP via ARP (`synoctrl getmac [<name>] [options]`)
## Configuration
You do not need to create a configuration file and can use SynoCtrl completely portable only via command-line parameter.
But (for convenience) you can specify properties of your NAS (or multiple NAS') in a config file and reference them in your program call:
~~~TOML
Default = "MyDevice" # The default device to use if no specific device is specified
# Can be removed if there shall be no default device.
[[Device]]
Name = "MyDevice" # Device name
IP = "192.168.0.20" # IP address (optional)
Port = 1924 # Port of DiskStation WebInterface (optional)
HTTPS = false # Enable HTTPS Communication (optional)
Mac = "00-11-22-33-44-55" # MAC address (optional)
Username = "usr" # DSM Web interface username (optional)
Password = "pass" # DSM Web interface password (optional)
# You can add more than one device:
# [[Device]]
# Name = "Demo2" # Device name
# IP = "10.10.10.99" # IP address (optional)
# Port = 1924 # Port of DiskStation WebInterface (optional)
# HTTPS = false # Enable HTTPS Communication (optional)
# Mac = "00-A1-B2-C3-D4-E5" # MAC address (optional)
# Username = "admin" # DSM Web interface username (optional)
# Password = "admin" # DSM Web interface password (optional)
# You can add more devices here and use them by their device-names in the command-line interface
# ...
~~~
*(This is [TOML](https://github.com/toml-lang/toml) syntax)*
Then you can call `synoctrl shutdown MyDevice` to shutdown the device with the name "MyDevice".
If no config file exists or no device name is given you have to supply all necessary parameters via command-line parameter (In this case `--ip`, `--username`, `--password`)
All fields except the *Name* field are optional in the TOML config file are optional and can be removed, in this case you need to supply these parameters in the program call if they are necessary.
The config file location can be set with the command line parameter `--config`. If no `--config` parameter is set the standard locations are searched for a config file (in this order):
- `%program_dir%\synoctrl.toml`
- `%userprofile%\.config\synoctrl.toml`
- `%userprofile%\synoctrl.toml`
- `%appdata%\synoctrl\synoctrl.toml`
You can create a example config file with the command `synoctrl create-config synoctrl.toml`
## Options / Command-line parameter
| Parameter | Description |
| -- | -- |
| `-h` `--help` | Show the command-line help |
| `--version` | Show the version |
| `--mac <mac>` | The MAC address of the device |
| `--ip <ip>` | The IP address of the device |
| `--port <port>` | The Port of the DSM Web interface (if not set the default port 5000/5001 is used |
| `--https` | Use a TLS encrypted connection to the DSM Web interface |
| `-u <user>` `--user <user>` | The username for the DSM Web interface (and API) |
| `-p <pass>` `--password <pass>` | The password for the DSM Web interface (and API) |
| `-c <config>` `--config <config>` | Use the config file at this specific path, do not search in other places |
| `-s`, `--silent` | Only output the result (or errors), useful if you want to parse the output |
| `-v`, `--verbose` | Output debug/trace messages, useful for debugging |
## Commands
### Shutdown/Reboot
You can shutdown the device `Melkor` with the command `synoctrl shutdown MyDevice`.
This uses the Synology DSM API to send an shutdown request.
If you do not have a configuration file you can supply all parameter by yourself:
`synoctrl shutdown --ip 192.168.0.100 --user admin --password admin`
If you want to reboot your device (instead of shutdown) you can use the *reboot* command `synoctrl reboot MyDevice`
### Boot-up (Wake-on-LAN)
You can boot the device by sending a Wake-on-LAN package to the MAC address of your NAS.
For this to work you have to [enable WOL in your device config](https://www.synology.com/en-us/knowledgebase/search/Wake%20on%20LAN).
The command is `synoctrl wol MyDevice`, if you do not have a configured device the command is `synoctrl wol --mac 00:11:22:33:44:55`
### Get IP/MAC address
For convenience two commands are available to get the MAC address from an IP address (via ARP) and to get the IP address from a MAC address (via you local ARP table):
`synoctrl getip MyDevice` and `synoctrl getmac MyDevice` or `synoctrl getip --mac 00:11:22:33:44:55` and `synoctrl getmac --ip 192.168.0.100`.
For obvious reasons *getip* only works when the device is powered on (and accepts ARP requests) and *getmac* only works if the device is already in your local ARP table.
### Status
SynoCtrl can show many different status fields. All these data is gathered via the API, so if you don't have a config file with the respective data supplied you need to at least set the parameters `--ip`, `--username` and `--password`.
You can list all available status fields with `synoctrl status-list` (see [Appendix 1](#appendix-1-available-status-fields)).
The *status-all* command returns all available status fields, this can take a moment because multiple API endpoints have to be called. (`synoctrl status-all MyDevice`).
But the normal way is to call *status* together with a comma-separated list of fields you want to get:
`synoctrl status Model,MemoryUsageReal,Uptime MyDevice` or `synoctrl status Load5min MyDevice`
If you only want the raw unformatted value you can add `--silent` and if you want the value together with the field description you can add `--info`
##Contribution
Contributions are always welcome, if you're missing something feel free to send a pull request. Also if you find a bug or have a feature request create an [issue](https://github.com/Mikescher/SynoCtrl/issues).
## License
[MIT](https://github.com/Mikescher/AlephNote/blob/master/LICENSE)
## Appendix 1: Available Status fields
~~~
Name | Description
------------------------|------------------------------------------------------
Model | The model of the device
RAM | The amount of installed RAM
Serial | The serial number
Temperature | The current device temperature
DeviceTime | The current device time
Uptime | Time since last boot
UptimeStr | Time since last boot as formatted value
VersionString | Currently running DSM version
VersionRaw | Currently running DSM version number
IsSystemCrashed | Indicator if the system experienced a crash
IsUpgradeReady | Indicator if the system is ready to upgrade
Hostname | The DSM hostname
UserIsAdmin | If the logged-in user is an administrator
UserSupportsSharing | Whether the logged-in user can share file(s)/folder(s)
UserID | UserID of the logged-in user
ShareCount | Number of shares
ConnectionCount | Number of active connections
ArpIgnore | Ignore ARP requests
DnsManual | The manual configured DNS server
PrimaryDNS | The configured primary DNS server
SecondaryDNS | The configured secondary DNS server
WinDomain | The configured Windows Domain
Gateway | The configured Gateway
ServerName | The server name
GatewayIPv6 | The configured IPv6 Gateway
Services | All services
ServicesEnabled | Enabled services
ClockSpeed | Clock speed of the CPU
CoreCount | Number of CPU cores
CPUFamily | CPU family
CPUSeries | CPU series
CPUVendor | CPU vendor
NTPEnabled | Whether NTP enabled is
FirmwareDate | Date of the firmware
FirmwareVersion | Version of the firmware
NTPServer | Configued NTP server
Timezone | Configued timezone
Load15min | Load average in the last 15 minutes
Load5min | Load average in the last 5 minutes
Load1min | Load average in the last minute
DiscCount | Number of mounted disks
RamAvailableReal | Available (real) RAM in bytes
RamAvailableSwap | Available (swap) RAM in bytes
BufferSize | Buffer size
CachedSize | Cached size
MemorySize | Memory size
MemoryUsageReal | Memory usage (real)
MemoryUsageSwap | Memory usage (swap)
TotalMemoryReal | Total memory (real)
TotalMemorySwap | Total Memory (swap)
NetworkLoadTransmit | Network load Recieve (RX)
NetworkLoadRecieve | Network load Transmit (TX)
DiskAccessReadCount | Disk utilization Read count
DiskAccessReadBytes | Disk utilization Read amount in bytes
DiskAccessWriteCount | Disk utilization Write count
DiskAccessWriteBytes | Disk utilization Write amount in bytes
UserCount | Amount of configured users
~~~

View File

@@ -648,7 +648,7 @@ return
'prog_language' => 'Java', 'prog_language' => 'Java',
'short_description' => 'SimpleCloudNotifier is a app to display messages that you can send to your phone with a simple POST request.', 'short_description' => 'SimpleCloudNotifier is a app to display messages that you can send to your phone with a simple POST request.',
'add_date' => '2018-11-19', 'add_date' => '2018-11-19',
'license' => null, 'license' => 'MIT',
'urls' => 'urls' =>
[ [
'playstore' => 'https://play.google.com/store/apps/details?id=com.blackforestbytes.simplecloudnotifier', 'playstore' => 'https://play.google.com/store/apps/details?id=com.blackforestbytes.simplecloudnotifier',
@@ -662,4 +662,23 @@ return
'SCN_03.png', 'SCN_03.png',
], ],
], ],
[
'name' => 'SynoCtrl',
'internal_name' => 'SynoCtrl',
'internal_name_alt' => null,
'category' => 'Commandline',
'stars' => 4,
'ui_language' => 'English',
'prog_language' => 'C#',
'short_description' => 'A command-line interface to remotely control your Synology NAS',
'add_date' => '2019-03-19',
'license' => 'MIT',
'urls' =>
[
'github' => 'https://github.com/Mikescher/SynoCtrl',
'download' => 'https://github.com/Mikescher/SynoCtrl/releases',
],
],
]; ];