2005-03-19 22:16:49 +00:00
|
|
|
/* -*-mode: C; fill-column: 78; c-basic-offset: 4; -*- */
|
|
|
|
/*
|
|
|
|
* Copyright 2005 by Eric House (fixin@peak.org). All rights reserved.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _XWRELAY_H_
|
|
|
|
#define _XWRELAY_H_
|
|
|
|
|
|
|
|
/* This file is meant to be included by both linux code that doesn't
|
|
|
|
include xptypes and from Crosswords client code.*/
|
|
|
|
|
|
|
|
/* Set if device is acting a server; cleared if as client */
|
|
|
|
#define FLAGS_SERVER_BIT 0x01
|
|
|
|
|
2005-09-05 15:50:49 +00:00
|
|
|
typedef
|
|
|
|
enum { XWRELAY_NONE /* 0 is an illegal value */
|
2005-03-19 22:16:49 +00:00
|
|
|
|
2005-09-05 15:50:49 +00:00
|
|
|
, XWRELAY_GAME_CONNECT
|
2005-03-19 22:16:49 +00:00
|
|
|
/* Sent from device to relay to establish connection to relay. Format:
|
|
|
|
flags: 1; cookieLen: 1; cookie: <cookieLen>; hostID:
|
2005-08-08 23:33:51 +00:00
|
|
|
2. connectionID: 2. */
|
|
|
|
|
2005-09-05 15:50:49 +00:00
|
|
|
, XWRELAY_GAME_RECONNECT
|
2005-08-08 23:33:51 +00:00
|
|
|
/* Connect using ID rather than cookie. Used by a device that's lost
|
|
|
|
its connection to a game in progress. Once a game is locked this is
|
|
|
|
the only way a host can get (back) in. */
|
2005-03-19 22:16:49 +00:00
|
|
|
|
2005-09-05 15:50:49 +00:00
|
|
|
, XWRELAY_GAME_DISCONNECT
|
|
|
|
/* Tell the relay that we're gone for this game. After this message is
|
|
|
|
sent, the host can reconnect on the same socket for a new game.
|
|
|
|
Format: cookieID: 4; srcID: 2 */
|
|
|
|
|
2005-03-19 22:16:49 +00:00
|
|
|
, XWRELAY_CONNECTRESP
|
2005-08-08 23:33:51 +00:00
|
|
|
/* Sent from relay to device in response to XWRELAY_CONNECT or
|
|
|
|
XWRELAY_RECONNECT. Format: heartbeat_seconds: 2; connectionID:
|
|
|
|
2; */
|
|
|
|
|
2005-09-03 18:32:12 +00:00
|
|
|
, XWRELAY_OTHERCONNECT /* Another device has [re]joined your game.
|
|
|
|
Format: ??? */
|
|
|
|
|
2005-09-03 15:41:17 +00:00
|
|
|
, XWRELAY_DISCONNECT_YOU
|
|
|
|
/* Sent from relay when existing connection is terminated.
|
|
|
|
Format: errorCode: 1 */
|
|
|
|
|
|
|
|
, XWRELAY_DISCONNECT_OTHER
|
|
|
|
/* Another device has left the game.
|
|
|
|
Format: errorCode: 1; lostHostId: 2 */
|
2005-09-03 06:46:03 +00:00
|
|
|
|
2005-07-06 01:36:52 +00:00
|
|
|
, XWRELAY_CONNECTDENIED
|
2005-08-08 23:33:51 +00:00
|
|
|
/* The relay says go away. Format: reason code: 1 */
|
2005-07-06 01:36:52 +00:00
|
|
|
|
2005-03-19 22:16:49 +00:00
|
|
|
, XWRELAY_HEARTBEAT
|
2005-09-05 15:50:49 +00:00
|
|
|
/* Sent in either direction. Format: cookieID: 4; srcID: 2 */
|
2005-03-19 22:16:49 +00:00
|
|
|
|
|
|
|
, XWRELAY_MSG_FROMRELAY
|
2005-09-05 15:50:49 +00:00
|
|
|
/* Sent from relay to device. Format: cookieID: 4; src_hostID: 2;
|
2005-03-19 22:16:49 +00:00
|
|
|
dest_hostID: 2; data <len-headerLen> */
|
|
|
|
|
|
|
|
, XWRELAY_MSG_TORELAY
|
|
|
|
/* Sent from device to relay. Format: connectionID: 2; src_hostID:
|
|
|
|
2; dest_hostID: 2 */
|
2005-09-03 18:32:12 +00:00
|
|
|
} XWRelayMsg;
|
2005-03-19 22:16:49 +00:00
|
|
|
|
|
|
|
#ifndef CANT_DO_TYPEDEF
|
|
|
|
typedef unsigned char XWRELAY_Cmd;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define HOST_ID_NONE 0
|
|
|
|
#define HOST_ID_SERVER 1
|
|
|
|
|
|
|
|
#define MAX_COOKIE_LEN 15
|
|
|
|
#define MAX_MSG_LEN 256 /* 100 is more like it */
|
|
|
|
|
2005-07-06 01:36:52 +00:00
|
|
|
#define XWRELAY_PROTO_VERSION 0x01
|
|
|
|
|
|
|
|
/* Errors passed with denied */
|
2005-09-03 06:46:03 +00:00
|
|
|
typedef enum {
|
2005-07-06 01:36:52 +00:00
|
|
|
XWRELAY_ERROR_NONE
|
|
|
|
,XWRELAY_ERROR_BADPROTO
|
|
|
|
,XWRELAY_ERROR_RELAYBUSY
|
2005-09-03 06:46:03 +00:00
|
|
|
,XWRELAY_ERROR_SHUTDOWN /* relay's going down */
|
|
|
|
,XWRELAY_ERROR_TIMEOUT /* Other players didn't show */
|
2005-09-03 15:41:17 +00:00
|
|
|
,XWRELAY_ERROR_HEART_YOU /* Haven't heard from somebody in too long */
|
2005-09-04 14:35:13 +00:00
|
|
|
,XWRELAY_ERROR_HEART_OTHER /* Haven't heard from other in too long */
|
|
|
|
,XWRELAY_ERROR_LOST_OTHER /* Generic other-left-we-dunno-why error */
|
2005-07-06 01:36:52 +00:00
|
|
|
|
2005-09-03 06:46:03 +00:00
|
|
|
,XWRELAY_ERROR_LASTERR
|
|
|
|
} XWREASON;
|
2005-09-04 20:55:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
typedef unsigned int CookieID;
|
|
|
|
#define COOKIE_ID_NONE 0L
|
|
|
|
|
2005-03-19 22:16:49 +00:00
|
|
|
#endif
|