2024-10-23 12:04:25 +02:00
|
|
|
Index: src/xcb_auth.c
|
|
|
|
===================================================================
|
|
|
|
--- src/xcb_auth.c.orig
|
|
|
|
+++ src/xcb_auth.c
|
|
|
|
@@ -118,6 +118,7 @@ static Xauth *get_authptr(struct sockadd
|
|
|
|
char hostnamebuf[256]; /* big enough for max hostname */
|
|
|
|
char dispbuf[40]; /* big enough to hold more than 2^64 base 10 */
|
2024-05-03 16:09:01 +02:00
|
|
|
int dispbuflen;
|
|
|
|
+ Xauth *authptr = NULL;
|
|
|
|
|
2024-10-23 12:04:25 +02:00
|
|
|
family = FamilyLocal; /* 256 */
|
|
|
|
switch(sockname->sa_family)
|
|
|
|
@@ -162,10 +163,20 @@ static Xauth *get_authptr(struct sockadd
|
|
|
|
addrlen = strlen(addr);
|
|
|
|
}
|
2024-05-03 16:09:01 +02:00
|
|
|
|
|
|
|
- return XauGetBestAuthByAddr (family,
|
|
|
|
+ authptr = XauGetBestAuthByAddr (family,
|
|
|
|
(unsigned short) addrlen, addr,
|
|
|
|
(unsigned short) dispbuflen, dispbuf,
|
2024-10-23 12:04:25 +02:00
|
|
|
N_AUTH_PROTOS, (char **)authnames, authnameslen);
|
2024-05-03 16:09:01 +02:00
|
|
|
+ // && !phostname
|
|
|
|
+ if ((!authptr || !authptr->data_length) && family == FamilyLocal) {
|
|
|
|
+ if ( (addr = getenv("XAUTHLOCALHOSTNAME")) ) {
|
|
|
|
+ authptr = XauGetBestAuthByAddr (family,
|
|
|
|
+ (unsigned short) strlen(addr), addr,
|
|
|
|
+ (unsigned short) dispbuflen, dispbuf,
|
2024-10-23 12:04:25 +02:00
|
|
|
+ N_AUTH_PROTOS, (char **) authnames, authnameslen);
|
2024-05-03 16:09:01 +02:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return authptr;
|
|
|
|
}
|
2024-10-23 12:04:25 +02:00
|
|
|
|
|
|
|
#ifdef HASXDMAUTH
|