2014-07-18 15:53:08 +02:00
|
|
|
--- xdm/auth.c.orig 2011-09-25 09:35:47.000000000 +0200
|
|
|
|
+++ xdm/auth.c 2014-07-18 14:55:03.244300844 +0200
|
|
|
|
@@ -767,7 +767,7 @@ writeAddr (
|
2012-04-14 11:33:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
-DefineLocal (FILE *file, Xauth *auth)
|
|
|
|
+DefineLocal (FILE *file, Xauth *auth, char **pLocalAddress)
|
|
|
|
{
|
|
|
|
char displayname[100];
|
|
|
|
int len = _XGetHostname (displayname, sizeof(displayname));
|
2014-07-18 15:53:08 +02:00
|
|
|
@@ -803,6 +803,9 @@ DefineLocal (FILE *file, Xauth *auth)
|
2012-04-14 11:33:31 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
writeAddr (FamilyLocal, len, displayname, file, auth);
|
|
|
|
+
|
2014-07-18 15:53:08 +02:00
|
|
|
+ if (pLocalAddress)
|
2012-04-14 11:33:31 +02:00
|
|
|
+ *pLocalAddress = strdup(displayname);
|
|
|
|
}
|
|
|
|
|
2014-07-18 15:53:08 +02:00
|
|
|
#ifdef HAVE_GETIFADDRS
|
|
|
|
@@ -1236,7 +1239,7 @@ setAuthNumber (Xauth *auth, char *name)
|
2012-04-14 11:33:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
-writeLocalAuth (FILE *file, Xauth *auth, char *name)
|
|
|
|
+writeLocalAuth (FILE *file, Xauth *auth, char *name, char **pLocalAddress)
|
|
|
|
{
|
|
|
|
int fd;
|
|
|
|
|
2014-07-18 15:53:08 +02:00
|
|
|
@@ -1263,13 +1266,13 @@ writeLocalAuth (FILE *file, Xauth *auth,
|
2012-04-14 11:33:31 +02:00
|
|
|
DefineSelf (fd, file, auth);
|
|
|
|
close (fd);
|
|
|
|
#endif
|
|
|
|
- DefineLocal (file, auth);
|
|
|
|
+ DefineLocal (file, auth, pLocalAddress);
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef XDMCP
|
|
|
|
|
|
|
|
static void
|
|
|
|
-writeRemoteAuth (FILE *file, Xauth *auth, XdmcpNetaddr peer, int peerlen, char *name)
|
|
|
|
+writeRemoteAuth (FILE *file, Xauth *auth, XdmcpNetaddr peer, int peerlen, char *name, char **pLocalAddress)
|
|
|
|
{
|
|
|
|
int family = FamilyLocal;
|
|
|
|
char *addr;
|
2014-07-18 15:53:08 +02:00
|
|
|
@@ -1288,7 +1291,7 @@ writeRemoteAuth (FILE *file, Xauth *auth
|
2012-04-14 11:33:31 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
- writeLocalAuth (file, auth, name);
|
|
|
|
+ writeLocalAuth (file, auth, name, pLocalAddress);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-18 15:53:08 +02:00
|
|
|
@@ -1312,6 +1315,7 @@ SetUserAuthorization (struct display *d,
|
|
|
|
#ifdef HAVE_MKSTEMP
|
2012-04-14 11:33:31 +02:00
|
|
|
int fd;
|
|
|
|
#endif
|
|
|
|
+ char *localAddress = NULL;
|
|
|
|
|
|
|
|
Debug ("SetUserAuthorization\n");
|
|
|
|
auths = d->authorizations;
|
2014-07-18 15:53:08 +02:00
|
|
|
@@ -1404,10 +1408,10 @@ SetUserAuthorization (struct display *d,
|
2012-04-14 11:33:31 +02:00
|
|
|
{
|
|
|
|
magicCookie = i;
|
2014-07-18 15:53:08 +02:00
|
|
|
if (d->displayType.location == Local)
|
|
|
|
- writeLocalAuth (new, auths[i], d->name);
|
|
|
|
+ writeLocalAuth (new, auths[i], d->name, &localAddress);
|
2012-04-14 11:33:31 +02:00
|
|
|
#ifdef XDMCP
|
2014-07-18 15:53:08 +02:00
|
|
|
else
|
|
|
|
- writeRemoteAuth (new, auths[i], d->peer, d->peerlen, d->name);
|
|
|
|
+ writeRemoteAuth (new, auths[i], d->peer, d->peerlen, d->name, &localAddress);
|
2012-04-14 11:33:31 +02:00
|
|
|
#endif
|
|
|
|
break;
|
|
|
|
}
|
2014-07-18 15:53:08 +02:00
|
|
|
@@ -1425,10 +1429,10 @@ SetUserAuthorization (struct display *d,
|
2012-04-14 11:33:31 +02:00
|
|
|
!strncmp (auths[i]->name, "MIT-KERBEROS-5", 14))
|
|
|
|
auths[i]->data_length = 0;
|
2014-07-18 15:53:08 +02:00
|
|
|
if (d->displayType.location == Local)
|
|
|
|
- writeLocalAuth (new, auths[i], d->name);
|
|
|
|
+ writeLocalAuth (new, auths[i], d->name, &localAddress);
|
2012-04-14 11:33:31 +02:00
|
|
|
#ifdef XDMCP
|
2014-07-18 15:53:08 +02:00
|
|
|
else
|
|
|
|
- writeRemoteAuth (new, auths[i], d->peer, d->peerlen, d->name);
|
|
|
|
+ writeRemoteAuth (new, auths[i], d->peer, d->peerlen, d->name, &localAddress);
|
2012-04-14 11:33:31 +02:00
|
|
|
#endif
|
|
|
|
auths[i]->data_length = data_len;
|
|
|
|
}
|
2014-07-18 15:53:08 +02:00
|
|
|
@@ -1473,6 +1477,12 @@ SetUserAuthorization (struct display *d,
|
2012-04-14 11:33:31 +02:00
|
|
|
verify->systemEnviron = setEnv (verify->systemEnviron,
|
|
|
|
"XAUTHORITY", envname);
|
|
|
|
}
|
|
|
|
+ if (localAddress) {
|
|
|
|
+ verify->userEnviron = setEnv (verify->userEnviron,
|
|
|
|
+ "XAUTHLOCALHOSTNAME",localAddress);
|
|
|
|
+ free(localAddress);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
XauUnlockAuth (name);
|
|
|
|
if (envname)
|
|
|
|
chown (envname, verify->uid, verify->gid);
|
2014-07-18 15:53:08 +02:00
|
|
|
@@ -1511,10 +1521,10 @@ RemoveUserAuthorization (struct display
|
2012-04-14 11:33:31 +02:00
|
|
|
for (i = 0; i < d->authNum; i++)
|
|
|
|
{
|
|
|
|
if (d->displayType.location == Local)
|
2014-07-18 15:53:08 +02:00
|
|
|
- writeLocalAuth (new, auths[i], d->name);
|
|
|
|
+ writeLocalAuth (new, auths[i], d->name, NULL);
|
2012-04-14 11:33:31 +02:00
|
|
|
#ifdef XDMCP
|
|
|
|
else
|
2014-07-18 15:53:08 +02:00
|
|
|
- writeRemoteAuth (new, auths[i], d->peer, d->peerlen, d->name);
|
|
|
|
+ writeRemoteAuth (new, auths[i], d->peer, d->peerlen, d->name, NULL);
|
2012-04-14 11:33:31 +02:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
doWrite = 1;
|