mirror of
https://github.com/gnustep/libs-base.git
synced 2025-06-02 09:31:07 +00:00
Apply security fix and minor portability tweaks.
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/base/trunk@18936 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
parent
ca3d4a1a01
commit
1df7325dc3
4 changed files with 83 additions and 16 deletions
10
ChangeLog
10
ChangeLog
|
@ -1,3 +1,13 @@
|
||||||
|
2004-03-27 Richard Frith-Macdonald <rfm@gnu.org>
|
||||||
|
|
||||||
|
* NSMessagePort.m:
|
||||||
|
* NSMessagePortNameServer.m: Use base library methods for file
|
||||||
|
management rather than unix syscalls.
|
||||||
|
|
||||||
|
2004-03-27 Alexander Malmberg <alexander@malmberg.org>
|
||||||
|
|
||||||
|
* NSUser.m: Plug some security loopholes in temporary directory
|
||||||
|
|
||||||
2004-03-27 Mark Allison <mark@brainstorm.co.uk>
|
2004-03-27 Mark Allison <mark@brainstorm.co.uk>
|
||||||
|
|
||||||
* Headers/Additions/GNUstepBase/GSXML.h:
|
* Headers/Additions/GNUstepBase/GSXML.h:
|
||||||
|
|
|
@ -39,6 +39,9 @@
|
||||||
#include "Foundation/NSConnection.h"
|
#include "Foundation/NSConnection.h"
|
||||||
#include "Foundation/NSDebug.h"
|
#include "Foundation/NSDebug.h"
|
||||||
#include "Foundation/NSPathUtilities.h"
|
#include "Foundation/NSPathUtilities.h"
|
||||||
|
#include "Foundation/NSValue.h"
|
||||||
|
#include "Foundation/NSFileManager.h"
|
||||||
|
#include "Foundation/NSProcessInfo.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#ifdef HAVE_UNISTD_H
|
#ifdef HAVE_UNISTD_H
|
||||||
|
@ -1186,19 +1189,27 @@ static unsigned wordAlign;
|
||||||
+ (id) new
|
+ (id) new
|
||||||
{
|
{
|
||||||
static int unique_index = 0;
|
static int unique_index = 0;
|
||||||
NSString *path;
|
NSString *path;
|
||||||
|
NSNumber *p = [NSNumber numberWithInt: 0700];
|
||||||
|
NSDictionary *attr;
|
||||||
|
|
||||||
|
attr = [NSDictionary dictionaryWithObject: p
|
||||||
|
forKey: NSFilePosixPermissions];
|
||||||
|
|
||||||
path = NSTemporaryDirectory();
|
path = NSTemporaryDirectory();
|
||||||
|
|
||||||
path = [path stringByAppendingPathComponent: @"NSMessagePort"];
|
path = [path stringByAppendingPathComponent: @"NSMessagePort"];
|
||||||
mkdir([path fileSystemRepresentation], 0700);
|
[[NSFileManager defaultManager] createDirectoryAtPath: path
|
||||||
|
attributes: attr];
|
||||||
|
|
||||||
path = [path stringByAppendingPathComponent: @"ports"];
|
path = [path stringByAppendingPathComponent: @"ports"];
|
||||||
mkdir([path fileSystemRepresentation], 0700);
|
[[NSFileManager defaultManager] createDirectoryAtPath: path
|
||||||
|
attributes: attr];
|
||||||
|
|
||||||
M_LOCK(messagePortLock);
|
M_LOCK(messagePortLock);
|
||||||
path = [path stringByAppendingPathComponent:
|
path = [path stringByAppendingPathComponent:
|
||||||
[NSString stringWithFormat: @"%i.%i", getpid(), unique_index++]];
|
[NSString stringWithFormat: @"%i.%i",
|
||||||
|
[[NSProcessInfo processInfo] processIdentifier], unique_index++]];
|
||||||
M_UNLOCK(messagePortLock);
|
M_UNLOCK(messagePortLock);
|
||||||
|
|
||||||
return RETAIN([self _portWithName: [path fileSystemRepresentation]
|
return RETAIN([self _portWithName: [path fileSystemRepresentation]
|
||||||
|
|
|
@ -7,6 +7,8 @@
|
||||||
#include "Foundation/NSMapTable.h"
|
#include "Foundation/NSMapTable.h"
|
||||||
#include "Foundation/NSPathUtilities.h"
|
#include "Foundation/NSPathUtilities.h"
|
||||||
#include "Foundation/NSPort.h"
|
#include "Foundation/NSPort.h"
|
||||||
|
#include "Foundation/NSFileManager.h"
|
||||||
|
#include "Foundation/NSValue.h"
|
||||||
|
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
@ -104,13 +106,20 @@ static void clean_up_names(void)
|
||||||
[serverLock lock];
|
[serverLock lock];
|
||||||
if (!base_path)
|
if (!base_path)
|
||||||
{
|
{
|
||||||
|
NSNumber *p = [NSNumber numberWithInt: 0700];
|
||||||
|
NSDictionary *attr;
|
||||||
|
|
||||||
path = NSTemporaryDirectory();
|
path = NSTemporaryDirectory();
|
||||||
|
attr = [NSDictionary dictionaryWithObject: p
|
||||||
|
forKey: NSFilePosixPermissions];
|
||||||
|
|
||||||
path = [path stringByAppendingPathComponent: @"NSMessagePort"];
|
path = [path stringByAppendingPathComponent: @"NSMessagePort"];
|
||||||
mkdir([path fileSystemRepresentation], 0700);
|
[[NSFileManager defaultManager] createDirectoryAtPath: path
|
||||||
|
attributes: attr];
|
||||||
|
|
||||||
path = [path stringByAppendingPathComponent: @"names"];
|
path = [path stringByAppendingPathComponent: @"names"];
|
||||||
mkdir([path fileSystemRepresentation], 0700);
|
[[NSFileManager defaultManager] createDirectoryAtPath: path
|
||||||
|
attributes: attr];
|
||||||
|
|
||||||
base_path = RETAIN(path);
|
base_path = RETAIN(path);
|
||||||
}
|
}
|
||||||
|
|
|
@ -774,6 +774,9 @@ NSStandardLibraryPaths(void)
|
||||||
/**
|
/**
|
||||||
* Returns the name of a directory in which temporary files can be stored.
|
* Returns the name of a directory in which temporary files can be stored.
|
||||||
* Under GNUstep this is a location which is not readable by other users.
|
* Under GNUstep this is a location which is not readable by other users.
|
||||||
|
* <br />
|
||||||
|
* If a suitable directory can't be found or created, this function raises an
|
||||||
|
* NSGenericException.
|
||||||
*/
|
*/
|
||||||
NSString *
|
NSString *
|
||||||
NSTemporaryDirectory(void)
|
NSTemporaryDirectory(void)
|
||||||
|
@ -783,6 +786,8 @@ NSTemporaryDirectory(void)
|
||||||
NSString *baseTempDirName = nil;
|
NSString *baseTempDirName = nil;
|
||||||
NSDictionary *attr;
|
NSDictionary *attr;
|
||||||
int perm;
|
int perm;
|
||||||
|
int owner;
|
||||||
|
int uid;
|
||||||
BOOL flag;
|
BOOL flag;
|
||||||
#if defined(__WIN32__)
|
#if defined(__WIN32__)
|
||||||
char buffer[1024];
|
char buffer[1024];
|
||||||
|
@ -830,19 +835,32 @@ NSTemporaryDirectory(void)
|
||||||
if ([manager fileExistsAtPath: tempDirName isDirectory: &flag] == NO
|
if ([manager fileExistsAtPath: tempDirName isDirectory: &flag] == NO
|
||||||
|| flag == NO)
|
|| flag == NO)
|
||||||
{
|
{
|
||||||
NSLog(@"Temporary directory (%@) does not seem to exist", tempDirName);
|
[NSException raise: NSGenericException
|
||||||
return nil;
|
format: @"Temporary directory (%@) does not exist",
|
||||||
|
tempDirName];
|
||||||
|
return nil; /* Not reached. */
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check that the directory owner (presumably us) has access to it,
|
* Check that we are the directory owner, and that we, and nobody else,
|
||||||
* and nobody else. If other people have access, try to create a
|
* have access to it. If other people have access, try to create a secure
|
||||||
* secure subdirectory.
|
* subdirectory.
|
||||||
*/
|
*/
|
||||||
attr = [manager fileAttributesAtPath: tempDirName traverseLink: YES];
|
attr = [manager fileAttributesAtPath: tempDirName traverseLink: YES];
|
||||||
|
owner = [[attr objectForKey: NSFileOwnerAccountID] intValue];
|
||||||
perm = [[attr objectForKey: NSFilePosixPermissions] intValue];
|
perm = [[attr objectForKey: NSFilePosixPermissions] intValue];
|
||||||
perm = perm & 0777;
|
perm = perm & 0777;
|
||||||
if (perm != 0700 && perm != 0600)
|
|
||||||
|
#if defined(__MINGW__)
|
||||||
|
uid = owner;
|
||||||
|
#else
|
||||||
|
#ifdef HAVE_GETEUID
|
||||||
|
uid = geteuid();
|
||||||
|
#else
|
||||||
|
uid = getuid();
|
||||||
|
#endif /* HAVE_GETEUID */
|
||||||
|
#endif
|
||||||
|
if ((perm != 0700 && perm != 0600) || owner != uid)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
NSLog(@"Temporary directory (%@) may be insecure ... attempting to "
|
NSLog(@"Temporary directory (%@) may be insecure ... attempting to "
|
||||||
|
@ -860,16 +878,35 @@ NSTemporaryDirectory(void)
|
||||||
if ([manager createDirectoryAtPath: tempDirName
|
if ([manager createDirectoryAtPath: tempDirName
|
||||||
attributes: attr] == NO)
|
attributes: attr] == NO)
|
||||||
{
|
{
|
||||||
tempDirName = baseTempDirName;
|
[NSException raise: NSGenericException
|
||||||
NSLog(@"Temporary directory (%@) may be insecure", tempDirName);
|
format: @"Attempt to create a secure temporary directory (%@) failed.",
|
||||||
|
tempDirName];
|
||||||
|
return nil; /* Not reached. */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Check that the new directory is really secure.
|
||||||
|
*/
|
||||||
|
attr = [manager fileAttributesAtPath: tempDirName traverseLink: YES];
|
||||||
|
owner = [[attr objectForKey: NSFileOwnerAccountID] intValue];
|
||||||
|
perm = [[attr objectForKey: NSFilePosixPermissions] intValue];
|
||||||
|
perm = perm & 0777;
|
||||||
|
if ((perm != 0700 && perm != 0600) || owner != uid)
|
||||||
|
{
|
||||||
|
[NSException raise: NSGenericException
|
||||||
|
format: @"Attempt to create a secure temporary directory (%@) failed.",
|
||||||
|
tempDirName];
|
||||||
|
return nil; /* Not reached. */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ([manager isWritableFileAtPath: tempDirName] == NO)
|
if ([manager isWritableFileAtPath: tempDirName] == NO)
|
||||||
{
|
{
|
||||||
NSLog(@"Temporary directory (%@) is not writable", tempDirName);
|
[NSException raise: NSGenericException
|
||||||
return nil;
|
format: @"Temporary directory (%@) is not writable",
|
||||||
|
tempDirName];
|
||||||
|
return nil; /* Not reached. */
|
||||||
}
|
}
|
||||||
return tempDirName;
|
return tempDirName;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue