mirror of
				https://github.com/mordentral/AdvancedSessionsPlugin.git
				synced 2025-10-25 09:24:18 +00:00 
			
		
		
		
	Compare commits
	
		
			7 Commits
		
	
	
		
			5.7-Previe
			...
			5.4-Locked
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ff03d723f5 | ||
|   | db1c29067d | ||
|   | 46a921a55d | ||
|   | d012a8c737 | ||
|   | b3b1add401 | ||
|   | 894db2ab95 | ||
|   | e8f3ffd1be | 
| @@ -44,6 +44,11 @@ public: | ||||
| 	UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = AdvancedVoiceInterface) | ||||
| 	bool bEnableTalkingStatusDelegate; | ||||
|  | ||||
| 	// If true we will auto travel to a game session when an invite is received. | ||||
| 	// This can get in the way of Beacon Sessions, you may want to disable it. | ||||
| 	UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = AdvancedFriendsInterface) | ||||
| 	bool bAutoTravelOnAcceptedUserInviteReceived = true; | ||||
|  | ||||
| 	//virtual void PostLoad() override; | ||||
| 	virtual void Shutdown() override; | ||||
| 	virtual void Init() override; | ||||
|   | ||||
| @@ -160,6 +160,10 @@ public: | ||||
| 		UFUNCTION(BlueprintPure, Category = "Online|AdvancedSessions|PlayerInfo|PlayerID") | ||||
| 		static void GetUniqueNetID(APlayerController *PlayerController, FBPUniqueNetId &UniqueNetId); | ||||
|  | ||||
| 		// Get the unique net id of a network player attached to the given controller | ||||
| 		UFUNCTION(BlueprintPure, Category = "Online|AdvancedSessions|PlayerInfo|PlayerID") | ||||
| 		static void GetUniqueNetIdOfSessionOwner(FBlueprintSessionResult SessionResult, FBPUniqueNetId& UniqueNetId); | ||||
|  | ||||
| 		// Get the unique net id of a network player who is assigned the the given player state | ||||
| 		UFUNCTION(BlueprintPure, Category = "Online|AdvancedSessions|PlayerInfo|PlayerID") | ||||
| 		static void GetUniqueNetIDFromPlayerState(APlayerState *PlayerState, FBPUniqueNetId &UniqueNetId); | ||||
|   | ||||
| @@ -21,7 +21,7 @@ class UUpdateSessionCallbackProxyAdvanced : public UOnlineBlueprintCallProxyBase | ||||
|  | ||||
| 	// Creates a session with the default online subsystem with advanced optional inputs, you MUST fill in all categories or it will pass in values that you didn't want as default values | ||||
| 	UFUNCTION(BlueprintCallable, meta=(BlueprintInternalUseOnly = "true", WorldContext="WorldContextObject",AutoCreateRefTerm="ExtraSettings"), Category = "Online|AdvancedSessions") | ||||
| 	static UUpdateSessionCallbackProxyAdvanced* UpdateSession(UObject* WorldContextObject, const TArray<FSessionPropertyKeyPair> &ExtraSettings, int32 PublicConnections = 100, int32 PrivateConnections = 0, bool bUseLAN = false, bool bAllowInvites = false, bool bAllowJoinInProgress = false, bool bRefreshOnlineData = true, bool bIsDedicatedServer = false, bool bShouldAdvertise = true); | ||||
| 	static UUpdateSessionCallbackProxyAdvanced* UpdateSession(UObject* WorldContextObject, const TArray<FSessionPropertyKeyPair> &ExtraSettings, int32 PublicConnections = 100, int32 PrivateConnections = 0, bool bUseLAN = false, bool bAllowInvites = false, bool bAllowJoinInProgress = false, bool bRefreshOnlineData = true, bool bIsDedicatedServer = false, bool bShouldAdvertise = true, bool bAllowJoinViaPresence = true, bool bAllowJoinViaPresenceFriendsOnly = false); | ||||
|  | ||||
| 	// UOnlineBlueprintCallProxyBase interface | ||||
| 	virtual void Activate() override; | ||||
| @@ -58,6 +58,12 @@ private: | ||||
| 	// Allow joining in progress | ||||
| 	bool bAllowJoinInProgress = true; | ||||
|  | ||||
| 	// Allow joining in progress | ||||
| 	bool bAllowJoinViaPresence = true; | ||||
|  | ||||
| 	// Allow joining in progress | ||||
| 	bool bAllowJoinViaPresenceFriendsOnly = false; | ||||
|  | ||||
| 	// Update whether this is a dedicated server or not | ||||
| 	bool bDedicatedServer = false; | ||||
|  | ||||
|   | ||||
| @@ -36,6 +36,13 @@ void UAdvancedFriendsGameInstance::OnSessionUserInviteAccepted(const bool bWasSu | ||||
|  | ||||
| void UAdvancedFriendsGameInstance::OnJoinSessionComplete(FName SessionName, EOnJoinSessionCompleteResult::Type Result) | ||||
| { | ||||
|  | ||||
| 	// If we don't want to auto travel to the session instance then exit out | ||||
| 	if (!bAutoTravelOnAcceptedUserInviteReceived) | ||||
| 	{ | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	IOnlineSessionPtr SessionInterface = Online::GetSessionInterface(GetWorld()); | ||||
| 	if (SessionInterface.IsValid()) | ||||
| 	{ | ||||
|   | ||||
| @@ -451,6 +451,17 @@ void UAdvancedSessionsLibrary::GetUniqueNetID(APlayerController *PlayerControlle | ||||
| 	} | ||||
| } | ||||
|  | ||||
| void UAdvancedSessionsLibrary::GetUniqueNetIdOfSessionOwner(FBlueprintSessionResult SessionResult, FBPUniqueNetId& UniqueNetId) | ||||
| { | ||||
| 	FBPUniqueNetId ReturnID; | ||||
| 	if (SessionResult.OnlineResult.IsValid()) | ||||
| 	{ | ||||
| 		ReturnID.SetUniqueNetId(SessionResult.OnlineResult.Session.OwningUserId); | ||||
| 	} | ||||
|  | ||||
| 	UniqueNetId = ReturnID; | ||||
| } | ||||
|  | ||||
| void UAdvancedSessionsLibrary::GetUniqueNetIDFromPlayerState(APlayerState *PlayerState, FBPUniqueNetId &UniqueNetId) | ||||
| { | ||||
| 	if (!PlayerState) | ||||
|   | ||||
| @@ -83,6 +83,8 @@ void UAutoLoginUserCallbackProxy::OnCompleted(int32 LocalUserNum, bool bWasSucce | ||||
| 		{ | ||||
| 			OnFailure.Broadcast(); | ||||
| 		} | ||||
|  | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	OnFailure.Broadcast(); | ||||
|   | ||||
| @@ -12,7 +12,7 @@ UUpdateSessionCallbackProxyAdvanced::UUpdateSessionCallbackProxyAdvanced(const F | ||||
| { | ||||
| }	 | ||||
|  | ||||
| UUpdateSessionCallbackProxyAdvanced* UUpdateSessionCallbackProxyAdvanced::UpdateSession(UObject* WorldContextObject, const TArray<FSessionPropertyKeyPair> &ExtraSettings, int32 PublicConnections, int32 PrivateConnections, bool bUseLAN, bool bAllowInvites, bool bAllowJoinInProgress, bool bRefreshOnlineData, bool bIsDedicatedServer, bool bShouldAdvertise) | ||||
| UUpdateSessionCallbackProxyAdvanced* UUpdateSessionCallbackProxyAdvanced::UpdateSession(UObject* WorldContextObject, const TArray<FSessionPropertyKeyPair> &ExtraSettings, int32 PublicConnections, int32 PrivateConnections, bool bUseLAN, bool bAllowInvites, bool bAllowJoinInProgress, bool bRefreshOnlineData, bool bIsDedicatedServer, bool bShouldAdvertise, bool bAllowJoinViaPresence, bool bAllowJoinViaPresenceFriendsOnly) | ||||
| { | ||||
| 	UUpdateSessionCallbackProxyAdvanced* Proxy = NewObject<UUpdateSessionCallbackProxyAdvanced>(); | ||||
| 	Proxy->NumPublicConnections = PublicConnections; | ||||
| @@ -25,6 +25,8 @@ UUpdateSessionCallbackProxyAdvanced* UUpdateSessionCallbackProxyAdvanced::Update | ||||
| 	Proxy->bAllowJoinInProgress = bAllowJoinInProgress; | ||||
| 	Proxy->bDedicatedServer = bIsDedicatedServer; | ||||
| 	Proxy->bShouldAdvertise = bShouldAdvertise; | ||||
| 	Proxy->bAllowJoinViaPresence = bAllowJoinViaPresence; | ||||
| 	Proxy->bAllowJoinViaPresenceFriendsOnly = bAllowJoinViaPresenceFriendsOnly; | ||||
| 	return Proxy;	 | ||||
| } | ||||
|  | ||||
| @@ -65,11 +67,14 @@ void UUpdateSessionCallbackProxyAdvanced::Activate() | ||||
| 			Settings->bAllowJoinInProgress = bAllowJoinInProgress; | ||||
| 			Settings->bIsLANMatch = bUseLAN; | ||||
| 			//Settings->bUsesPresence = true; | ||||
| 			//Settings->bAllowJoinViaPresence = true; | ||||
| 			Settings->bAllowInvites = bAllowInvites; | ||||
| 			Settings->bAllowJoinInProgress = bAllowJoinInProgress; | ||||
| 			Settings->bIsDedicated = bDedicatedServer; | ||||
|  | ||||
| 			// Added in 5.6 | ||||
| 			Settings->bAllowJoinViaPresence = bAllowJoinViaPresence; | ||||
| 			Settings->bAllowJoinViaPresenceFriendsOnly = bAllowJoinViaPresenceFriendsOnly; | ||||
|  | ||||
| 			FOnlineSessionSetting * fSetting = NULL; | ||||
| 			FOnlineSessionSetting ExtraSetting; | ||||
| 			for (int i = 0; i < ExtraSettings.Num(); i++) | ||||
|   | ||||
| @@ -337,8 +337,8 @@ public: | ||||
| 	static bool RequestSteamFriendInfo(const FBPUniqueNetId UniqueNetId, bool bRequireNameOnly = false); | ||||
|  | ||||
| 	// Opens the steam overlay to go to the specified user dialog | ||||
| 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedFriends|SteamAPI") | ||||
| 		static bool OpenSteamUserOverlay(const FBPUniqueNetId UniqueNetId, ESteamUserOverlayType DialogType); | ||||
| 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedFriends|SteamAPI", meta = (WorldContext = "WorldContextObject")) | ||||
| 		static bool OpenSteamUserOverlay(UObject* WorldContextObject, const FBPUniqueNetId UniqueNetId, ESteamUserOverlayType DialogType); | ||||
| 	 | ||||
| 	// Returns if the steam overlay is currently active (this can return false during initial overlay hooking) | ||||
| 	UFUNCTION(BlueprintPure, Category = "Online|AdvancedFriends|SteamAPI") | ||||
|   | ||||
| @@ -38,14 +38,27 @@ public: | ||||
| 		void Initialize(USteamNotificationsSubsystem* MyParent) | ||||
| 		{ | ||||
| 			ParentSubsystem = MyParent; | ||||
|  | ||||
| #if (PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX) && STEAM_SDK_INSTALLED | ||||
| 			OnExternalUITriggeredCallback.Register(this, &USteamNotificationsSubsystem::cSteamEventsStore::OnExternalUITriggered); | ||||
| #endif | ||||
| 		} | ||||
|  | ||||
| 		void UnInitialize(USteamNotificationsSubsystem* MyParent) | ||||
| 		{ | ||||
| #if (PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX) && STEAM_SDK_INSTALLED | ||||
| 			OnExternalUITriggeredCallback.Unregister(); | ||||
| #endif | ||||
| 		} | ||||
|  | ||||
| #if (PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX) && STEAM_SDK_INSTALLED | ||||
| 		cSteamEventsStore() : | ||||
| 		OnExternalUITriggeredCallback(this, &cSteamEventsStore::OnExternalUITriggered) | ||||
| 		cSteamEventsStore() | ||||
| 		{} | ||||
| 			//: | ||||
| 		/*OnExternalUITriggeredCallback(this, &cSteamEventsStore::OnExternalUITriggered) | ||||
| 		{ | ||||
|  | ||||
| 		} | ||||
| 		}*/ | ||||
| #else | ||||
| 		//cSteamEventsStore() | ||||
| 		//{ | ||||
| @@ -57,7 +70,8 @@ public: | ||||
|  | ||||
| 	private: | ||||
| #if (PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX) && STEAM_SDK_INSTALLED | ||||
| 		STEAM_CALLBACK(cSteamEventsStore, OnExternalUITriggered, GameOverlayActivated_t, OnExternalUITriggeredCallback); | ||||
| 		//STEAM_CALLBACK(cSteamEventsStore, OnExternalUITriggered, GameOverlayActivated_t, OnExternalUITriggeredCallback); | ||||
| 		STEAM_CALLBACK_MANUAL(cSteamEventsStore, OnExternalUITriggered, GameOverlayActivated_t, OnExternalUITriggeredCallback); | ||||
| #endif | ||||
| 	}; | ||||
|  | ||||
| @@ -72,7 +86,7 @@ public: | ||||
| 	/** Implement this for deinitialization of instances of the system */ | ||||
| 	virtual void Deinitialize() override | ||||
| 	{ | ||||
|  | ||||
| 		MyEvents.UnInitialize(this); | ||||
| 	} | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,11 @@ | ||||
| // Fill out your copyright notice in the Description page of Project Settings. | ||||
| #include "AdvancedSteamFriendsLibrary.h" | ||||
| #include "OnlineSubSystemHeader.h" | ||||
| #include "OnlineSubsystemTypes.h" | ||||
| #include "Engine/Texture.h" | ||||
| #include "Engine/Texture2D.h" | ||||
| #include "TextureResource.h" | ||||
| #include "PixelFormat.h" | ||||
|  | ||||
| //General Log | ||||
| DEFINE_LOG_CATEGORY(AdvancedSteamFriendsLog); | ||||
| @@ -233,7 +238,7 @@ bool UAdvancedSteamFriendsLibrary::RequestSteamFriendInfo(const FBPUniqueNetId U | ||||
| } | ||||
|  | ||||
|  | ||||
| bool UAdvancedSteamFriendsLibrary::OpenSteamUserOverlay(const FBPUniqueNetId UniqueNetId, ESteamUserOverlayType DialogType) | ||||
| bool UAdvancedSteamFriendsLibrary::OpenSteamUserOverlay(UObject* WorldContextObject,const FBPUniqueNetId UniqueNetId, ESteamUserOverlayType DialogType) | ||||
| { | ||||
| #if (PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX) && STEAM_SDK_INSTALLED | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid() || UniqueNetId.UniqueNetId->GetType() != STEAM_SUBSYSTEM) | ||||
| @@ -244,13 +249,24 @@ bool UAdvancedSteamFriendsLibrary::OpenSteamUserOverlay(const FBPUniqueNetId Uni | ||||
|  | ||||
| 	if (SteamAPI_Init()) | ||||
| 	{ | ||||
| 		uint64 id = *((uint64*)UniqueNetId.UniqueNetId->GetBytes()); | ||||
| 		if (DialogType == ESteamUserOverlayType::invitetolobby) | ||||
| 		{ | ||||
| 			UWorld* const World = GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull); | ||||
| 			IOnlineSessionPtr SessionInterface = Online::GetSessionInterface(World); | ||||
| 			if (SessionInterface.IsValid()) | ||||
| 			{ | ||||
| 				FNamedOnlineSession* CurrentSession = SessionInterface->GetNamedSession(NAME_GameSession); | ||||
|  | ||||
| 				if (CurrentSession && CurrentSession->SessionInfo->GetSessionId().IsValid()) | ||||
| 				{			 | ||||
| 					uint64 id = *((uint64*)CurrentSession->SessionInfo->GetSessionId().GetBytes()); | ||||
| 					SteamFriends()->ActivateGameOverlayInviteDialog(id); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			uint64 id = *((uint64*)UniqueNetId.UniqueNetId->GetBytes()); | ||||
| 			FString DialogName = EnumToString("ESteamUserOverlayType", (uint8)DialogType); | ||||
| 			SteamFriends()->ActivateGameOverlayToUser(TCHAR_TO_ANSI(*DialogName), id); | ||||
| 		} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user