1ntp_time(n)                 Network Time Facilities                ntp_time(n)
2
3
4
5______________________________________________________________________________
6

NAME

8       ntp_time - Tcl Time Service Client
9

SYNOPSIS

11       package require Tcl  8.0
12
13       package require time  ?1.2.1?
14
15       ::time::gettime ?options? timeserver ?port?
16
17       ::time::getsntp ?options? timeserver ?port?
18
19       ::time::configure ?options?
20
21       ::time::cget name
22
23       ::time::unixtime token
24
25       ::time::status token
26
27       ::time::error token
28
29       ::time::reset token ?reason?
30
31       ::time::wait token
32
33       ::time::cleanup token
34
35_________________________________________________________________
36

DESCRIPTION

38       This  package  implements  a  client  for  the  RFC  868  TIME protocol
39       (http://www.rfc-editor.org/rfc/rfc868.txt) and also  a  minimal  client
40       for  the  RFC  2030  Simple  Network Time Protocol (http://www.rfc-edi
41       tor.org/rfc/rfc2030.txt).  RFC 868 returns the time in seconds since  1
42       January  1900  to  either  tcp or udp clients. RFC 2030 also gives this
43       time but also provides a fractional part which  is  not  used  in  this
44       client.
45

COMMANDS

47       ::time::gettime ?options? timeserver ?port?
48              Get the time from timeserver. You may specify any of the options
49              listed for the configure command here. This  command  returns  a
50              token  which  must  then  be used with the remaining commands in
51              this package. Once you have finished, you should use cleanup  to
52              release all resources. The default port is 37.
53
54       ::time::getsntp ?options? timeserver ?port?
55              Get  the time from an SNTP server. This accepts exactly the same
56              arguments as ::time::gettime except that  the  default  port  is
57              123.  The result is a token as per ::time::gettime and should be
58              handled in the same way.
59
60              Note that it is unlikely that any SNTP server will  reply  using
61              tcp  so  you will require the tcludp or the ceptcl package. If a
62              suitable package can be loaded then the  udp  protocol  will  be
63              used by default.
64
65       ::time::configure ?options?
66              Called  with  no  arguments this command returns all the current
67              configuration options and values. Otherwise it should be  called
68              with pairs of option name and value.
69
70              -protocol number
71                     Set the default network protocol. This defaults to udp if
72                     the tcludp package is available. Otherwise  it  will  use
73                     tcp.
74
75              -port number
76                     Set  the  default  port to use. RFC 868 uses port 37, RFC
77                     2030 uses port 123.
78
79              -timeout number
80                     Set  the  default  timeout  value  in  milliseconds.  The
81                     default is 10 seconds.
82
83              -command number
84                     Set  a  command  procedure  to  be  run  when  a reply is
85                     received. The procedure is called  with  the  time  token
86                     appended to the argument list.
87
88              -loglevel number
89                     Set the logging level. The default is 'warning'.
90
91       ::time::cget name
92              Get the current value for the named configuration option.
93
94       ::time::unixtime token
95              Format  the  returned  time  for  the  unix  epoch. RFC 868 time
96              defines time 0 as 1 Jan 1900, while unix time defines time 0  as
97              1 Jan 1970. This command converts the reply to unix time.
98
99       ::time::status token
100              Returns the status flag. For a successfully completed query this
101              will  be  ok.  May  be  error  or  timeout  or  eof.   See  also
102              ::time::error
103
104       ::time::error token
105              Returns  the error message provided for requests whose status is
106              error.  If there is no error message then  an  empty  string  is
107              returned.
108
109       ::time::reset token ?reason?
110              Reset  or  cancel  the  query optionally specfying the reason to
111              record for the error command.
112
113       ::time::wait token
114              Wait for a query to complete and return the status upon  comple‐
115              tion.
116
117       ::time::cleanup token
118              Remove all state variables associated with the request.
119
120              % set tok [::time::gettime ntp2a.mcc.ac.uk]
121              % set t [::time::unixtime $tok]
122              % ::time::cleanup $tok
123
124
125              % set tok [::time::getsntp pool.ntp.org]
126              % set t [::time::unixtime $tok]
127              % ::time::cleanup $tok
128
129
130              proc on_time {token} {
131                 if {[time::status $token] eq "ok"} {
132                    puts [clock format [time::unixtime $token]]
133                 } else {
134                    puts [time::error $token]
135                 }
136                 time::cleanup $token
137              }
138              time::getsntp -command on_time pool.ntp.org
139
140

AUTHORS

142       Pat Thoyts
143

SEE ALSO

145       ntp
146

KEYWORDS

148       NTP, SNTP, rfc 2030, rfc 868, time
149
151       Copyright (c) 2002, Pat Thoyts <patthoyts@users.sourceforge.net>
152
153
154
155
156ntp                                  1.2.1                         ntp_time(n)
Impressum