From 0a217a8df1657b4334b55b0e4a6c7837a8dbcfd9 Mon Sep 17 00:00:00 2001 From: Christian Grothoff Date: Fri, 29 May 2009 00:46:26 +0000 Subject: ng --- src/peerinfo/peerinfo.h | 135 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 135 insertions(+) create mode 100644 src/peerinfo/peerinfo.h (limited to 'src/peerinfo/peerinfo.h') diff --git a/src/peerinfo/peerinfo.h b/src/peerinfo/peerinfo.h new file mode 100644 index 000000000..040b084e4 --- /dev/null +++ b/src/peerinfo/peerinfo.h @@ -0,0 +1,135 @@ +/* + This file is part of GNUnet. + (C) 2009 Christian Grothoff (and other contributing authors) + + GNUnet 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, or (at your + option) any later version. + + GNUnet 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 GNUnet; see the file COPYING. If not, write to the + Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. +*/ + +/** + * @file peerinfo/peerinfo.h + * @brief common internal definitions for peerinfo service + * @author Christian Grothoff + */ +#include "gnunet_crypto_lib.h" +#include "gnunet_time_lib.h" +#include "gnunet_peerinfo_service.h" + + +/** + * Add the given peer to the list. This message + * is always followed by a verified HELLO message. + */ +struct PeerAddMessage +{ + + /** + * Type will be GNUNET_MESSAGE_TYPE_PEERINFO_ADD + */ + struct GNUNET_MessageHeader header; + + /** + * Always zero. + */ + uint32_t reserved GNUNET_PACKED; + + /** + * For which peer do we provide a HELLO message here? + */ + struct GNUNET_PeerIdentity peer; + +}; + + +/** + * Message requesting a listing of all known peers, + * possibly modified by the specified trust value + * and restricted to the specified peer identity. + */ +struct ListPeerMessage +{ + + /** + * Type will be GNUNET_MESSAGE_TYPE_PEERINFO_GET + */ + struct GNUNET_MessageHeader header; + + /** + * How much to change the trust in each returned peer, + * in network byte order. + */ + int32_t trust_change GNUNET_PACKED; + + /** + * Restrict to peers with this identity (optional + * field, check header.size!). + */ + struct GNUNET_PeerIdentity peer; + +}; + + +/** + * Message requesting a listing of all known peers, + * possibly modified by the specified trust value + * and restricted to the specified peer identity. + */ +struct ListAllPeersMessage +{ + + /** + * Type will be GNUNET_MESSAGE_TYPE_PEERINFO_GET + */ + struct GNUNET_MessageHeader header; + + /** + * How much to change the trust in each returned peer, + * in network byte order. + */ + int32_t trust_change GNUNET_PACKED; + +}; + + +/** + * Message used to inform the client about + * a particular peer; this message is optionally followed + * by a HELLO message for the respective peer (if available). + * Check the header.size field to see if a HELLO is + * present. + */ +struct InfoMessage +{ + + /** + * Type will be GNUNET_MESSAGE_TYPE_PEERINFO_INFO + */ + struct GNUNET_MessageHeader header; + + /** + * Amount of trust we now have in the peer, + * in network byte order. + */ + uint32_t trust GNUNET_PACKED; + + /** + * About which peer are we talking here? + */ + struct GNUNET_PeerIdentity peer; + +}; + + +/* end of peerinfo.h */ -- cgit v1.2.3