69 lines
2.1 KiB
JavaScript
Executable File
69 lines
2.1 KiB
JavaScript
Executable File
#!/usr/bin/env node
|
|
'use strict';
|
|
|
|
// dig -p 53 @redirect-www.org pi.nadal.daplie.com A
|
|
var updateIp = require('./holepunch/helpers/update-ip.js').update;
|
|
var cli = require('cli');
|
|
|
|
cli.parse({
|
|
service: [ 's', 'The service to use for updates i.e. redirect-www.org', 'string', 'redirect-www.org' ]
|
|
, hostname: [ 'h', 'The hostname you wish to update i.e. example.com', 'string' ]
|
|
, type: [ 't', 'The record type i.e. A, MX, CNAME, etc', 'string', 'A' ]
|
|
, priority: [ 'p', 'The priority (for MX and other records)', 'string' ]
|
|
, port: [ false, 'The port (default https/443)', 'number', 443 ]
|
|
, insecure: [ false, '(deprecated) allow insecure non-https connections', 'boolean' ]
|
|
, cacert: [ false, '(not implemented) specify a CA for "self-signed" https certificates', 'string' ]
|
|
, answer: [ 'a', 'The answer', 'string' ]
|
|
, token: [ false, 'Token (TODO or filepath to token)', 'string' ]
|
|
});
|
|
|
|
cli.main(function (args, options) {
|
|
//console.log(options);
|
|
options.hostname = options.hostname || args[0]
|
|
options.answer = options.answer || args[1]
|
|
|
|
if (options.insecure) {
|
|
//console.error('--insecure is not supported. You must use secure connections.');
|
|
//return;
|
|
options.cacert = false;
|
|
}
|
|
|
|
if (!options.hostname) {
|
|
console.error('Usage: ddns-client HOSTNAME ANSWER -t A -s updater.mydns.com');
|
|
console.error('Example: ddns-client example.com');
|
|
console.error('Note: if you omit ANSWER, it is assumed that the dyndns service will use the request ip');
|
|
return;
|
|
}
|
|
|
|
//console.log('args');
|
|
//console.log(args);
|
|
//console.log(options);
|
|
|
|
return updateIp({
|
|
updater: options.service
|
|
, port: options.port
|
|
, cacert: options.cacert
|
|
, token: options.token
|
|
, ddns: [
|
|
{ "name": options.hostname
|
|
, "value": options.answer
|
|
, "type": options.type
|
|
, "priority": options.priority
|
|
, "token": options.token
|
|
}
|
|
]
|
|
}).then(function (data) {
|
|
if ('string') {
|
|
try {
|
|
data = JSON.parse(data);
|
|
} catch(e) {
|
|
console.error(data);
|
|
}
|
|
}
|
|
|
|
console.log(JSON.stringify(data, null, ' '));
|
|
console.log('Test with');
|
|
console.log('dig ' + options.hostname + ' ' + options.type);
|
|
});
|
|
});
|