src/network.c

Wed, 05 Feb 2014 14:07:43 +0100

author
Mike Becker <universe@uap-core.de>
date
Wed, 05 Feb 2014 14:07:43 +0100
changeset 1
e5fbb8f9edbe
child 2
0a08f79c320d
permissions
-rw-r--r--

added (single) client / server architecture

universe@1 1 /*
universe@1 2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
universe@1 3 *
universe@1 4 * Copyright 2014 Mike Becker. All rights reserved.
universe@1 5 *
universe@1 6 * Redistribution and use in source and binary forms, with or without
universe@1 7 * modification, are permitted provided that the following conditions are met:
universe@1 8 *
universe@1 9 * 1. Redistributions of source code must retain the above copyright
universe@1 10 * notice, this list of conditions and the following disclaimer.
universe@1 11 *
universe@1 12 * 2. Redistributions in binary form must reproduce the above copyright
universe@1 13 * notice, this list of conditions and the following disclaimer in the
universe@1 14 * documentation and/or other materials provided with the distribution.
universe@1 15 *
universe@1 16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
universe@1 17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
universe@1 18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
universe@1 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
universe@1 20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
universe@1 21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
universe@1 22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
universe@1 23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
universe@1 24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
universe@1 25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
universe@1 26 * POSSIBILITY OF SUCH DAMAGE.
universe@1 27 *
universe@1 28 */
universe@1 29
universe@1 30 #include <stdlib.h>
universe@1 31 #include <string.h>
universe@1 32 #include "network.h"
universe@1 33
universe@1 34 int server_bind(Server *server) {
universe@1 35 server->fd = socket(server->info->ai_family,
universe@1 36 server->info->ai_socktype, server->info->ai_protocol);
universe@1 37 if (server->fd > -1) {
universe@1 38 int true = 1;
universe@1 39 setsockopt(server->fd, SOL_SOCKET, SO_REUSEADDR, &true, sizeof(int));
universe@1 40 if (bind(server->fd,
universe@1 41 server->info->ai_addr, server->info->ai_addrlen)) {
universe@1 42 server->fd = -1;
universe@1 43 return 1;
universe@1 44 } else {
universe@1 45 return 0;
universe@1 46 }
universe@1 47 } else {
universe@1 48 return 1;
universe@1 49 }
universe@1 50 }
universe@1 51
universe@1 52 int net_create(Server *server, char* port) {
universe@1 53 return net_find(server, "localhost", port) || server_bind(server);
universe@1 54 }
universe@1 55
universe@1 56 int getaddrinfo_intrnl(char *host, char *port, struct addrinfo **info) {
universe@1 57 struct addrinfo hints;
universe@1 58 memset(&hints, 0, sizeof(hints));
universe@1 59 hints.ai_socktype = SOCK_STREAM;
universe@1 60 hints.ai_protocol = IPPROTO_TCP;
universe@1 61
universe@1 62 return getaddrinfo(host, port, &hints, info);
universe@1 63 }
universe@1 64
universe@1 65 int net_find(Server *server, char *host, char* port) {
universe@1 66 memset(server, 0, sizeof(Server));
universe@1 67 server->fd = -1;
universe@1 68
universe@1 69 return getaddrinfo_intrnl(host, port, &(server->info));
universe@1 70 }
universe@1 71
universe@1 72 int net_listen(Server *server) {
universe@1 73 listen(server->fd, 1);
universe@1 74 Client* client = calloc(1, sizeof(Client));
universe@1 75 client->fd = -1;
universe@1 76 server->client = client;
universe@1 77
universe@1 78 client->fd = accept(server->fd,
universe@1 79 &(client->address), &(client->address_len));
universe@1 80
universe@1 81 return client->fd == -1;
universe@1 82 }
universe@1 83
universe@1 84 int net_connect(Server *server) {
universe@1 85 struct addrinfo *info;
universe@1 86 if (getaddrinfo_intrnl("localhost", NULL, &info)) {
universe@1 87 return 1;
universe@1 88 }
universe@1 89
universe@1 90 Client* client = calloc(1, sizeof(Client));
universe@1 91 client->fd = socket(info->ai_family, info->ai_socktype, info->ai_protocol);
universe@1 92 server->client = client;
universe@1 93
universe@1 94 freeaddrinfo(info);
universe@1 95 if (client->fd == -1) {
universe@1 96 return 1;
universe@1 97 }
universe@1 98
universe@1 99 return connect(client->fd, server->info->ai_addr, server->info->ai_addrlen);
universe@1 100 }
universe@1 101
universe@1 102 int net_destroy(Server *server) {
universe@1 103 if (server->info) {
universe@1 104 freeaddrinfo(server->info);
universe@1 105 }
universe@1 106 if (server->client) {
universe@1 107 shutdown(server->client->fd, SHUT_RDWR);
universe@1 108 free(server->client);
universe@1 109 }
universe@1 110 if (server->fd > -1) {
universe@1 111 return shutdown(server->fd, SHUT_RDWR);
universe@1 112 }
universe@1 113
universe@1 114 return EXIT_SUCCESS;
universe@1 115 }

mercurial