summaryrefslogtreecommitdiff
path: root/source3
diff options
context:
space:
mode:
Diffstat (limited to 'source3')
-rw-r--r--source3/utils/net_time.c36
1 files changed, 30 insertions, 6 deletions
diff --git a/source3/utils/net_time.c b/source3/utils/net_time.c
index f99eb9054d..20d51e2a41 100644
--- a/source3/utils/net_time.c
+++ b/source3/utils/net_time.c
@@ -25,7 +25,7 @@
/*
return the time on a server. This does not require any authentication
*/
-static time_t cli_servertime(const char *host, struct in_addr *ip)
+static time_t cli_servertime(const char *host, struct in_addr *ip, int *zone)
{
struct nmb_name calling, called;
time_t ret = 0;
@@ -57,6 +57,7 @@ static time_t cli_servertime(const char *host, struct in_addr *ip)
}
ret = cli->servertime;
+ if (zone) *zone = cli->serverzone;
done:
if (cli) cli_shutdown(cli);
@@ -64,12 +65,12 @@ done:
}
/* find the servers time on the opt_host host */
-static time_t nettime(void)
+static time_t nettime(int *zone)
{
extern BOOL opt_have_ip;
extern struct in_addr opt_dest_ip;
extern char *opt_host;
- return cli_servertime(opt_host, opt_have_ip? &opt_dest_ip : NULL);
+ return cli_servertime(opt_host, opt_have_ip? &opt_dest_ip : NULL, zone);
}
/* return a time as a string ready to be passed to date -u */
@@ -92,6 +93,7 @@ int net_time_usage(int argc, const char **argv)
"net time\n\tdisplays time on a server\n\n"\
"net time system\n\tdisplays time on a server in a format ready for /bin/date\n\n"\
"net time set\n\truns /bin/date -u with the time from the server\n\n"\
+"net time zone\n\tdisplays the timezone in hours from GMT on the remote computer\n\n"\
"\n");
general_rap_usage(argc, argv);
return -1;
@@ -100,7 +102,7 @@ int net_time_usage(int argc, const char **argv)
/* try to set the system clock using /bin/date */
static int net_time_set(int argc, const char **argv)
{
- time_t t = nettime();
+ time_t t = nettime(NULL);
char *cmd;
if (t == 0) return -1;
@@ -118,7 +120,7 @@ static int net_time_set(int argc, const char **argv)
/* display the time on a remote box in a format ready for /bin/date */
static int net_time_system(int argc, const char **argv)
{
- time_t t = nettime();
+ time_t t = nettime(NULL);
if (t == 0) return -1;
@@ -127,6 +129,27 @@ static int net_time_system(int argc, const char **argv)
return 0;
}
+/* display the time on a remote box in a format ready for /bin/date */
+static int net_time_zone(int argc, const char **argv)
+{
+ int zone = 0;
+ time_t t;
+
+ t = nettime(&zone);
+
+ if (t == 0) return -1;
+
+ zone /= 60;
+
+ if (zone % 60 == 0) {
+ printf("%+d\n", -zone / 60);
+ } else {
+ printf("%+.1f\n", ((double)-zone) / 60);
+ }
+
+ return 0;
+}
+
/* display or set the time on a host */
int net_time(int argc, const char **argv)
{
@@ -137,6 +160,7 @@ int net_time(int argc, const char **argv)
struct functable func[] = {
{"SYSTEM", net_time_system},
{"SET", net_time_set},
+ {"ZONE", net_time_zone},
{NULL, NULL}
};
@@ -150,7 +174,7 @@ int net_time(int argc, const char **argv)
}
/* default - print the time */
- t = cli_servertime(opt_host, opt_have_ip? &opt_dest_ip : NULL);
+ t = cli_servertime(opt_host, opt_have_ip? &opt_dest_ip : NULL, NULL);
if (t == 0) return -1;
d_printf("%s", ctime(&t));