GNUnet 0.21.1
messenger_api_util.c
Go to the documentation of this file.
1/*
2 This file is part of GNUnet.
3 Copyright (C) 2020--2024 GNUnet e.V.
4
5 GNUnet is free software: you can redistribute it and/or modify it
6 under the terms of the GNU Affero General Public License as published
7 by the Free Software Foundation, either version 3 of the License,
8 or (at your option) any later version.
9
10 GNUnet is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Affero General Public License for more details.
14
15 You should have received a copy of the GNU Affero General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18 SPDX-License-Identifier: AGPL3.0-or-later
19 */
26#include "messenger_api_util.h"
27
30
31static void
33{
34 struct GNUNET_CADET_Channel *channel = cls;
35
36 if (channel)
38}
39
40
41void
43{
44 GNUNET_assert (channel);
45
48 callback_close_channel, channel);
49}
50
51
54 const struct GNUNET_CONTAINER_MultiShortmap *members)
55{
56 GNUNET_assert (id);
57
58 size_t counter = 1 + (members ? GNUNET_CONTAINER_multishortmap_size (
59 members) : 0);
60
61 do
62 {
65
67 members, id)))
68 counter--;
69 else
70 break;
71 }
72 while (counter > 0);
73
74 if (counter)
75 return GNUNET_YES;
76
77 return GNUNET_NO;
78}
79
80
81const struct GNUNET_CRYPTO_PrivateKey*
83{
86}
87
88
89const struct GNUNET_CRYPTO_PublicKey*
91{
92 static struct GNUNET_CRYPTO_PublicKey public_key;
93 static struct GNUNET_IDENTITY_Ego *ego = NULL;
94
95 if (! ego)
96 {
98 GNUNET_IDENTITY_ego_get_public_key (ego, &public_key);
99 }
100
101 return &public_key;
102}
103
104
105void
107 struct GNUNET_HashCode *port)
108{
109 static uint32_t version_value = 0;
110 static struct GNUNET_HashCode version;
111
112 if (! version_value)
113 {
114 version_value = (uint32_t) (GNUNET_MESSENGER_VERSION);
115 version_value = ((version_value >> 16) & 0xFFFF);
116 version_value = GNUNET_htole32 (version_value);
117 GNUNET_CRYPTO_hash (&version_value, sizeof(version_value), &version);
118 }
119
120 GNUNET_CRYPTO_hash_sum (key, &version, port);
121}
122
123
124void
126 struct GNUNET_ShortHashCode *id)
127{
128 GNUNET_memcpy (id, identity, sizeof(struct GNUNET_ShortHashCode));
129}
static uint16_t port
Port number.
Definition: gnunet-bcd.c:147
struct GNUNET_HashCode key
The key used in the DHT.
static struct GNUNET_IDENTITY_Handle * identity
Which namespace do we publish to? NULL if we do not publish to a namespace.
Identity service; implements identity management for GNUnet.
void GNUNET_CADET_channel_destroy(struct GNUNET_CADET_Channel *channel)
Destroy an existing channel.
Definition: cadet_api.c:830
void GNUNET_CRYPTO_random_block(enum GNUNET_CRYPTO_Quality mode, void *buffer, size_t length)
Fill block with a random values.
@ GNUNET_CRYPTO_QUALITY_STRONG
High-quality operations are desired.
void GNUNET_CRYPTO_hash(const void *block, size_t size, struct GNUNET_HashCode *ret)
Compute hash of a given block.
Definition: crypto_hash.c:41
void GNUNET_CRYPTO_hash_sum(const struct GNUNET_HashCode *a, const struct GNUNET_HashCode *delta, struct GNUNET_HashCode *result)
compute result = a + delta
Definition: crypto_hash.c:123
unsigned int GNUNET_CONTAINER_multishortmap_size(const struct GNUNET_CONTAINER_MultiShortmap *map)
Get the number of key-value pairs in the map.
int GNUNET_CONTAINER_multishortmap_contains(const struct GNUNET_CONTAINER_MultiShortmap *map, const struct GNUNET_ShortHashCode *key)
Check if the map contains any value under the given key (including values that are NULL).
const struct GNUNET_CRYPTO_PrivateKey * GNUNET_IDENTITY_ego_get_private_key(const struct GNUNET_IDENTITY_Ego *ego)
Obtain the ECC key associated with a ego.
Definition: identity_api.c:517
struct GNUNET_IDENTITY_Ego * GNUNET_IDENTITY_ego_get_anonymous(void)
Obtain the ego representing 'anonymous' users.
Definition: identity_api.c:157
void GNUNET_IDENTITY_ego_get_public_key(struct GNUNET_IDENTITY_Ego *ego, struct GNUNET_CRYPTO_PublicKey *pk)
Get the identifier (public key) of an ego.
Definition: identity_api.c:529
#define GNUNET_htole32(x)
#define GNUNET_memcpy(dst, src, n)
Call memcpy() but check for n being 0 first.
GNUNET_GenericReturnValue
Named constants for return values.
@ GNUNET_SCHEDULER_PRIORITY_URGENT
Run with priority for urgent tasks.
@ GNUNET_YES
@ GNUNET_NO
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
#define GNUNET_MESSENGER_VERSION
Version number of GNUnet Messenger API.
struct GNUNET_SCHEDULER_Task * GNUNET_SCHEDULER_add_delayed_with_priority(struct GNUNET_TIME_Relative delay, enum GNUNET_SCHEDULER_Priority priority, GNUNET_SCHEDULER_TaskCallback task, void *task_cls)
Schedule a new task to be run with a specified delay.
Definition: scheduler.c:1208
struct GNUNET_TIME_Relative GNUNET_TIME_relative_get_zero_(void)
Return relative time of 0ms.
Definition: time.c:133
enum GNUNET_GenericReturnValue generate_free_member_id(struct GNUNET_ShortHashCode *id, const struct GNUNET_CONTAINER_MultiShortmap *members)
Tries to generate an unused member id and store it into the id parameter.
static void callback_close_channel(void *cls)
const struct GNUNET_CRYPTO_PrivateKey * get_anonymous_private_key()
Returns the private identity key of GNUNET_IDENTITY_ego_get_anonymous() without recalculating it ever...
void convert_messenger_key_to_port(const struct GNUNET_HashCode *key, struct GNUNET_HashCode *port)
Converts a Messenger service key of a room to the specific port which gets used for the CADET channel...
void convert_peer_identity_to_id(const struct GNUNET_PeerIdentity *identity, struct GNUNET_ShortHashCode *id)
Converts a peers identity to a short hash code which can be used as id to refer to a peer via sender ...
void delayed_disconnect_channel(struct GNUNET_CADET_Channel *channel)
Starts an urgent task to close a CADET channel asynchronously.
const struct GNUNET_CRYPTO_PublicKey * get_anonymous_public_key()
Returns the public identity key of GNUNET_IDENTITY_ego_get_anonymous() without recalculating it every...
Opaque handle to a channel.
Definition: cadet.h:116
Internal representation of the hash map.
A private key for an identity as per LSD0001.
An identity key as per LSD0001.
A 512-bit hashcode.
Handle for an ego.
Definition: identity.h:37
The identity of the host (wraps the signing key of the peer).
A 256-bit hashcode.