Source code pulled from OpenBSD for OpenNTPD. The place to contribute to this code is via the OpenBSD CVS tree.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

117 lines
4.9 KiB

  1. /* $OpenBSD: talkd.h,v 1.2 1997/09/21 10:46:07 niklas Exp $ */
  2. /* $NetBSD: talkd.h,v 1.5 1995/03/04 07:59:30 cgd Exp $ */
  3. /*
  4. * Copyright (c) 1983 Regents of the University of California.
  5. * All rights reserved.
  6. *
  7. * Redistribution and use in source and binary forms, with or without
  8. * modification, are permitted provided that the following conditions
  9. * are met:
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. All advertising materials mentioning features or use of this software
  16. * must display the following acknowledgement:
  17. * This product includes software developed by the University of
  18. * California, Berkeley and its contributors.
  19. * 4. Neither the name of the University nor the names of its contributors
  20. * may be used to endorse or promote products derived from this software
  21. * without specific prior written permission.
  22. *
  23. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  24. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  25. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  26. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  27. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  28. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  29. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  30. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  31. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  32. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  33. * SUCH DAMAGE.
  34. *
  35. * @(#)talkd.h 5.7 (Berkeley) 4/3/91
  36. */
  37. #ifndef _TALKD_H_
  38. #define _TALKD_H_
  39. /*
  40. * This describes the protocol used by the talk server and clients.
  41. *
  42. * The talk server acts a repository of invitations, responding to
  43. * requests by clients wishing to rendezvous for the purpose of
  44. * holding a conversation. In normal operation, a client, the caller,
  45. * initiates a rendezvous by sending a CTL_MSG to the server of
  46. * type LOOK_UP. This causes the server to search its invitation
  47. * tables to check if an invitation currently exists for the caller
  48. * (to speak to the callee specified in the message). If the lookup
  49. * fails, the caller then sends an ANNOUNCE message causing the server
  50. * to broadcast an announcement on the callee's login ports requesting
  51. * contact. When the callee responds, the local server uses the
  52. * recorded invitation to respond with the appropriate rendezvous
  53. * address and the caller and callee client programs establish a
  54. * stream connection through which the conversation takes place.
  55. */
  56. /*
  57. * Client->server request message format.
  58. */
  59. typedef struct {
  60. u_char vers; /* protocol version */
  61. u_char type; /* request type, see below */
  62. u_char answer; /* not used */
  63. u_char pad;
  64. u_int32_t id_num; /* message id */
  65. struct osockaddr addr; /* old (4.3) style */
  66. struct osockaddr ctl_addr; /* old (4.3) style */
  67. int32_t pid; /* caller's process id */
  68. #define NAME_SIZE 12
  69. char l_name[NAME_SIZE]; /* caller's name */
  70. char r_name[NAME_SIZE]; /* callee's name */
  71. #define TTY_SIZE 16
  72. char r_tty[TTY_SIZE]; /* callee's tty name */
  73. } CTL_MSG;
  74. /*
  75. * Server->client response message format.
  76. */
  77. typedef struct {
  78. u_char vers; /* protocol version */
  79. u_char type; /* type of request message, see below */
  80. u_char answer; /* respose to request message, see below */
  81. u_char pad;
  82. u_int32_t id_num; /* message id */
  83. struct osockaddr addr; /* address for establishing conversation */
  84. } CTL_RESPONSE;
  85. #define TALK_VERSION 1 /* protocol version */
  86. /* message type values */
  87. #define LEAVE_INVITE 0 /* leave invitation with server */
  88. #define LOOK_UP 1 /* check for invitation by callee */
  89. #define DELETE 2 /* delete invitation by caller */
  90. #define ANNOUNCE 3 /* announce invitation by caller */
  91. /* answer values */
  92. #define SUCCESS 0 /* operation completed properly */
  93. #define NOT_HERE 1 /* callee not logged in */
  94. #define FAILED 2 /* operation failed for unexplained reason */
  95. #define MACHINE_UNKNOWN 3 /* caller's machine name unknown */
  96. #define PERMISSION_DENIED 4 /* callee's tty doesn't permit announce */
  97. #define UNKNOWN_REQUEST 5 /* request has invalid type value */
  98. #define BADVERSION 6 /* request has invalid protocol version */
  99. #define BADADDR 7 /* request has invalid addr value */
  100. #define BADCTLADDR 8 /* request has invalid ctl_addr value */
  101. /*
  102. * Operational parameters.
  103. */
  104. #define MAX_LIFE 60 /* max time daemon saves invitations */
  105. /* RING_WAIT should be 10's of seconds less than MAX_LIFE */
  106. #define RING_WAIT 30 /* time to wait before resending invitation */
  107. #endif /* !_TALKD_H_ */