mirror of
https://github.com/inverse-inc/sogo.git
synced 2026-04-24 06:19:30 +00:00
fix(core): adjustments for IPv6
This commit is contained in:
@@ -351,7 +351,7 @@ The following table describes the general parameters that can be set:
|
||||
|S |WOWorkersCount
|
||||
|The amount of instances of SOGo that will be spawned
|
||||
to handle multiple requests simultaneously. When started from the init
|
||||
script, that amount is overriden by the `PREFORK` value
|
||||
script, that amount is overridden by the `PREFORK` value
|
||||
in `/etc/sysconfig/sogo` or `/etc/default/sogo`. A value of 3 is a
|
||||
reasonable default for low usage. The maximum value depends on the CPU
|
||||
and IO power provided by your machine: a value set too high will
|
||||
@@ -369,7 +369,8 @@ Defaults to 5 when unset.
|
||||
|
||||
|S |WOPort
|
||||
|The TCP listening address and port used by the SOGo
|
||||
daemon. The format is `ipaddress:port`.
|
||||
daemon. The format is `ipaddress:port`. To bind to an IPv6 address, use
|
||||
`[ipv6address]:port`, e.g. `[::1]:20000`.
|
||||
|
||||
Defaults to `127.0.0.1:20000` when unset.
|
||||
|
||||
@@ -937,7 +938,7 @@ even when using multiple domains.
|
||||
|The field that returns the complete name.
|
||||
|
||||
|IDFieldName
|
||||
|The field that starts a user DN if bindFields is not used. This field
|
||||
|The field that starts a user DN if bindFields is not used. This field
|
||||
must be unique across the entire SOGo domain.
|
||||
|
||||
|UIDFieldName
|
||||
@@ -1136,14 +1137,14 @@ ModulesConstraints = {
|
||||
attributes used by the schema of the LDAP source. Each entry must have
|
||||
an attribute name as key and an array of strings as value. This enables
|
||||
actual fields to be mapped one after another when fetching contact
|
||||
informations.
|
||||
information.
|
||||
|
||||
See the LDAP Attribute Mapping section below for an example and a list
|
||||
of supported attributes.
|
||||
|
||||
|objectClasses
|
||||
|When the _modifiers_ list (see below) is set, or when using LDAP-based
|
||||
user addressbooks (see _abOU_ below), this list of object classes will
|
||||
user address books (see _abOU_ below), this list of object classes will
|
||||
be applied to new records as they are created.
|
||||
|
||||
|GroupObjectClasses
|
||||
@@ -1156,7 +1157,7 @@ and `posixgroup`.
|
||||
modifications to the address book defined by this LDAP source.
|
||||
|
||||
|abOU
|
||||
|This field enables LDAP-based user addressbooks by specifying the value
|
||||
|This field enables LDAP-based user address books by specifying the value
|
||||
of the address book container beneath each user entry, for example:
|
||||
`ou=addressbooks,uid=username,dc=domain`.
|
||||
|=======================================================================
|
||||
|
||||
@@ -28,6 +28,7 @@
|
||||
#import <NGExtensions/NSURL+misc.h>
|
||||
#import <NGImap4/NGImap4Connection.h>
|
||||
#import <NGImap4/NGImap4Client.h>
|
||||
#import <NGStreams/NGInternetSocketAddress.h>
|
||||
|
||||
#import <SOGo/SOGoCache.h>
|
||||
#import <SOGo/SOGoSystemDefaults.h>
|
||||
@@ -138,7 +139,7 @@
|
||||
NGImap4ConnectionManager *manager;
|
||||
NGImap4Connection *newConnection;
|
||||
NSString *password;
|
||||
NSHost *host;
|
||||
NGInternetSocketAddress *host;
|
||||
SOGoSystemDefaults *sd;
|
||||
BOOL usesSSO;
|
||||
|
||||
@@ -147,14 +148,14 @@
|
||||
// We first check if we're trying to establish an IMAP connection to localhost
|
||||
// for an account number greater than 0 (default account). We prevent that
|
||||
// for security reasons if admins use an IMAP trust.
|
||||
host = [NSHost hostWithName: [[self imap4URL] host]];
|
||||
host = [NGInternetSocketAddress addressWithPort:0 onHost:[[self imap4URL] host]];
|
||||
|
||||
sd = [SOGoSystemDefaults sharedSystemDefaults];
|
||||
usesSSO = [[sd authenticationType] isEqualToString: @"cas"] || [[sd authenticationType] isEqualToString: @"saml2"];
|
||||
|
||||
if (![[[self mailAccountFolder] nameInContainer] isEqualToString: @"0"] &&
|
||||
usesSSO &&
|
||||
[[host address] isEqualToString: @"127.0.0.1"])
|
||||
[host isLocalhost])
|
||||
{
|
||||
[self errorWithFormat: @"Trying to use localhost for additional IMAP account - aborting."];
|
||||
return nil;
|
||||
|
||||
@@ -26,6 +26,7 @@ $(TEST_TOOL)_OBJC_FILES += \
|
||||
TestNGMimeMessageGenerator.m \
|
||||
TestNGMimeType.m \
|
||||
\
|
||||
TestNGNetUtlilities.m \
|
||||
TestNSData+Crypto.m \
|
||||
TestNSString+Crypto.m \
|
||||
TestNSString+URLEscaping.m \
|
||||
|
||||
@@ -31,8 +31,7 @@
|
||||
|
||||
- (void) test_isLocalhost
|
||||
{
|
||||
// @"localhost6",
|
||||
NSString *addrStr[] = { @"127.0.0.1", @"127.1.2.3", @"localhost", @"something.localhost", @"localhost.", nil };
|
||||
NSString *addrStr[] = { @"127.0.0.1", @"127.1.2.3", @"localhost", @"something.localhost", @"localhost.", @"::1", nil };
|
||||
NSString **curHost;
|
||||
BOOL is_localhost;
|
||||
NSString *error;
|
||||
|
||||
90
Tests/Unit/TestNGNetUtlilities.m
Normal file
90
Tests/Unit/TestNGNetUtlilities.m
Normal file
@@ -0,0 +1,90 @@
|
||||
/* TestNGNetUtilities.m - this file is part of SOGo
|
||||
*
|
||||
* Copyright (C) 2022 Nicolas Höft
|
||||
* Copyright (C) Inverse Inc.
|
||||
*
|
||||
* Author: Nicolas Höft <nicolas@hoeft.de>
|
||||
*
|
||||
* This file is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2, or (at your option)
|
||||
* any later version.
|
||||
*
|
||||
* This file is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; see the file COPYING. If not, write to
|
||||
* the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
* Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
#import <NGStreams/NGNetUtilities.h>
|
||||
#import <NGStreams/NGInternetSocketAddress.h>
|
||||
|
||||
#import "SOGoTest.h"
|
||||
|
||||
@interface TestNGNetUtilities : SOGoTest
|
||||
@end
|
||||
|
||||
@implementation TestNGNetUtilities
|
||||
|
||||
- (void) test_NGInternetSocketAddressFromString
|
||||
{
|
||||
NSArray *cases = [NSArray arrayWithObjects:
|
||||
// input, host, port, isWildcard, isIpV4
|
||||
[NSArray arrayWithObjects: @"127.0.0.1:1000", @"127.0.0.1", [NSNumber numberWithInt: 1000], [NSNumber numberWithBool:NO], [NSNumber numberWithBool:YES], nil],
|
||||
[NSArray arrayWithObjects: @"*:1001", @"*", [NSNumber numberWithInt:1001], [NSNumber numberWithBool:YES], [NSNumber numberWithBool:YES], nil],
|
||||
[NSArray arrayWithObjects: @"0.0.0.0:1001", @"0.0.0.0", [NSNumber numberWithInt:1001], [NSNumber numberWithBool:YES], [NSNumber numberWithBool:YES], nil],
|
||||
[NSArray arrayWithObjects: @"localhost:1001", @"localhost", [NSNumber numberWithInt:1001], [NSNumber numberWithBool:NO], [NSNumber numberWithBool:YES], nil],
|
||||
[NSArray arrayWithObjects: @"localhost:echo", @"localhost", [NSNumber numberWithInt:7], [NSNumber numberWithBool:NO], [NSNumber numberWithBool:YES], nil],
|
||||
[NSArray arrayWithObjects: @"[2001:0db8:85a3:0000:0000:8a2e:0370:7334]:1234", @"2001:0db8:85a3:0000:0000:8a2e:0370:7334", [NSNumber numberWithInt:1234], [NSNumber numberWithBool:NO], [NSNumber numberWithBool:NO], nil],
|
||||
[NSArray arrayWithObjects: @"[::1]:echo", @"::1", [NSNumber numberWithInt:7], [NSNumber numberWithBool:NO], [NSNumber numberWithBool:NO], nil],
|
||||
[NSArray arrayWithObjects: @"[::]:echo", @"::", [NSNumber numberWithInt:7], [NSNumber numberWithBool:YES], [NSNumber numberWithBool:NO], nil],
|
||||
nil
|
||||
];
|
||||
int i;
|
||||
for (i = 0; i < [cases count]; i++)
|
||||
{
|
||||
NSString *error;
|
||||
|
||||
NSArray *currentCase = [cases objectAtIndex: i];
|
||||
NSString *input = [currentCase objectAtIndex: 0];
|
||||
NSString *expectedHost = [currentCase objectAtIndex: 1];
|
||||
int expectedPort = [[currentCase objectAtIndex: 2] intValue];
|
||||
bool expectedIsWildcard = [[currentCase objectAtIndex: 3] boolValue];
|
||||
bool expectedIsIpV4 = [[currentCase objectAtIndex: 4] boolValue];
|
||||
NGInternetSocketAddress *addr = (NGInternetSocketAddress *)NGSocketAddressFromString(input);
|
||||
NSString *host = [addr hostName];
|
||||
if (host == nil)
|
||||
host = @"*";
|
||||
|
||||
error = [NSString stringWithFormat:
|
||||
@"Hostname mismatch. Expected: '%@', result: '%@'. Test url: '%@'",
|
||||
expectedHost, host, input];
|
||||
testWithMessage([host isEqualToString: expectedHost], error);
|
||||
|
||||
int port = [addr port];
|
||||
error = [NSString stringWithFormat:
|
||||
@"Port mismatch. Expected: '%d', result: '%d'. Test url: '%@'",
|
||||
expectedPort, port, input];
|
||||
testWithMessage(port == expectedPort, error);
|
||||
|
||||
BOOL isWildcard = [addr isWildcardAddress];
|
||||
error = [NSString stringWithFormat:
|
||||
@"isWildcard mismatch. Expected: '%d', result: '%d'. Test url: '%@'",
|
||||
expectedIsWildcard, isWildcard, input];
|
||||
testWithMessage(isWildcard == expectedIsWildcard, error);
|
||||
|
||||
|
||||
BOOL isIPv4 = [addr isIPv4];
|
||||
error = [NSString stringWithFormat:
|
||||
@"isIpv4 mismatch. Expected: '%d', result: '%d'. Test url: '%@'",
|
||||
expectedIsIpV4, isIPv4, input];
|
||||
testWithMessage(isIPv4 == expectedIsIpV4, error);
|
||||
}
|
||||
}
|
||||
|
||||
@end
|
||||
@@ -59,6 +59,30 @@
|
||||
test([[queryComp valueForKey: @"key1"] isEqualToString: @"value123"]);
|
||||
test([[queryComp valueForKey: @"key2"] isEqualToString: @"val2"]);
|
||||
|
||||
urlStr = @"http://domain/path";
|
||||
url = [NSURL URLWithString: urlStr];
|
||||
queryComp = [url queryComponents];
|
||||
error = [NSString stringWithFormat:
|
||||
@"expected '%@' to have no entries, got %d", urlStr, [queryComp count]];
|
||||
testWithMessage([queryComp count] == 0, error);
|
||||
|
||||
}
|
||||
|
||||
- (void) test_IpV6Address
|
||||
{
|
||||
NSURL *url;
|
||||
NSString *error;
|
||||
NSString *host = @"2001:0db8:85a3:0000:0000:8a2e:0370:7334";
|
||||
NSString *urlhost;
|
||||
url = [NSURL URLWithString: @"mysql://user:pass@[2001:0db8:85a3:0000:0000:8a2e:0370:7334]:1234/path"];
|
||||
testWithMessage([[url scheme] isEqualToString: @"mysql"], @"unexpected scheme");
|
||||
urlhost = [url host];
|
||||
error = [NSString
|
||||
stringWithFormat: @"hostname is '%@' instead of '%@' ",
|
||||
host, urlhost];
|
||||
testWithMessage([urlhost isEqualToString: host], error);
|
||||
testWithMessage([[url port] intValue] == 1234, @"port does not match");
|
||||
}
|
||||
|
||||
|
||||
@end
|
||||
|
||||
Reference in New Issue
Block a user