00001 /* 00002 * Author: MA Hartman 00003 * Date: apr 13, 2007 00004 * 00005 * Function: 00006 * Keeps track of other nodes in the network. 00007 * 00008 * License information: 00009 * 00010 * Copyright (c) 2006 Maurits Hartman 00011 * 00012 * Permission is hereby granted, free of charge, to any person 00013 * obtaining a copy of this software and associated documentation 00014 * files (the "Software"), to deal in the Software without 00015 * restriction, including without limitation the rights to use, 00016 * copy, modify, merge, publish, distribute, sublicense, and/or sell 00017 * copies of the Software, and to permit persons to whom the 00018 * Software is furnished to do so, subject to the following 00019 * conditions: 00020 * 00021 * The above copyright notice and this permission notice shall be 00022 * included in all copies or substantial portions of the Software. 00023 * 00024 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 00025 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES 00026 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 00027 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 00028 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 00029 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 00030 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 00031 * OTHER DEALINGS IN THE SOFTWARE. 00032 * 00033 */ 00034 00035 #ifndef NODE_H_ 00036 #define NODE_H_ 00037 00038 #include <biosphere.h> 00039 #include <apr_pools.h> 00040 #include <apr_time.h> 00041 00051 typedef struct node_address 00052 { 00053 char *address; 00054 bs_uint16 port; 00055 } node_address; 00056 00060 typedef struct node_info 00061 { 00062 node_address *address; 00063 bs_definition *services; 00065 bs_uint32 ping; 00066 bs_uint32 mips; 00067 apr_time_t last_seen; 00068 } node_info; 00069 00076 bs_status init_node(apr_pool_t *mp); 00077 00088 bs_status add_node(const char *address, bs_uint16 port); 00089 00096 bs_status remove_node(const char *address, bs_uint16 port); 00097 00104 node_info *get_servicing_node(const bs_service_request *def); 00105 00113 bs_uint32 ping_node(const char *address, bs_uint16 port, 00114 apr_pool_t *mp); 00115 00120 #endif /*NODE_H_*/