X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=classes%2FUser.php;fp=classes%2FUser.php;h=8a3190cbf2c77faa53939518d2b5f608ebfc4dd3;hb=2617c40e048aee071b72b4b5f664fab36e6c632d;hp=041c64c38ff8080ea480c8cdf888c51aab6b3245;hpb=89f5dd4c182e470f063c760daf59b858cd92f9bf;p=quix0rs-gnu-social.git diff --git a/classes/User.php b/classes/User.php index 041c64c38f..8a3190cbf2 100644 --- a/classes/User.php +++ b/classes/User.php @@ -928,6 +928,38 @@ class User extends Memcached_DataObject } } + /** + * This is kind of a hack for using external setup code that's trying to + * build single-user sites. + * + * Will still return a username if the config singleuser/nickname is set + * even if the account doesn't exist, which normally indicates that the + * site is horribly misconfigured. + * + * At the moment, we need to let it through so that router setup can + * complete, otherwise we won't be able to create the account. + * + * This will be easier when we can more easily create the account and + * *then* switch the site to 1user mode without jumping through hoops. + * + * @return string + * @throws ServerException if no valid single user account is present + * @throws ServerException if called when not in single-user mode + */ + static function singleUserNickname() + { + try { + $user = User::singleUser(); + return $user->nickname; + } catch (Exception $e) { + if (common_config('singleuser', 'enabled') && common_config('singleuser', 'nickname')) { + common_log(LOG_WARN, "Warning: code attempting to pull single-user nickname when the account does not exist. If this is not setup time, this is probably a bug."); + return common_config('singleuser', 'nickname'); + } + throw $e; + } + } + /** * Find and shorten links in the given text using this user's URL shortening * settings.