mirror of
https://gitlab.freedesktop.org/pulseaudio/pulseaudio.git
synced 2025-12-29 11:08:35 -05:00
use machine id instead of hostname to identify local connections
This commit is contained in:
parent
dcb24f5068
commit
380e97a596
3 changed files with 23 additions and 17 deletions
|
|
@ -87,13 +87,15 @@ int pa_parse_address(const char *name, pa_parsed_address *ret_p) {
|
|||
ret_p->type = PA_PARSED_ADDRESS_TCP_AUTO;
|
||||
|
||||
if (*name == '{') {
|
||||
char hn[256], *pfx;
|
||||
/* The URL starts with a host specification for detecting local connections */
|
||||
char *id, *pfx;
|
||||
|
||||
if (!pa_get_host_name(hn, sizeof(hn)))
|
||||
/* The URL starts with a host id for detecting local connections */
|
||||
if (!(id = pa_machine_id()))
|
||||
return -1;
|
||||
|
||||
pfx = pa_sprintf_malloc("{%s}", hn);
|
||||
pfx = pa_sprintf_malloc("{%s}", id);
|
||||
pa_xfree(id);
|
||||
|
||||
if (!pa_startswith(name, pfx)) {
|
||||
pa_xfree(pfx);
|
||||
/* Not local */
|
||||
|
|
|
|||
|
|
@ -467,11 +467,13 @@ char *pa_socket_server_get_address(pa_socket_server *s, char *c, size_t l) {
|
|||
pa_snprintf(c, l, "tcp6:%s:%u", fqdn, (unsigned) ntohs(sa.sin6_port));
|
||||
|
||||
} else if (memcmp(&in6addr_loopback, &sa.sin6_addr, sizeof(in6addr_loopback)) == 0) {
|
||||
char hn[256];
|
||||
if (!pa_get_host_name(hn, sizeof(hn)))
|
||||
char *id;
|
||||
|
||||
if (!(id = pa_machine_id()))
|
||||
return NULL;
|
||||
|
||||
pa_snprintf(c, l, "{%s}tcp6:localhost:%u", hn, (unsigned) ntohs(sa.sin6_port));
|
||||
pa_snprintf(c, l, "{%s}tcp6:localhost:%u", id, (unsigned) ntohs(sa.sin6_port));
|
||||
pa_xfree(id);
|
||||
} else {
|
||||
char ip[INET6_ADDRSTRLEN];
|
||||
|
||||
|
|
@ -503,11 +505,13 @@ char *pa_socket_server_get_address(pa_socket_server *s, char *c, size_t l) {
|
|||
|
||||
pa_snprintf(c, l, "tcp:%s:%u", fqdn, (unsigned) ntohs(sa.sin_port));
|
||||
} else if (sa.sin_addr.s_addr == INADDR_LOOPBACK) {
|
||||
char hn[256];
|
||||
if (!pa_get_host_name(hn, sizeof(hn)))
|
||||
char *id;
|
||||
|
||||
if (!(id = pa_machine_id()))
|
||||
return NULL;
|
||||
|
||||
pa_snprintf(c, l, "{%s}tcp:localhost:%u", hn, (unsigned) ntohs(sa.sin_port));
|
||||
pa_snprintf(c, l, "{%s}tcp:localhost:%u", id, (unsigned) ntohs(sa.sin_port));
|
||||
pa_xfree(id);
|
||||
} else {
|
||||
char ip[INET_ADDRSTRLEN];
|
||||
|
||||
|
|
@ -523,15 +527,15 @@ char *pa_socket_server_get_address(pa_socket_server *s, char *c, size_t l) {
|
|||
}
|
||||
|
||||
case SOCKET_SERVER_UNIX: {
|
||||
char hn[256];
|
||||
char *id;
|
||||
|
||||
if (!s->filename)
|
||||
return NULL;
|
||||
|
||||
if (!pa_get_host_name(hn, sizeof(hn)))
|
||||
if (!(id = pa_machine_id()))
|
||||
return NULL;
|
||||
|
||||
pa_snprintf(c, l, "{%s}unix:%s", hn, s->filename);
|
||||
pa_snprintf(c, l, "{%s}unix:%s", id, s->filename);
|
||||
return c;
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue