Skip to content

Commit a60f67c

Browse files
committed
Make 'user=' optional in mmts conninfo strings.
1 parent 1a0e6ba commit a60f67c

File tree

1 file changed

+25
-12
lines changed

1 file changed

+25
-12
lines changed

contrib/mmts/multimaster.c

Lines changed: 25 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,10 @@
1313
#include "funcapi.h"
1414
#include "fmgr.h"
1515
#include "miscadmin.h"
16+
1617
#include "libpq-fe.h"
18+
#include "common/username.h"
19+
1720
#include "postmaster/postmaster.h"
1821
#include "postmaster/bgworker.h"
1922
#include "storage/lwlock.h"
@@ -1932,21 +1935,31 @@ static void MtmSplitConnStrs(void)
19321935
elog(ERROR, "Database is not specified in connection string: '%s'", connStr);
19331936

19341937
if (dbUser == NULL)
1935-
elog(ERROR, "Database user is not specified in connection string: '%s'", connStr);
1938+
{
1939+
char *errstr;
1940+
const char *username = get_user_name(&errstr);
1941+
if (!username)
1942+
elog(FATAL, "Database user is not specified in connection string '%s', fallback failed: %s", connStr, errstr);
1943+
else
1944+
elog(WARNING, "Database user is not specified in connection string '%s', fallback to '%s'", connStr, username);
1945+
MtmDatabaseUser = pstrdup(username);
1946+
}
1947+
else
1948+
{
1949+
dbUser += 5;
1950+
end = strchr(dbUser, ' ');
1951+
if (!end) end = strchr(dbUser, '\0');
1952+
Assert(end != NULL);
1953+
len = end - dbUser;
1954+
MtmDatabaseUser = pnstrdup(dbUser, len);
1955+
}
19361956

19371957
dbName += 7;
1938-
for (end = dbName; *end != ' ' && *end != '\0'; end++);
1958+
end = strchr(dbName, ' ');
1959+
if (!end) end = strchr(dbName, '\0');
1960+
Assert(end != NULL);
19391961
len = end - dbName;
1940-
MtmDatabaseName = (char*)palloc(len + 1);
1941-
memcpy(MtmDatabaseName, dbName, len);
1942-
MtmDatabaseName[len] = '\0';
1943-
1944-
dbUser += 5;
1945-
for (end = dbUser; *end != ' ' && *end != '\0'; end++);
1946-
len = end - dbUser;
1947-
MtmDatabaseUser = (char*)palloc(len + 1);
1948-
memcpy(MtmDatabaseUser, dbUser, len);
1949-
MtmDatabaseUser[len] = '\0';
1962+
MtmDatabaseName = pnstrdup(dbName, len);
19501963
}
19511964
connStr = p + 1;
19521965
}

0 commit comments

Comments
 (0)
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy