mirror of
https://gitlab.com/openconnect/ocserv.git
synced 2026-02-09 08:16:58 +08:00
- Replaced strcpy() with strlcpy() in test files - Added linking to libcommon.a (and its dependency libnettle) as not all systems provide strlcpy() - Centralized syslog_open variable by moving it from multiple definitions in main.c, worker.c, and test files into log.c. This avoids duplication and resolves a linking conflict with libcommon.a Signed-off-by: Grigory Trenin <grigory.trenin@gmail.com>
115 lines
3.0 KiB
C
115 lines
3.0 KiB
C
/*
|
|
* Copyright (C) 2015 Red Hat, Inc.
|
|
*
|
|
* 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, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <arpa/inet.h>
|
|
|
|
#include "../src/ip-util.h"
|
|
#include "../src/ip-util.c"
|
|
|
|
static char *my_ipv6_prefix_to_mask(char str[MAX_IP_STR], unsigned int prefix)
|
|
{
|
|
struct in6_addr in;
|
|
|
|
if (ipv6_prefix_to_mask(&in, prefix) == 0)
|
|
return NULL;
|
|
|
|
if (inet_ntop(AF_INET6, &in, str, MAX_IP_STR) == NULL)
|
|
return NULL;
|
|
|
|
return str;
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
char *p;
|
|
char str[MAX_IP_STR];
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 128);
|
|
if (p == NULL ||
|
|
strcmp(p, "ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 127);
|
|
if (p == NULL ||
|
|
strcmp(p, "ffff:ffff:ffff:ffff:ffff:ffff:ffff:fffe") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 97);
|
|
if (p == NULL ||
|
|
strcmp(p, "ffff:ffff:ffff:ffff:ffff:ffff:8000:0") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 96);
|
|
if (p == NULL || strcmp(p, "ffff:ffff:ffff:ffff:ffff:ffff::") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 95);
|
|
if (p == NULL || strcmp(p, "ffff:ffff:ffff:ffff:ffff:fffe::") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 67);
|
|
if (p == NULL || strcmp(p, "ffff:ffff:ffff:ffff:e000::") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 64);
|
|
if (p == NULL || strcmp(p, "ffff:ffff:ffff:ffff::") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 59);
|
|
if (p == NULL || strcmp(p, "ffff:ffff:ffff:ffe0::") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 48);
|
|
if (p == NULL || strcmp(p, "ffff:ffff:ffff::") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 32);
|
|
if (p == NULL || strcmp(p, "ffff:ffff::") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
p = my_ipv6_prefix_to_mask(str, 12);
|
|
if (p == NULL || strcmp(p, "fff0::") != 0) {
|
|
fprintf(stderr, "error in %d: %s\n", __LINE__, p);
|
|
exit(1);
|
|
}
|
|
|
|
return 0;
|
|
}
|