QSC Post Quantum Cryptographic Library 1.0.0.6c (A6)
A post quantum secure library written in Ansi C
 
Loading...
Searching...
No Matches
ipinfo.h
Go to the documentation of this file.
1/*
2 * 2025 Quantum Resistant Cryptographic Solutions Corporation
3 * All Rights Reserved.
4 *
5 * NOTICE: This software and all accompanying materials are the exclusive
6 * property of Quantum Resistant Cryptographic Solutions Corporation (QRCS).
7 * The intellectual and technical concepts contained within this implementation
8 * are proprietary to QRCS and its authorized licensors and are protected under
9 * applicable U.S. and international copyright, patent, and trade secret laws.
10 *
11 * CRYPTOGRAPHIC STANDARDS:
12 * - This software includes implementations of cryptographic algorithms such as
13 * SHA3, AES, and others. These algorithms are public domain or standardized
14 * by organizations such as NIST and are NOT the property of QRCS.
15 * - However, all source code, optimizations, and implementations in this library
16 * are original works of QRCS and are protected under this license.
17 *
18 * RESTRICTIONS:
19 * - Redistribution, modification, or unauthorized distribution of this software,
20 * in whole or in part, is strictly prohibited.
21 * - This software is provided for non-commercial, educational, and research
22 * purposes only. Commercial use in any form is expressly forbidden.
23 * - Licensing and authorized distribution are solely at the discretion of QRCS.
24 * - Any use of this software implies acceptance of these restrictions.
25 *
26 * DISCLAIMER:
27 * This software is provided "as is," without warranty of any kind, express or
28 * implied, including but not limited to warranties of merchantability or fitness
29 * for a particular purpose. QRCS disclaims all liability for any direct, indirect,
30 * incidental, or consequential damages resulting from the use or misuse of this software.
31 *
32 * FULL LICENSE:
33 * This software is subject to the **Quantum Resistant Cryptographic Solutions
34 * Proprietary License (QRCS-PL)**. The complete license terms are included
35 * in the LICENSE.txt file distributed with this software.
36 *
37 * Written by: John G. Underhill
38 * Contact: john.underhill@protonmail.com
39 */
40
41#ifndef QSC_IPINFO_H
42#define QSC_IPINFO_H
43
44#include <stdio.h>
45#include <string.h>
46#include "common.h"
47#include "arrayutils.h"
48#include "intutils.h"
49#include "memutils.h"
50#include "socketflags.h"
51#include "stringutils.h"
52
53QSC_CPLUSPLUS_ENABLED_START
54
76
81#define QSC_IPINFO_IPV4_BYTELEN 0x04U
82
87#define QSC_IPINFO_IPV4_MINLEN 0x08U
88
93#define QSC_IPINFO_IPV4_STRNLEN 0x16U
94
99#define QSC_IPINFO_IPV4_MASK_STRNLEN 0x10U
100
105#define QSC_IPINFO_IPV6_BYTELEN 0x10U
106
111#define QSC_IPINFO_IP_MAX_BYTELEN (QSC_IPINFO_IPV6_BYTELEN)
112
117#define QSC_IPINFO_IPV6_STRNLEN 0x41U
118
123#define QSC_IPINFO_IPV6_MASK_STRNLEN 0x41U
124
129#define QSC_IPINFO_MAX_SIZE (QSC_IPINFO_IPV6_STRNLEN)
130
142
153
166
174
181
188
196
206QSC_EXPORT_API qsc_ipinfo_ipv4_address qsc_ipinfo_ipv4_address_from_bytes(uint8_t a1, uint8_t a2, uint8_t a3, uint8_t a4);
207
215
224
232
240
248
256
263
271
279
287
295
302QSC_EXPORT_API void qsc_ipinfo_ipv4_array_to_string(char output[QSC_IPINFO_IPV4_STRNLEN], const uint8_t* address);
303
312
325
333
340
347
355
363
372
380
388
396
404
411
419
427
435
443
450QSC_EXPORT_API void qsc_ipinfo_ipv6_array_to_string(char output[QSC_IPINFO_IPV6_STRNLEN], const uint8_t* address);
451
459
467
468QSC_CPLUSPLUS_ENABLED_END
469
470#endif
Functions for handling character arrays.
Contains common definitions for the Quantum Secure Cryptographic (QSC) library.
#define QSC_EXPORT_API
API export macro for Microsoft compilers when importing from a DLL.
Definition common.h:520
This file contains common integer manipulation and conversion functions.
QSC_EXPORT_API uint8_t qsc_ipinfo_ipv6_address_get_cidr_mask(const qsc_ipinfo_ipv6_address *address)
Get the IPv6 network subnet CIDR length.
Definition ipinfo.c:828
#define QSC_IPINFO_IPV4_BYTELEN
The IPv4 byte array length.
Definition ipinfo.h:81
QSC_EXPORT_API qsc_ipinfo_ipv6_address qsc_ipinfo_ipv6_address_from_string(const char input[QSC_IPINFO_IPV6_STRNLEN])
Instantiate an IPv6 address structure from a string.
Definition ipinfo.c:598
qsc_ipinfo_address_types
The IP address family types.
Definition ipinfo.h:136
@ qsc_ipinfo_address_type_none
Definition ipinfo.h:137
@ qsc_ipinfo_address_type_unknown
Definition ipinfo.h:140
@ qsc_ipinfo_address_type_ipv6
Definition ipinfo.h:139
@ qsc_ipinfo_address_type_ipv4
Definition ipinfo.h:138
QSC_EXPORT_API void qsc_ipinfo_ipv4_cidr_to_mask(char mask[QSC_IPINFO_IPV4_MASK_STRNLEN], uint8_t cidr)
Convert a CIDR mask to a subnet mask string.
Definition ipinfo.c:439
QSC_EXPORT_API void qsc_ipinfo_ipv6_address_to_string(char output[QSC_IPINFO_IPV6_STRNLEN], const qsc_ipinfo_ipv6_address *address)
Serialize an IPv6 address structure to a string.
Definition ipinfo.c:867
QSC_EXPORT_API uint8_t qsc_ipinfo_ipv4_address_get_cidr_mask(const qsc_ipinfo_ipv4_address *address)
Get the IPv4 network subnet CIDR length.
Definition ipinfo.c:292
QSC_EXPORT_API bool qsc_ipinfo_ipv6_address_string_is_valid(const char *address)
Test if the IPv6 address string is valid.
Definition ipinfo.c:727
QSC_EXPORT_API bool qsc_ipinfo_ipv4_address_is_routable(const qsc_ipinfo_ipv4_address *address)
Test if the IPv4 address is a valid public address.
Definition ipinfo.c:185
#define QSC_IPINFO_IPV6_MASK_STRNLEN
The IPv6 subnet mask string length.
Definition ipinfo.h:123
QSC_EXPORT_API qsc_ipinfo_ipv4_address qsc_ipinfo_ipv4_address_any(void)
Use the device's primary IPv4 address.
Definition ipinfo.c:39
QSC_EXPORT_API qsc_ipinfo_ipv4_address qsc_ipinfo_ipv4_address_from_bytes(uint8_t a1, uint8_t a2, uint8_t a3, uint8_t a4)
Instantiate an IPv4 address structure from individual bytes.
Definition ipinfo.c:74
QSC_EXPORT_API void qsc_ipinfo_ipv6_address_to_array(uint8_t *output, const qsc_ipinfo_ipv6_address *address)
Serialize an IPv6 address structure to a byte array.
Definition ipinfo.c:856
QSC_EXPORT_API bool qsc_ipinfo_ipv6_address_is_valid(const qsc_ipinfo_ipv6_address *address)
Test if the IPv6 address is valid.
Definition ipinfo.c:696
QSC_EXPORT_API qsc_ipv6_address_prefix_types qsc_ipinfo_ipv6_address_type(const qsc_ipinfo_ipv6_address *address)
Get the IPv6 address routing prefix type.
Definition ipinfo.c:536
QSC_EXPORT_API bool qsc_ipinfo_ipv6_address_is_zeroed(const qsc_ipinfo_ipv6_address *address)
Test if the IPv6 address is zeroed.
Definition ipinfo.c:758
QSC_EXPORT_API qsc_ipinfo_ipv6_address qsc_ipinfo_ipv6_address_from_array(const uint8_t *address)
Instantiate an IPv6 address structure from a byte array.
Definition ipinfo.c:584
QSC_EXPORT_API qsc_ipinfo_ipv4_address qsc_ipinfo_ipv4_address_loopback(void)
Get a copy of the IPv4 loopback address.
Definition ipinfo.c:257
QSC_EXPORT_API bool qsc_ipinfo_ipv4_address_is_zeroed(const qsc_ipinfo_ipv4_address *address)
Test if the IPv4 address is zeroed.
Definition ipinfo.c:246
#define QSC_IPINFO_IPV4_STRNLEN
The IPv4 string length.
Definition ipinfo.h:93
QSC_EXPORT_API void qsc_ipinfo_ipv4_address_get_mask(char mask[QSC_IPINFO_IPV4_MASK_STRNLEN], const qsc_ipinfo_ipv4_address *address)
Get the IPv4 network subnet mask string.
Definition ipinfo.c:268
QSC_EXPORT_API bool qsc_ipinfo_ipv4_address_is_equal(const qsc_ipinfo_ipv4_address *a, const qsc_ipinfo_ipv4_address *b)
Compare two IPv4 address structures for equality.
Definition ipinfo.c:161
QSC_EXPORT_API void qsc_ipinfo_ipv6_address_get_mask(char mask[QSC_IPINFO_IPV6_MASK_STRNLEN], const qsc_ipinfo_ipv6_address *address)
Get the IPv6 network subnet mask string.
Definition ipinfo.c:804
QSC_EXPORT_API uint8_t qsc_ipinfo_ipv4_mask_to_cidr(const char mask[QSC_IPINFO_IPV4_MASK_STRNLEN])
Convert a subnet mask string to a CIDR mask.
Definition ipinfo.c:412
QSC_EXPORT_API bool qsc_ipinfo_ipv4_address_is_valid(const qsc_ipinfo_ipv4_address *address)
Test if the IPv4 address is valid.
Definition ipinfo.c:224
QSC_EXPORT_API bool qsc_ipinfo_ipv4_address_string_is_valid(const char *address)
Test if the IPv4 address string is valid.
Definition ipinfo.c:235
#define QSC_IPINFO_IPV6_STRNLEN
The IPv6 string length.
Definition ipinfo.h:117
QSC_EXPORT_API void qsc_ipinfo_ipv4_address_to_string(char output[QSC_IPINFO_IPV4_STRNLEN], const qsc_ipinfo_ipv4_address *address)
Serialize an IPv4 address structure to a string.
Definition ipinfo.c:332
QSC_EXPORT_API void qsc_ipinfo_ipv4_address_clear(qsc_ipinfo_ipv4_address *address)
Clear the IPv4 address structure.
Definition ipinfo.c:50
QSC_EXPORT_API void qsc_ipinfo_ipv4_address_to_array(uint8_t *output, const qsc_ipinfo_ipv4_address *address)
Serialize an IPv4 address structure to a byte array.
Definition ipinfo.c:318
QSC_EXPORT_API qsc_ipinfo_address_types qsc_ipinfo_get_address_type(const char *address)
Determine the IP address type from a string.
Definition ipinfo.c:5
QSC_EXPORT_API void qsc_ipinfo_ipv6_array_to_string(char output[QSC_IPINFO_IPV6_STRNLEN], const uint8_t *address)
Convert an IPv6 address array to a string.
Definition ipinfo.c:904
QSC_EXPORT_API qsc_ipinfo_ipv6_address qsc_ipinfo_ipv6_address_loopback(void)
Get a copy of the IPv6 loopback address.
Definition ipinfo.c:780
#define QSC_IPINFO_IPV6_BYTELEN
The IPv6 byte array length.
Definition ipinfo.h:105
QSC_EXPORT_API qsc_ipinfo_ipv4_address qsc_ipinfo_ipv4_address_from_array(const uint8_t *address)
Instantiate an IPv4 address structure from a byte array.
Definition ipinfo.c:60
QSC_EXPORT_API bool qsc_ipinfo_ipv6_address_is_routable(const qsc_ipinfo_ipv6_address *address)
Test if the IPv6 address is a valid public address.
Definition ipinfo.c:658
QSC_EXPORT_API void qsc_ipinfo_ipv4_array_to_string(char output[QSC_IPINFO_IPV4_STRNLEN], const uint8_t *address)
Convert an IPv4 address array to a string.
Definition ipinfo.c:372
QSC_EXPORT_API qsc_ipinfo_ipv6_address qsc_ipinfo_ipv6_address_any(void)
Get a copy of the IPv6 loopback address.
Definition ipinfo.c:567
QSC_EXPORT_API void qsc_ipinfo_ipv6_address_clear(qsc_ipinfo_ipv6_address *address)
Clear the IPv6 address structure.
Definition ipinfo.c:574
QSC_EXPORT_API bool qsc_ipinfo_ipv6_address_is_equal(const qsc_ipinfo_ipv6_address *a, const qsc_ipinfo_ipv6_address *b)
Compare two IPv6 address structures for equality.
Definition ipinfo.c:634
QSC_EXPORT_API qsc_ipinfo_ipv4_address qsc_ipinfo_ipv4_address_from_string(const char input[QSC_IPINFO_IPV4_STRNLEN])
Instantiate an IPv4 address structure from a string.
Definition ipinfo.c:85
#define QSC_IPINFO_IPV4_MASK_STRNLEN
The IPv4 subnet mask string length.
Definition ipinfo.h:99
Contains common memory-related functions implemented using SIMD instructions.
The socket flags enumerations.
qsc_ipv6_address_prefix_types
IPv6 address prefixes.
Definition socketflags.h:56
String utilities; common string support functions.
The IPv4 address structure.
Definition ipinfo.h:150
uint8_t ipv4[QSC_IPINFO_IPV4_BYTELEN]
Definition ipinfo.h:151
The IPv4 information structure.
Definition ipinfo.h:161
qsc_ipinfo_ipv4_address address
Definition ipinfo.h:162
uint8_t mask
Definition ipinfo.h:164
uint16_t port
Definition ipinfo.h:163
The IPv6 address structure.
Definition ipinfo.h:309
uint8_t ipv6[QSC_IPINFO_IPV6_BYTELEN]
Definition ipinfo.h:310
The IPv6 information structure.
Definition ipinfo.h:320
qsc_ipinfo_ipv6_address address
Definition ipinfo.h:321
uint8_t mask
Definition ipinfo.h:323
uint16_t port
Definition ipinfo.h:322