We now fetch data with an automatically generated system user
This commit is contained in:
		
					parent
					
						
							
								2475058cc4
							
						
					
				
			
			
				commit
				
					
						7dbf72e454
					
				
			
		
					 9 changed files with 244 additions and 72 deletions
				
			
		|  | @ -99,6 +99,95 @@ class User | ||||||
| 
 | 
 | ||||||
| 	private static $owner; | 	private static $owner; | ||||||
| 
 | 
 | ||||||
|  | 	/** | ||||||
|  | 	 * Fetch the system account | ||||||
|  | 	 * | ||||||
|  | 	 * @return return system account | ||||||
|  | 	 */ | ||||||
|  | 	public static function getSystemAccount() | ||||||
|  | 	{ | ||||||
|  | 		$system = Contact::selectFirst([], ['self' => true, 'uid' => 0]); | ||||||
|  | 		if (!DBA::isResult($system)) { | ||||||
|  | 			self::createSystemAccount(); | ||||||
|  | 			$system = Contact::selectFirst([], ['self' => true, 'uid' => 0]); | ||||||
|  | 			if (!DBA::isResult($system)) { | ||||||
|  | 				return []; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		$system['spubkey'] = $system['uprvkey'] = $system['prvkey']; | ||||||
|  | 		$system['username'] = $system['name']; | ||||||
|  | 		$system['nickname'] = $system['nick']; | ||||||
|  | 		return $system; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	/** | ||||||
|  | 	 * Create the system account | ||||||
|  | 	 * | ||||||
|  | 	 * @return void | ||||||
|  | 	 */ | ||||||
|  | 	private static function createSystemAccount() | ||||||
|  | 	{ | ||||||
|  | 		$system_actor_name = DI::config()->get('system', 'actor_name'); | ||||||
|  | 		if (empty($system_actor_name)) { | ||||||
|  | 			$system_actor_name = self::getActorName(); | ||||||
|  | 			if (empty($system_actor_name)) { | ||||||
|  | 				return; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		$keys = Crypto::newKeypair(4096); | ||||||
|  | 		if ($keys === false) { | ||||||
|  | 			throw new Exception(DI::l10n()->t('SERIOUS ERROR: Generation of security keys failed.')); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		$system = []; | ||||||
|  | 		$system['uid'] = 0; | ||||||
|  | 		$system['created'] = DateTimeFormat::utcNow(); | ||||||
|  | 		$system['self'] = true; | ||||||
|  | 		$system['network'] = Protocol::ACTIVITYPUB; | ||||||
|  | 		$system['name'] = 'System Account'; | ||||||
|  | 		$system['addr'] = $system_actor_name . '@' . DI::baseUrl()->getHostname(); | ||||||
|  | 		$system['nick'] = $system_actor_name; | ||||||
|  | 		$system['avatar'] = DI::baseUrl() . Contact::DEFAULT_AVATAR_PHOTO; | ||||||
|  | 		$system['photo'] = DI::baseUrl() . Contact::DEFAULT_AVATAR_PHOTO; | ||||||
|  | 		$system['thumb'] = DI::baseUrl() . Contact::DEFAULT_AVATAR_THUMB; | ||||||
|  | 		$system['micro'] = DI::baseUrl() . Contact::DEFAULT_AVATAR_MICRO; | ||||||
|  | 		$system['url'] = DI::baseUrl() . '/friendica'; | ||||||
|  | 		$system['nurl'] = Strings::normaliseLink($system['url']); | ||||||
|  | 		$system['pubkey'] = $keys['pubkey']; | ||||||
|  | 		$system['prvkey'] = $keys['prvkey']; | ||||||
|  | 		$system['blocked'] = 0; | ||||||
|  | 		$system['pending'] = 0; | ||||||
|  | 		$system['contact-type'] = Contact::TYPE_RELAY; // In AP this is translated to 'Application'
 | ||||||
|  | 		$system['name-date'] = DateTimeFormat::utcNow(); | ||||||
|  | 		$system['uri-date'] = DateTimeFormat::utcNow(); | ||||||
|  | 		$system['avatar-date'] = DateTimeFormat::utcNow(); | ||||||
|  | 		$system['closeness'] = 0; | ||||||
|  | 		$system['baseurl'] = DI::baseUrl(); | ||||||
|  | 		$system['gsid'] = GServer::getID($system['baseurl']); | ||||||
|  | 		DBA::insert('contact', $system); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	/** | ||||||
|  | 	 * Detect a usable actor name | ||||||
|  | 	 * | ||||||
|  | 	 * @return string actor account name | ||||||
|  | 	 */ | ||||||
|  | 	public static function getActorName() | ||||||
|  | 	{ | ||||||
|  | 		// List of possible actor names
 | ||||||
|  | 		$possible_accounts = ['friendica', 'actor', 'system', 'internal']; | ||||||
|  | 		foreach ($possible_accounts as $name) { | ||||||
|  | 			if (!DBA::exists('user', ['nickname' => $name, 'account_removed' => false, 'expire']) && | ||||||
|  | 				!DBA::exists('userd', ['username' => $name])) { | ||||||
|  | 				DI::config()->set('system', 'actor_name', $name); | ||||||
|  | 				return $name; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		return ''; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	/** | 	/** | ||||||
| 	 * Returns true if a user record exists with the provided id | 	 * Returns true if a user record exists with the provided id | ||||||
| 	 * | 	 * | ||||||
|  | @ -588,15 +677,24 @@ class User | ||||||
| 	public static function isNicknameBlocked($nickname) | 	public static function isNicknameBlocked($nickname) | ||||||
| 	{ | 	{ | ||||||
| 		$forbidden_nicknames = DI::config()->get('system', 'forbidden_nicknames', ''); | 		$forbidden_nicknames = DI::config()->get('system', 'forbidden_nicknames', ''); | ||||||
| 
 | 		if (!empty($forbidden_nicknames)) { | ||||||
| 		// if the config variable is empty return false
 |  | ||||||
| 		if (empty($forbidden_nicknames)) { |  | ||||||
| 			return false; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 			// check if the nickname is in the list of blocked nicknames
 | 			// check if the nickname is in the list of blocked nicknames
 | ||||||
| 			$forbidden = explode(',', $forbidden_nicknames); | 			$forbidden = explode(',', $forbidden_nicknames); | ||||||
| 			$forbidden = array_map('trim', $forbidden); | 			$forbidden = array_map('trim', $forbidden); | ||||||
|  | 		} else { | ||||||
|  | 			$forbidden = []; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		// Add the name of the internal actor to the "forbidden" list
 | ||||||
|  | 		$actor_name = DI::config()->get('system', 'actor_name'); | ||||||
|  | 		if (!empty($actor_name)) { | ||||||
|  | 			$forbidden[] = $actor_name; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if (empty($forbidden)) { | ||||||
|  | 			return false; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		if (in_array(strtolower($nickname), $forbidden)) { | 		if (in_array(strtolower($nickname), $forbidden)) { | ||||||
| 			return true; | 			return true; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | @ -29,6 +29,7 @@ use Friendica\Core\Worker; | ||||||
| use Friendica\Database\DBA; | use Friendica\Database\DBA; | ||||||
| use Friendica\DI; | use Friendica\DI; | ||||||
| use Friendica\Model\Contact; | use Friendica\Model\Contact; | ||||||
|  | use Friendica\Model\User; | ||||||
| use Friendica\Module\BaseAdmin; | use Friendica\Module\BaseAdmin; | ||||||
| use Friendica\Module\Register; | use Friendica\Module\Register; | ||||||
| use Friendica\Util\BasePath; | use Friendica\Util\BasePath; | ||||||
|  | @ -148,6 +149,7 @@ class Site extends BaseAdmin | ||||||
| 		$allowed_sites          = (!empty($_POST['allowed_sites'])           ? Strings::escapeTags(trim($_POST['allowed_sites']))  : ''); | 		$allowed_sites          = (!empty($_POST['allowed_sites'])           ? Strings::escapeTags(trim($_POST['allowed_sites']))  : ''); | ||||||
| 		$allowed_email          = (!empty($_POST['allowed_email'])           ? Strings::escapeTags(trim($_POST['allowed_email']))  : ''); | 		$allowed_email          = (!empty($_POST['allowed_email'])           ? Strings::escapeTags(trim($_POST['allowed_email']))  : ''); | ||||||
| 		$forbidden_nicknames    = (!empty($_POST['forbidden_nicknames'])     ? strtolower(Strings::escapeTags(trim($_POST['forbidden_nicknames']))) : ''); | 		$forbidden_nicknames    = (!empty($_POST['forbidden_nicknames'])     ? strtolower(Strings::escapeTags(trim($_POST['forbidden_nicknames']))) : ''); | ||||||
|  | 		$system_actor_name      = (!empty($_POST['system_actor_name'])       ? Strings::escapeTags(trim($_POST['system_actor_name'])) : ''); | ||||||
| 		$no_oembed_rich_content = !empty($_POST['no_oembed_rich_content']); | 		$no_oembed_rich_content = !empty($_POST['no_oembed_rich_content']); | ||||||
| 		$allowed_oembed         = (!empty($_POST['allowed_oembed'])          ? Strings::escapeTags(trim($_POST['allowed_oembed'])) : ''); | 		$allowed_oembed         = (!empty($_POST['allowed_oembed'])          ? Strings::escapeTags(trim($_POST['allowed_oembed'])) : ''); | ||||||
| 		$block_public           = !empty($_POST['block_public']); | 		$block_public           = !empty($_POST['block_public']); | ||||||
|  | @ -355,6 +357,7 @@ class Site extends BaseAdmin | ||||||
| 		DI::config()->set('system', 'allowed_sites'          , $allowed_sites); | 		DI::config()->set('system', 'allowed_sites'          , $allowed_sites); | ||||||
| 		DI::config()->set('system', 'allowed_email'          , $allowed_email); | 		DI::config()->set('system', 'allowed_email'          , $allowed_email); | ||||||
| 		DI::config()->set('system', 'forbidden_nicknames'    , $forbidden_nicknames); | 		DI::config()->set('system', 'forbidden_nicknames'    , $forbidden_nicknames); | ||||||
|  | 		DI::config()->set('system', 'system_actor_name'      , $system_actor_name); | ||||||
| 		DI::config()->set('system', 'no_oembed_rich_content' , $no_oembed_rich_content); | 		DI::config()->set('system', 'no_oembed_rich_content' , $no_oembed_rich_content); | ||||||
| 		DI::config()->set('system', 'allowed_oembed'         , $allowed_oembed); | 		DI::config()->set('system', 'allowed_oembed'         , $allowed_oembed); | ||||||
| 		DI::config()->set('system', 'block_public'           , $block_public); | 		DI::config()->set('system', 'block_public'           , $block_public); | ||||||
|  | @ -510,6 +513,11 @@ class Site extends BaseAdmin | ||||||
| 		get_temppath(); | 		get_temppath(); | ||||||
| 		get_itemcachepath(); | 		get_itemcachepath(); | ||||||
| 
 | 
 | ||||||
|  | 		$system_actor_name = DI::config()->get('system', 'actor_name'); | ||||||
|  | 		if (empty($system_actor_name)) { | ||||||
|  | 			$system_actor_name = User::getActorName(); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		/* Register policy */ | 		/* Register policy */ | ||||||
| 		$register_choices = [ | 		$register_choices = [ | ||||||
| 			Register::CLOSED => DI::l10n()->t('Closed'), | 			Register::CLOSED => DI::l10n()->t('Closed'), | ||||||
|  | @ -600,6 +608,7 @@ class Site extends BaseAdmin | ||||||
| 			// name, label, value, help string, extra data...
 | 			// name, label, value, help string, extra data...
 | ||||||
| 			'$sitename'         => ['sitename', DI::l10n()->t('Site name'), DI::config()->get('config', 'sitename'), ''], | 			'$sitename'         => ['sitename', DI::l10n()->t('Site name'), DI::config()->get('config', 'sitename'), ''], | ||||||
| 			'$sender_email'     => ['sender_email', DI::l10n()->t('Sender Email'), DI::config()->get('config', 'sender_email'), DI::l10n()->t('The email address your server shall use to send notification emails from.'), '', '', 'email'], | 			'$sender_email'     => ['sender_email', DI::l10n()->t('Sender Email'), DI::config()->get('config', 'sender_email'), DI::l10n()->t('The email address your server shall use to send notification emails from.'), '', '', 'email'], | ||||||
|  | 			'$system_actor_name' => ['system_actor_name', DI::l10n()->t('Name of the system actor'), $system_actor_name, DI::l10n()->t("Name of the internal system account that is used to perform ActivityPub requests. This must be an unused username. If set, this shouldn't be changed again.")], | ||||||
| 			'$banner'           => ['banner', DI::l10n()->t('Banner/Logo'), $banner, ''], | 			'$banner'           => ['banner', DI::l10n()->t('Banner/Logo'), $banner, ''], | ||||||
| 			'$email_banner'     => ['email_banner', DI::l10n()->t('Email Banner/Logo'), $email_banner, ''], | 			'$email_banner'     => ['email_banner', DI::l10n()->t('Email Banner/Logo'), $email_banner, ''], | ||||||
| 			'$shortcut_icon'    => ['shortcut_icon', DI::l10n()->t('Shortcut icon'), DI::config()->get('system', 'shortcut_icon'), DI::l10n()->t('Link to an icon that will be used for browsers.')], | 			'$shortcut_icon'    => ['shortcut_icon', DI::l10n()->t('Shortcut icon'), DI::config()->get('system', 'shortcut_icon'), DI::l10n()->t('Link to an icon that will be used for browsers.')], | ||||||
|  |  | ||||||
|  | @ -25,8 +25,10 @@ use Friendica\BaseModule; | ||||||
| use Friendica\Core\Addon; | use Friendica\Core\Addon; | ||||||
| use Friendica\Core\Hook; | use Friendica\Core\Hook; | ||||||
| use Friendica\Core\Renderer; | use Friendica\Core\Renderer; | ||||||
|  | use Friendica\Core\System; | ||||||
| use Friendica\DI; | use Friendica\DI; | ||||||
| use Friendica\Model\User; | use Friendica\Model\User; | ||||||
|  | use Friendica\Protocol\ActivityPub; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * Prints information about the current node |  * Prints information about the current node | ||||||
|  | @ -108,6 +110,15 @@ class Friendica extends BaseModule | ||||||
| 
 | 
 | ||||||
| 	public static function rawContent(array $parameters = []) | 	public static function rawContent(array $parameters = []) | ||||||
| 	{ | 	{ | ||||||
|  | 		if (ActivityPub::isRequest()) { | ||||||
|  | 			$data = ActivityPub\Transmitter::getProfile(0); | ||||||
|  | 			if (!empty($data)) { | ||||||
|  | 				header('Access-Control-Allow-Origin: *'); | ||||||
|  | 				header('Cache-Control: max-age=23200, stale-while-revalidate=23200'); | ||||||
|  | 				System::jsonExit($data, 'application/activity+json'); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		$app = DI::app(); | 		$app = DI::app(); | ||||||
| 
 | 
 | ||||||
| 		// @TODO: Replace with parameter from router
 | 		// @TODO: Replace with parameter from router
 | ||||||
|  |  | ||||||
|  | @ -24,6 +24,7 @@ namespace Friendica\Module; | ||||||
| use Friendica\BaseModule; | use Friendica\BaseModule; | ||||||
| use Friendica\Core\Hook; | use Friendica\Core\Hook; | ||||||
| use Friendica\Core\Renderer; | use Friendica\Core\Renderer; | ||||||
|  | use Friendica\Core\System; | ||||||
| use Friendica\Database\DBA; | use Friendica\Database\DBA; | ||||||
| use Friendica\DI; | use Friendica\DI; | ||||||
| use Friendica\Model\Photo; | use Friendica\Model\Photo; | ||||||
|  | @ -77,14 +78,19 @@ class Xrd extends BaseModule | ||||||
| 			$name = substr($local, 0, strpos($local, '@')); | 			$name = substr($local, 0, strpos($local, '@')); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | 		if ($name == DI::config()->get('system', 'actor_name')) { | ||||||
|  | 			$owner = User::getSystemAccount(); | ||||||
|  | 			if (empty($owner)) { | ||||||
|  | 				throw new \Friendica\Network\HTTPException\NotFoundException(); | ||||||
|  | 			} | ||||||
|  | 			self::printSystemJSON($owner); | ||||||
|  | 		} else { | ||||||
| 			$user = User::getByNickname($name); | 			$user = User::getByNickname($name); | ||||||
| 
 |  | ||||||
| 			if (empty($user)) { | 			if (empty($user)) { | ||||||
| 				throw new \Friendica\Network\HTTPException\NotFoundException(); | 				throw new \Friendica\Network\HTTPException\NotFoundException(); | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			$owner = User::getOwnerDataById($user['uid']); | 			$owner = User::getOwnerDataById($user['uid']); | ||||||
| 
 |  | ||||||
| 			if (empty($owner)) { | 			if (empty($owner)) { | ||||||
| 				DI::logger()->warning('No owner data for user id', ['uri' => $uri, 'name' => $name, 'user' => $user]); | 				DI::logger()->warning('No owner data for user id', ['uri' => $uri, 'name' => $name, 'user' => $user]); | ||||||
| 				throw new \Friendica\Network\HTTPException\NotFoundException(); | 				throw new \Friendica\Network\HTTPException\NotFoundException(); | ||||||
|  | @ -93,8 +99,9 @@ class Xrd extends BaseModule | ||||||
| 			$alias = str_replace('/profile/', '/~', $owner['url']); | 			$alias = str_replace('/profile/', '/~', $owner['url']); | ||||||
| 
 | 
 | ||||||
| 			$avatar = Photo::selectFirst(['type'], ['uid' => $owner['uid'], 'profile' => true]); | 			$avatar = Photo::selectFirst(['type'], ['uid' => $owner['uid'], 'profile' => true]); | ||||||
|  | 		} | ||||||
| 
 | 
 | ||||||
| 		if (!DBA::isResult($avatar)) { | 		if (empty($avatar)) { | ||||||
| 			$avatar = ['type' => 'image/jpeg']; | 			$avatar = ['type' => 'image/jpeg']; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | @ -105,6 +112,32 @@ class Xrd extends BaseModule | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	private static function printSystemJSON(array $owner) | ||||||
|  | 	{ | ||||||
|  | 		$json = [ | ||||||
|  | 			'subject' => 'acct:' . $owner['addr'], | ||||||
|  | 			'aliases' => [$owner['url']], | ||||||
|  | 			'links'   => [ | ||||||
|  | 				[ | ||||||
|  | 					'rel'  => 'http://webfinger.net/rel/profile-page', | ||||||
|  | 					'type' => 'text/html', | ||||||
|  | 					'href' => $owner['url'], | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					'rel'  => 'self', | ||||||
|  | 					'type' => 'application/activity+json', | ||||||
|  | 					'href' => $owner['url'], | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					'rel'      => 'http://ostatus.org/schema/1.0/subscribe', | ||||||
|  | 					'template' => DI::baseUrl()->get() . '/follow?url={uri}', | ||||||
|  | 				], | ||||||
|  | 			] | ||||||
|  | 		]; | ||||||
|  | 		header('Access-Control-Allow-Origin: *'); | ||||||
|  | 		System::jsonExit($json, 'application/jrd+json; charset=utf-8'); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	private static function printJSON($alias, $baseURL, $owner, $avatar) | 	private static function printJSON($alias, $baseURL, $owner, $avatar) | ||||||
| 	{ | 	{ | ||||||
| 		$salmon_key = Salmon::salmonKey($owner['spubkey']); | 		$salmon_key = Salmon::salmonKey($owner['spubkey']); | ||||||
|  |  | ||||||
|  | @ -90,20 +90,6 @@ class ActivityPub | ||||||
| 	 */ | 	 */ | ||||||
| 	public static function fetchContent(string $url, int $uid = 0) | 	public static function fetchContent(string $url, int $uid = 0) | ||||||
| 	{ | 	{ | ||||||
| 		if (empty($uid)) { |  | ||||||
| 			$user = User::getFirstAdmin(['uid']); |  | ||||||
| 		 |  | ||||||
| 			if (empty($user['uid'])) { |  | ||||||
| 				// When the system setup is missing an admin we just take the first user
 |  | ||||||
| 				$condition = ['verified' => true, 'blocked' => false, 'account_removed' => false, 'account_expired' => false]; |  | ||||||
| 				$user = DBA::selectFirst('user', ['uid'], $condition); |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			if (!empty($user['uid'])) { |  | ||||||
| 				$uid = $user['uid']; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		return HTTPSignature::fetch($url, $uid); | 		return HTTPSignature::fetch($url, $uid); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -214,6 +214,7 @@ class Transmitter | ||||||
| 	 */ | 	 */ | ||||||
| 	public static function getProfile($uid) | 	public static function getProfile($uid) | ||||||
| 	{ | 	{ | ||||||
|  | 		if ($uid != 0) { | ||||||
| 			$condition = ['uid' => $uid, 'blocked' => false, 'account_expired' => false, | 			$condition = ['uid' => $uid, 'blocked' => false, 'account_expired' => false, | ||||||
| 				'account_removed' => false, 'verified' => true]; | 				'account_removed' => false, 'verified' => true]; | ||||||
| 			$fields = ['guid', 'nickname', 'pubkey', 'account-type', 'page-flags']; | 			$fields = ['guid', 'nickname', 'pubkey', 'account-type', 'page-flags']; | ||||||
|  | @ -233,20 +234,43 @@ class Transmitter | ||||||
| 			if (!DBA::isResult($contact)) { | 			if (!DBA::isResult($contact)) { | ||||||
| 				return []; | 				return []; | ||||||
| 			} | 			} | ||||||
|  | 		} else { | ||||||
|  | 			$contact = User::getSystemAccount(); | ||||||
|  | 			$user = ['guid' => '', 'nickname' => $contact['nick'], 'pubkey' => $contact['pubkey'], | ||||||
|  | 				'account-type' => $contact['contact-type'], 'page-flags' => User::PAGE_FLAGS_NORMAL]; | ||||||
|  | 			$profile = ['locality' => '', 'region' => '', 'country-name' => '']; | ||||||
|  | 		} | ||||||
| 
 | 
 | ||||||
| 		$data = ['@context' => ActivityPub::CONTEXT]; | 		$data = ['@context' => ActivityPub::CONTEXT]; | ||||||
| 		$data['id'] = $contact['url']; | 		$data['id'] = $contact['url']; | ||||||
|  | 
 | ||||||
|  | 		if (!empty($user['guid'])) { | ||||||
| 			$data['diaspora:guid'] = $user['guid']; | 			$data['diaspora:guid'] = $user['guid']; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		$data['type'] = ActivityPub::ACCOUNT_TYPES[$user['account-type']]; | 		$data['type'] = ActivityPub::ACCOUNT_TYPES[$user['account-type']]; | ||||||
|  | 		 | ||||||
|  | 		if ($uid != 0) { | ||||||
| 			$data['following'] = DI::baseUrl() . '/following/' . $user['nickname']; | 			$data['following'] = DI::baseUrl() . '/following/' . $user['nickname']; | ||||||
| 			$data['followers'] = DI::baseUrl() . '/followers/' . $user['nickname']; | 			$data['followers'] = DI::baseUrl() . '/followers/' . $user['nickname']; | ||||||
| 			$data['inbox'] = DI::baseUrl() . '/inbox/' . $user['nickname']; | 			$data['inbox'] = DI::baseUrl() . '/inbox/' . $user['nickname']; | ||||||
| 			$data['outbox'] = DI::baseUrl() . '/outbox/' . $user['nickname']; | 			$data['outbox'] = DI::baseUrl() . '/outbox/' . $user['nickname']; | ||||||
|  | 		} else { | ||||||
|  | 			$data['inbox'] = DI::baseUrl() . '/friendica/inbox'; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		$data['preferredUsername'] = $user['nickname']; | 		$data['preferredUsername'] = $user['nickname']; | ||||||
| 		$data['name'] = $contact['name']; | 		$data['name'] = $contact['name']; | ||||||
|  | 
 | ||||||
|  | 		if (!empty($profile['country-name'] . $profile['region'] . $profile['locality'])) { | ||||||
| 			$data['vcard:hasAddress'] = ['@type' => 'vcard:Home', 'vcard:country-name' => $profile['country-name'], | 			$data['vcard:hasAddress'] = ['@type' => 'vcard:Home', 'vcard:country-name' => $profile['country-name'], | ||||||
| 				'vcard:region' => $profile['region'], 'vcard:locality' => $profile['locality']]; | 				'vcard:region' => $profile['region'], 'vcard:locality' => $profile['locality']]; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if (!empty($contact['about'])) { | ||||||
| 			$data['summary'] = BBCode::convert($contact['about'], false); | 			$data['summary'] = BBCode::convert($contact['about'], false); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		$data['url'] = $contact['url']; | 		$data['url'] = $contact['url']; | ||||||
| 		$data['manuallyApprovesFollowers'] = in_array($user['page-flags'], [User::PAGE_FLAGS_NORMAL, User::PAGE_FLAGS_PRVGROUP]); | 		$data['manuallyApprovesFollowers'] = in_array($user['page-flags'], [User::PAGE_FLAGS_NORMAL, User::PAGE_FLAGS_PRVGROUP]); | ||||||
| 		$data['publicKey'] = ['id' => $contact['url'] . '#main-key', | 		$data['publicKey'] = ['id' => $contact['url'] . '#main-key', | ||||||
|  | @ -652,6 +676,10 @@ class Transmitter | ||||||
| 			$item_profile = APContact::getByURL($item['owner-link'], false); | 			$item_profile = APContact::getByURL($item['owner-link'], false); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | 		if (empty($item_profile)) { | ||||||
|  | 			return []; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		$profile_uid = User::getIdForURL($item_profile['url']); | 		$profile_uid = User::getIdForURL($item_profile['url']); | ||||||
| 
 | 
 | ||||||
| 		foreach (['to', 'cc', 'bto', 'bcc'] as $element) { | 		foreach (['to', 'cc', 'bto', 'bcc'] as $element) { | ||||||
|  |  | ||||||
|  | @ -420,6 +420,12 @@ class HTTPSignature | ||||||
| 			if (!$owner) { | 			if (!$owner) { | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
|  | 		} else { | ||||||
|  | 			$owner = User::getSystemAccount(); | ||||||
|  | 			if (!$owner) { | ||||||
|  | 				return; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
| 
 | 
 | ||||||
| 		if (!empty($owner['uprvkey'])) { | 		if (!empty($owner['uprvkey'])) { | ||||||
| 			// Header data that is about to be signed.
 | 			// Header data that is about to be signed.
 | ||||||
|  | @ -435,7 +441,6 @@ class HTTPSignature | ||||||
| 
 | 
 | ||||||
| 			$headers[] = 'Signature: keyId="' . $owner['url'] . '#main-key' . '",algorithm="rsa-sha256",headers="(request-target) date host",signature="' . $signature . '"'; | 			$headers[] = 'Signature: keyId="' . $owner['url'] . '#main-key' . '",algorithm="rsa-sha256",headers="(request-target) date host",signature="' . $signature . '"'; | ||||||
| 		} | 		} | ||||||
| 		} |  | ||||||
| 
 | 
 | ||||||
| 		if (!empty($opts['accept_content'])) { | 		if (!empty($opts['accept_content'])) { | ||||||
| 			$headers[] = 'Accept: ' . $opts['accept_content']; | 			$headers[] = 'Accept: ' . $opts['accept_content']; | ||||||
|  |  | ||||||
|  | @ -14,6 +14,7 @@ | ||||||
| 
 | 
 | ||||||
| 		{{include file="field_input.tpl" field=$sitename}} | 		{{include file="field_input.tpl" field=$sitename}} | ||||||
| 		{{include file="field_input.tpl" field=$sender_email}} | 		{{include file="field_input.tpl" field=$sender_email}} | ||||||
|  | 		{{include file="field_input.tpl" field=$system_actor_name}} | ||||||
| 		{{include file="field_textarea.tpl" field=$banner}} | 		{{include file="field_textarea.tpl" field=$banner}} | ||||||
| 		{{include file="field_input.tpl" field=$email_banner}} | 		{{include file="field_input.tpl" field=$email_banner}} | ||||||
| 		{{include file="field_input.tpl" field=$shortcut_icon}} | 		{{include file="field_input.tpl" field=$shortcut_icon}} | ||||||
|  |  | ||||||
|  | @ -41,6 +41,7 @@ | ||||||
| 					<div class="panel-body"> | 					<div class="panel-body"> | ||||||
| 						{{include file="field_input.tpl" field=$sitename}} | 						{{include file="field_input.tpl" field=$sitename}} | ||||||
| 						{{include file="field_input.tpl" field=$sender_email}} | 						{{include file="field_input.tpl" field=$sender_email}} | ||||||
|  | 						{{include file="field_input.tpl" field=$system_actor_name}} | ||||||
| 						{{include file="field_textarea.tpl" field=$banner}} | 						{{include file="field_textarea.tpl" field=$banner}} | ||||||
| 						{{include file="field_input.tpl" field=$shortcut_icon}} | 						{{include file="field_input.tpl" field=$shortcut_icon}} | ||||||
| 						{{include file="field_input.tpl" field=$touch_icon}} | 						{{include file="field_input.tpl" field=$touch_icon}} | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue