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.

115 lines
4.8 KiB

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