add macros get get/put short/long.
[unix-history] / usr / src / include / protocols / talkd.h
index d21befd..d536a95 100644 (file)
@@ -1,57 +1,84 @@
-/* $Header: ctl.h 1.4 83/03/28 20:46:27 moore Exp $ */
-
-/* ctl.h describes the structure that talk and talkd pass back
-   and forth
+/*
+ * Copyright (c) 1983 Regents of the University of California.
+ * All rights reserved.  The Berkeley software License Agreement
+ * specifies the terms and conditions for redistribution.
+ *
+ *     @(#)talkd.h     5.2 (Berkeley) %G%
  */
 
 #include <sys/types.h>
 #include <sys/socket.h>
  */
 
 #include <sys/types.h>
 #include <sys/socket.h>
-#include <netinet/in.h>
-#include <netdb.h>
-
-#define NAME_SIZE 9
-#define TTY_SIZE 16
-#define HOST_NAME_LENGTH 256
-
-#define MAX_LIFE 60 /* maximum time an invitation is saved by the
-                        talk daemons */
-#define RING_WAIT 30  /* time to wait before refreshing invitation 
-                        should be 10's of seconds less than MAX_LIFE */
-
-    /* the values for type */
-
-#define LEAVE_INVITE 0
-#define LOOK_UP 1
-#define DELETE 2
-#define ANNOUNCE 3
+/*
+ * This describes the protocol used by the talk server and clients.
+ *
+ * The talk server acts a repository of invitations, responding to
+ * requests by clients wishing to rendezvous for the purpose of
+ * holding a conversation.  In normal operation, a client, the caller,
+ * initiates a rendezvous by sending a CTL_MSG to the server of
+ * type LOOK_UP.  This causes the server to search its invitation
+ * tables to check if an invitation currently exists for the caller
+ * (to speak to the callee specified in the message).  If the lookup
+ * fails, the caller then sends an ANNOUNCE message causing the server
+ * to broadcast an announcement on the callee's login ports requesting
+ * contact.  When the callee responds, the local server uses the
+ * recorded invitation to respond with the appropriate rendezvous
+ * address and the caller and callee client programs establish a
+ * stream connection through which the conversation takes place.
+ */
 
 
-    /* the values for answer */
+/*
+ * Client->server request message format.
+ */
+typedef struct {
+       u_char  vers;           /* protocol version */
+       u_char  type;           /* request type, see below */
+       u_char  answer;         /* not used */
+       u_char  pad;
+       u_long  id_num;         /* message id */
+       struct  sockaddr addr;
+       struct  sockaddr ctl_addr;
+       long    pid;            /* caller's process id */
+#define        NAME_SIZE       12
+       char    l_name[NAME_SIZE];/* caller's name */
+       char    r_name[NAME_SIZE];/* callee's name */
+#define        TTY_SIZE        16
+       char    r_tty[TTY_SIZE];/* callee's tty name */
+} CTL_MSG;
 
 
-#define SUCCESS 0
-#define NOT_HERE 1
-#define FAILED 2
-#define MACHINE_UNKNOWN 3
-#define PERMISSION_DENIED 4
-#define UNKNOWN_REQUEST 5
+/*
+ * Server->client response message format.
+ */
+typedef struct {
+       u_char  vers;           /* protocol version */
+       u_char  type;           /* type of request message, see below */
+       u_char  answer;         /* respose to request message, see below */
+       u_char  pad;
+       u_long  id_num;         /* message id */
+       struct  sockaddr addr;  /* address for establishing conversation */
+} CTL_RESPONSE;
 
 
-typedef struct ctl_response CTL_RESPONSE;
+#define        TALK_VERSION    1               /* protocol version */
 
 
-struct ctl_response {
-    char type;
-    char answer;
-    int id_num;
-    struct sockaddr_in addr;
-};
+/* message type values */
+#define LEAVE_INVITE   0       /* leave invitation with server */
+#define LOOK_UP                1       /* check for invitation by callee */
+#define DELETE         2       /* delete invitation by caller */
+#define ANNOUNCE       3       /* announce invitation by caller */
 
 
-typedef struct ctl_msg CTL_MSG;
+/* answer values */
+#define SUCCESS                0       /* operation completed properly */
+#define NOT_HERE       1       /* callee not logged in */
+#define FAILED         2       /* operation failed for unexplained reason */
+#define MACHINE_UNKNOWN        3       /* caller's machine name unknown */
+#define PERMISSION_DENIED 4    /* callee's tty doesn't permit announce */
+#define UNKNOWN_REQUEST        5       /* request has invalid type value */
+#define        BADVERSION      6       /* request has invalid protocol version */
+#define        BADADDR         7       /* request has invalid addr value */
+#define        BADCTLADDR      8       /* request has invalid ctl_addr value */
 
 
-struct ctl_msg {
-    char type;
-    char l_name[NAME_SIZE];
-    char r_name[NAME_SIZE];
-    int id_num;
-    int pid;
-    char r_tty[TTY_SIZE];
-    struct sockaddr_in addr;
-    struct sockaddr_in ctl_addr;
-};
+/*
+ * Operational parameters.
+ */
+#define MAX_LIFE       60      /* max time daemon saves invitations */
+/* RING_WAIT should be 10's of seconds less than MAX_LIFE */
+#define RING_WAIT      30      /* time to wait before resending invitation */