Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
opendht
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Code
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Locked files
Deploy
Model registry
Analyze
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
savoirfairelinux
opendht
Commits
2e47b9ba
Commit
2e47b9ba
authored
5 years ago
by
Adrien Béraud
Browse files
Options
Downloads
Patches
Plain Diff
c wrapper: add dht_runner_get_public_address to dhtcnode
parent
f938d486
Branches
Branches containing commit
Tags
Tags containing commit
No related merge requests found
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
c/opendht.cpp
+7
-5
7 additions, 5 deletions
c/opendht.cpp
c/opendht_c.h
+1
-3
1 addition, 3 deletions
c/opendht_c.h
tools/dhtcnode.c
+36
-0
36 additions, 0 deletions
tools/dhtcnode.c
with
44 additions
and
8 deletions
c/opendht.cpp
+
7
−
5
View file @
2e47b9ba
...
@@ -193,7 +193,10 @@ void dht_runner_ping(dht_runner* r, struct sockaddr* addr, socklen_t addr_len) {
...
@@ -193,7 +193,10 @@ void dht_runner_ping(dht_runner* r, struct sockaddr* addr, socklen_t addr_len) {
void
dht_runner_bootstrap
(
dht_runner
*
r
,
const
char
*
host
,
const
char
*
service
)
{
void
dht_runner_bootstrap
(
dht_runner
*
r
,
const
char
*
host
,
const
char
*
service
)
{
auto
runner
=
reinterpret_cast
<
dht
::
DhtRunner
*>
(
r
);
auto
runner
=
reinterpret_cast
<
dht
::
DhtRunner
*>
(
r
);
if
(
service
)
runner
->
bootstrap
(
host
,
service
);
runner
->
bootstrap
(
host
,
service
);
else
runner
->
bootstrap
(
host
);
}
}
void
dht_runner_get
(
dht_runner
*
r
,
const
dht_infohash
*
h
,
dht_get_cb
cb
,
dht_done_cb
done_cb
,
void
*
cb_user_data
)
{
void
dht_runner_get
(
dht_runner
*
r
,
const
dht_infohash
*
h
,
dht_get_cb
cb
,
dht_done_cb
done_cb
,
void
*
cb_user_data
)
{
...
@@ -294,16 +297,15 @@ dht_infohash dht_runner_get_id(const dht_runner* r) {
...
@@ -294,16 +297,15 @@ dht_infohash dht_runner_get_id(const dht_runner* r) {
return
ret
;
return
ret
;
}
}
const
struct
sockaddr
**
dht_runner_get_public_address
(
const
dht_runner
*
r
)
struct
sockaddr
**
dht_runner_get_public_address
(
const
dht_runner
*
r
)
{
{
auto
runner
=
reinterpret_cast
<
const
dht
::
DhtRunner
*>
(
r
);
auto
runner
=
reinterpret_cast
<
const
dht
::
DhtRunner
*>
(
r
);
auto
addrs
=
const_cast
<
dht
::
DhtRunner
*>
(
runner
)
->
getPublicAddress
();
auto
addrs
=
const_cast
<
dht
::
DhtRunner
*>
(
runner
)
->
getPublicAddress
();
if
(
addrs
.
empty
())
if
(
addrs
.
empty
())
return
nullptr
;
return
nullptr
;
auto
ret
=
(
const
struct
sockaddr
**
)
malloc
(
sizeof
(
struct
sockaddr
*
)
*
(
addrs
.
size
()
+
1
));
auto
ret
=
(
struct
sockaddr
**
)
malloc
(
sizeof
(
struct
sockaddr
*
)
*
(
addrs
.
size
()
+
1
));
for
(
size_t
i
=
0
;
i
<
addrs
.
size
();
i
++
)
{
for
(
size_t
i
=
0
;
i
<
addrs
.
size
();
i
++
)
{
if
(
auto
len
=
addrs
[
i
].
getLength
())
{
if
(
auto
len
=
addrs
[
i
].
getLength
())
{
ret
[
i
]
=
(
const
struct
sockaddr
*
)
malloc
(
len
);
ret
[
i
]
=
(
struct
sockaddr
*
)
malloc
(
len
);
memcpy
((
struct
sockaddr
*
)
ret
[
i
],
addrs
[
i
].
get
(),
len
);
memcpy
((
struct
sockaddr
*
)
ret
[
i
],
addrs
[
i
].
get
(),
len
);
}
else
{
}
else
{
ret
[
i
]
=
nullptr
;
ret
[
i
]
=
nullptr
;
...
...
This diff is collapsed.
Click to expand it.
c/opendht_c.h
+
1
−
3
View file @
2e47b9ba
...
@@ -11,8 +11,6 @@ extern "C" {
...
@@ -11,8 +11,6 @@ extern "C" {
#include
<stdint.h>
#include
<stdint.h>
#include
<stddef.h>
#include
<stddef.h>
struct
sockaddr
;
// Non-owning data view
// Non-owning data view
struct
OPENDHT_C_PUBLIC
dht_data_view
{
struct
OPENDHT_C_PUBLIC
dht_data_view
{
const
uint8_t
*
data
;
const
uint8_t
*
data
;
...
@@ -139,7 +137,7 @@ OPENDHT_C_PUBLIC void dht_runner_cancel_put(dht_runner* runner, const dht_infoha
...
@@ -139,7 +137,7 @@ OPENDHT_C_PUBLIC void dht_runner_cancel_put(dht_runner* runner, const dht_infoha
OPENDHT_C_PUBLIC
void
dht_runner_shutdown
(
dht_runner
*
runner
,
dht_shutdown_cb
done_cb
,
void
*
cb_user_data
);
OPENDHT_C_PUBLIC
void
dht_runner_shutdown
(
dht_runner
*
runner
,
dht_shutdown_cb
done_cb
,
void
*
cb_user_data
);
OPENDHT_C_PUBLIC
dht_infohash
dht_runner_get_node_id
(
const
dht_runner
*
runner
);
OPENDHT_C_PUBLIC
dht_infohash
dht_runner_get_node_id
(
const
dht_runner
*
runner
);
OPENDHT_C_PUBLIC
dht_infohash
dht_runner_get_id
(
const
dht_runner
*
runner
);
OPENDHT_C_PUBLIC
dht_infohash
dht_runner_get_id
(
const
dht_runner
*
runner
);
OPENDHT_C_PUBLIC
const
struct
sockaddr
**
dht_runner_get_public_address
(
const
dht_runner
*
runner
);
OPENDHT_C_PUBLIC
struct
sockaddr
**
dht_runner_get_public_address
(
const
dht_runner
*
runner
);
#ifdef __cplusplus
#ifdef __cplusplus
}
}
...
...
This diff is collapsed.
Click to expand it.
tools/dhtcnode.c
+
36
−
0
View file @
2e47b9ba
...
@@ -4,6 +4,7 @@
...
@@ -4,6 +4,7 @@
#include
<string.h>
#include
<string.h>
#include
<unistd.h>
#include
<unistd.h>
#include
<stdlib.h>
#include
<stdlib.h>
#include
<arpa/inet.h>
struct
op_context
{
struct
op_context
{
dht_runner
*
runner
;
dht_runner
*
runner
;
...
@@ -36,6 +37,27 @@ bool op_context_free(void* user_data)
...
@@ -36,6 +37,27 @@ bool op_context_free(void* user_data)
free
(
ctx
);
free
(
ctx
);
}
}
char
*
print_addr
(
const
struct
sockaddr
*
addr
)
{
char
*
s
=
NULL
;
switch
(
addr
->
sa_family
)
{
case
AF_INET
:
{
struct
sockaddr_in
*
addr_in
=
(
struct
sockaddr_in
*
)
addr
;
s
=
malloc
(
INET_ADDRSTRLEN
);
inet_ntop
(
AF_INET
,
&
(
addr_in
->
sin_addr
),
s
,
INET_ADDRSTRLEN
);
break
;
}
case
AF_INET6
:
{
struct
sockaddr_in6
*
addr_in6
=
(
struct
sockaddr_in6
*
)
addr
;
s
=
malloc
(
INET6_ADDRSTRLEN
);
inet_ntop
(
AF_INET6
,
&
(
addr_in6
->
sin6_addr
),
s
,
INET6_ADDRSTRLEN
);
break
;
}
default:
break
;
}
return
s
;
}
int
main
()
int
main
()
{
{
dht_runner
*
runner
=
dht_runner_new
();
dht_runner
*
runner
=
dht_runner_new
();
...
@@ -63,6 +85,20 @@ int main()
...
@@ -63,6 +85,20 @@ int main()
sleep
(
1
);
sleep
(
1
);
dht_runner_bootstrap
(
runner
,
"bootstrap.jami.net"
,
NULL
);
sleep
(
2
);
struct
sockaddr
**
addrs
=
dht_runner_get_public_address
(
runner
);
for
(
struct
sockaddr
**
addrIt
=
addrs
;
*
addrIt
;
addrIt
++
)
{
struct
sockaddr
*
addr
=
*
addrIt
;
char
*
addr_str
=
print_addr
(
addr
);
free
(
addr
);
printf
(
"Found public address: %s
\n
"
,
addr_str
);
free
(
addr_str
);
}
free
(
addrs
);
dht_runner_cancel_listen
(
runner
,
&
h
,
token
);
dht_runner_cancel_listen
(
runner
,
&
h
,
token
);
dht_op_token_delete
(
token
);
dht_op_token_delete
(
token
);
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment