mirror of
				https://github.com/mordentral/AdvancedSessionsPlugin.git
				synced 2025-10-26 18:04:07 +00:00 
			
		
		
		
	Compare commits
	
		
			22 Commits
		
	
	
		
			4.16_Locke
			...
			4.19_Locke
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 105df50764 | ||
|   | 6d404d22ce | ||
|   | f47699e940 | ||
|   | 924b1ecf1c | ||
|   | c73b96993c | ||
|   | 0229b69d9c | ||
|   | ad2881cd75 | ||
|   | d007eed9a8 | ||
|   | 37891f168a | ||
|   | c2a5598582 | ||
|   | 90e7a3f7e4 | ||
|   | 2db3b7221c | ||
|   | ea77c18a2e | ||
|   | 483ffd5f6b | ||
|   | 64218a7f5b | ||
|   | 651292d8a9 | ||
|   | f338fd62f2 | ||
|   | fcba71790f | ||
|   | ab557a31d5 | ||
|   | 2faf24bce3 | ||
|   | 9b2899cf28 | ||
|   | f5f801273d | 
| @@ -2,8 +2,8 @@ | ||||
|     "FileVersion" : 3, | ||||
|   | ||||
|     "FriendlyName" : "Advanced Sessions", | ||||
|     "Version" : 1.9, | ||||
|     "VersionName": "1.9", | ||||
|     "Version" : 4.17, | ||||
|     "VersionName": "4.17", | ||||
|     "Description" : "Adds new blueprint functions to handle more advanced session operations.", | ||||
|     "Category" : "Advanced Sessions Plugin", | ||||
|     "CreatedBy" : "Joshua Statzer", | ||||
| @@ -16,5 +16,15 @@ | ||||
|             "Type" : "RunTime", | ||||
| 			"LoadingPhase" : "PreDefault" | ||||
|         }  | ||||
|     ] | ||||
|     ], | ||||
| 	"Plugins": [ | ||||
| 		{ | ||||
| 			"Name": "OnlineSubsystem", | ||||
| 			"Enabled": true | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Name": "OnlineSubsystemUtils", | ||||
| 			"Enabled": true | ||||
| 		} | ||||
| 	] | ||||
| } | ||||
| @@ -8,7 +8,7 @@ public class AdvancedSessions : ModuleRules | ||||
|         PCHUsage = PCHUsageMode.UseExplicitOrSharedPCHs; | ||||
|         //bEnforceIWYU = true; | ||||
|  | ||||
|         Definitions.Add("WITH_ADVANCED_SESSIONS=1"); | ||||
|         PublicDefinitions.Add("WITH_ADVANCED_SESSIONS=1"); | ||||
|  | ||||
|         PrivateIncludePaths.AddRange(new string[] { "AdvancedSessions/Private"/*, "OnlineSubsystemSteam/Private"*/ }); | ||||
|         PublicIncludePaths.AddRange(new string[] { "AdvancedSessions/Public" }); | ||||
|   | ||||
| @@ -65,6 +65,7 @@ public: | ||||
| 	void OnSessionInviteAcceptedMaster(const bool bWasSuccessful, int32 LocalPlayer, TSharedPtr<const FUniqueNetId> PersonInviting, const FOnlineSessionSearchResult& SessionToJoin); | ||||
|  | ||||
| 	// After a session invite has been accepted by the local player this event is triggered, call JoinSession on the session result to join it | ||||
| 	// This function is currently not hooked up in any of Epics default subsystems, it is here for custom subsystems | ||||
| 	UFUNCTION(BlueprintImplementableEvent, Category = "AdvancedFriends") | ||||
| 	void OnSessionInviteAccepted(int32 LocalPlayerNum, FBPUniqueNetId PersonInvited, const FBlueprintSessionResult& SessionToJoin); | ||||
|  | ||||
|   | ||||
| @@ -13,7 +13,7 @@ | ||||
| #include "Engine/GameInstance.h" | ||||
| #include "OnlineSessionInterface.h" | ||||
|  | ||||
| #include "UObjectIterator.h" | ||||
| //#include "UObjectIterator.h" | ||||
|  | ||||
| #include "AdvancedSessionsLibrary.generated.h" | ||||
|  | ||||
| @@ -67,6 +67,25 @@ public: | ||||
| 		// Get the Unique Build ID from a session search result | ||||
| 		UFUNCTION(BlueprintPure, Category = "Online|AdvancedSessions|SessionInfo") | ||||
| 		static void GetUniqueBuildID(FBlueprintSessionResult SessionResult, int32 &UniqueBuildId); | ||||
| 		 | ||||
| 		 | ||||
| 		// Thanks CriErr for submission | ||||
|  | ||||
|  | ||||
| 		// Get session property Key Name value | ||||
| 		UFUNCTION(BlueprintCallable, Category = "Online|AdvancedSessions|SessionInfo") | ||||
| 		static FName GetSessionPropertyKey(const FSessionPropertyKeyPair& SessionProperty); | ||||
| 		 | ||||
| 		// Find session property by Name | ||||
| 		UFUNCTION(BlueprintCallable, Category = "Online|AdvancedSessions|SessionInfo", meta = (ExpandEnumAsExecs = "Result")) | ||||
| 		static void FindSessionPropertyByName(const TArray<FSessionPropertyKeyPair>& ExtraSettings, FName SettingsName, EBlueprintResultSwitch &Result, FSessionPropertyKeyPair& OutProperty); | ||||
| 		 | ||||
| 		// Find session property index by Name | ||||
| 		UFUNCTION(BlueprintCallable, Category = "Online|AdvancedSessions|SessionInfo", meta = (ExpandEnumAsExecs = "Result")) | ||||
| 		static void FindSessionPropertyIndexByName(const TArray<FSessionPropertyKeyPair>& ExtraSettings, FName SettingName, EBlueprintResultSwitch &Result, int32& OutIndex); | ||||
|  | ||||
| 		/// Removed the Index_None part of the last function, that isn't accessible in blueprint, better to return success/failure | ||||
| 		// End Thanks CriErr :p | ||||
|  | ||||
| 		// Get session custom information key/value as Byte (For Enums) | ||||
| 		UFUNCTION(BlueprintCallable, Category = "Online|AdvancedSessions|SessionInfo", meta = (ExpandEnumAsExecs = "SearchResult")) | ||||
|   | ||||
| @@ -48,6 +48,7 @@ public: | ||||
| 	static bool RegisterLocalTalker(uint8 LocalPlayerNum = 0); | ||||
|  | ||||
| 	// Registers all signed in players as local talkers | ||||
| 	// This is already done automatically, only do it manually if you unregistered someone | ||||
| 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedVoice") | ||||
| 	static void RegisterAllLocalTalkers(); | ||||
|  | ||||
| @@ -60,6 +61,7 @@ public: | ||||
| 	static void UnRegisterAllLocalTalkers(); | ||||
|  | ||||
| 	// Registers a remote player as a talker | ||||
| 	// This is already done automatically, only do it manually if you unregistered someone | ||||
| 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedVoice") | ||||
| 	static bool RegisterRemoteTalker(const FBPUniqueNetId& UniqueNetId); | ||||
|  | ||||
|   | ||||
| @@ -21,7 +21,7 @@ class UGetUserPrivilegeCallbackProxy : public UOnlineBlueprintCallProxyBase | ||||
| 	UPROPERTY(BlueprintAssignable) | ||||
| 	FEmptyOnlineDelegate OnFailure; | ||||
|  | ||||
| 	// Logs out of the identity interface | ||||
| 	// Gets the privilage of the user | ||||
| 	UFUNCTION(BlueprintCallable, meta=(BlueprintInternalUseOnly = "true", WorldContext="WorldContextObject"), Category = "Online|AdvancedIdentity") | ||||
| 	static UGetUserPrivilegeCallbackProxy* GetUserPrivilege(UObject* WorldContextObject, const EBPUserPrivileges & PrivilegeToCheck, const FBPUniqueNetId & PlayerUniqueNetID); | ||||
|  | ||||
|   | ||||
| @@ -20,7 +20,7 @@ class ULoginUserCallbackProxy : public UOnlineBlueprintCallProxyBase | ||||
| 	UPROPERTY(BlueprintAssignable) | ||||
| 	FEmptyOnlineDelegate OnFailure; | ||||
|  | ||||
| 	// Logs out of the identity interface | ||||
| 	// Logs into the identity interface | ||||
| 	UFUNCTION(BlueprintCallable, meta=(BlueprintInternalUseOnly = "true", WorldContext="WorldContextObject"), Category = "Online|AdvancedIdentity") | ||||
| 	static ULoginUserCallbackProxy* LoginUser(UObject* WorldContextObject, class APlayerController* PlayerController, FString UserID, FString UserToken); | ||||
|  | ||||
|   | ||||
| @@ -22,6 +22,31 @@ void UAdvancedSessionsLibrary::GetUniqueBuildID(FBlueprintSessionResult SessionR | ||||
| 	UniqueBuildId = SessionResult.OnlineResult.Session.SessionSettings.BuildUniqueId; | ||||
| } | ||||
|  | ||||
| FName UAdvancedSessionsLibrary::GetSessionPropertyKey(const FSessionPropertyKeyPair& SessionProperty) | ||||
| { | ||||
| 	return SessionProperty.Key; | ||||
| } | ||||
|  | ||||
| void UAdvancedSessionsLibrary::FindSessionPropertyByName(const TArray<FSessionPropertyKeyPair>& ExtraSettings, FName SettingName, EBlueprintResultSwitch &Result, FSessionPropertyKeyPair& OutProperty) | ||||
| { | ||||
| 	const FSessionPropertyKeyPair* prop = ExtraSettings.FindByPredicate([&](const FSessionPropertyKeyPair& it) {return it.Key == SettingName; }); | ||||
| 	if (prop) | ||||
| 	{ | ||||
| 		Result = EBlueprintResultSwitch::OnSuccess; | ||||
| 		OutProperty = *prop; | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	Result = EBlueprintResultSwitch::OnFailure; | ||||
| } | ||||
|  | ||||
| void UAdvancedSessionsLibrary::FindSessionPropertyIndexByName(const TArray<FSessionPropertyKeyPair>& ExtraSettings, FName SettingName, EBlueprintResultSwitch &Result, int32& OutIndex) | ||||
| { | ||||
| 	OutIndex = ExtraSettings.IndexOfByPredicate([&](const FSessionPropertyKeyPair& it) {return it.Key == SettingName; }); | ||||
|  | ||||
| 	Result = OutIndex != INDEX_NONE ? EBlueprintResultSwitch::OnSuccess : EBlueprintResultSwitch::OnFailure; | ||||
| }	 | ||||
|  | ||||
| void UAdvancedSessionsLibrary::AddOrModifyExtraSettings(UPARAM(ref) TArray<FSessionPropertyKeyPair> & SettingsArray, UPARAM(ref) TArray<FSessionPropertyKeyPair> & NewOrChangedSettings, TArray<FSessionPropertyKeyPair> & ModifiedSettingsArray) | ||||
| { | ||||
| 	ModifiedSettingsArray = SettingsArray; | ||||
| @@ -402,7 +427,7 @@ void UAdvancedSessionsLibrary::GetPlayerName(APlayerController *PlayerController | ||||
|  | ||||
| 	if (APlayerState* PlayerState = (PlayerController != NULL) ? PlayerController->PlayerState : NULL) | ||||
| 	{ | ||||
| 		PlayerName = PlayerState->PlayerName; | ||||
| 		PlayerName = PlayerState->GetPlayerName(); | ||||
| 		return; | ||||
| 	} | ||||
| 	else | ||||
| @@ -413,23 +438,14 @@ void UAdvancedSessionsLibrary::GetPlayerName(APlayerController *PlayerController | ||||
|  | ||||
| void UAdvancedSessionsLibrary::GetNumberOfNetworkPlayers(UObject* WorldContextObject, int32 &NumNetPlayers) | ||||
| { | ||||
| 	//Get an actor to GetWorld() from | ||||
| 	/*TObjectIterator<AActor> Itr; | ||||
| 	if (!Itr) | ||||
| 	{ | ||||
| 		UE_LOG(AdvancedSessionsLog, Warning, TEXT("GetNumberOfNetworkPlayers Failed to get iterator!")); | ||||
| 		return; | ||||
| 	}*/ | ||||
| 	//~~~~~~~~~~~~ | ||||
|  | ||||
| 	//Get World | ||||
| 	UWorld* TheWorld = GEngine->GetWorldFromContextObject(WorldContextObject); | ||||
| 	UWorld* TheWorld = GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull); | ||||
|  | ||||
| 	if (!TheWorld) | ||||
| 	{ | ||||
| 		UE_LOG(AdvancedSessionsLog, Warning, TEXT("GetNumberOfNetworkPlayers Failed to get World()!")); | ||||
| 		return; | ||||
| 	} | ||||
| 	TArray<class APlayerState*>& PlayerArray = (TheWorld->GetGameState()->PlayerArray); | ||||
| 	NumNetPlayers = PlayerArray.Num(); | ||||
|  | ||||
| 	NumNetPlayers = TheWorld->GetGameState()->PlayerArray.Num(); | ||||
| } | ||||
|   | ||||
| @@ -22,7 +22,7 @@ UCancelFindSessionsCallbackProxy* UCancelFindSessionsCallbackProxy::CancelFindSe | ||||
|  | ||||
| void UCancelFindSessionsCallbackProxy::Activate() | ||||
| { | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("CancelFindSessions"), GEngine->GetWorldFromContextObject(WorldContextObject)); | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("CancelFindSessions"), GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull)); | ||||
| 	Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
|  | ||||
| 	if (Helper.IsValid()) | ||||
| @@ -48,7 +48,7 @@ void UCancelFindSessionsCallbackProxy::Activate() | ||||
|  | ||||
| void UCancelFindSessionsCallbackProxy::OnCompleted(bool bWasSuccessful) | ||||
| { | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("CancelFindSessionsCallback"), GEngine->GetWorldFromContextObject(WorldContextObject)); | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("CancelFindSessionsCallback"), GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull)); | ||||
| 	Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
|  | ||||
| 	if (Helper.IsValid()) | ||||
|   | ||||
| @@ -35,7 +35,7 @@ UCreateSessionCallbackProxyAdvanced* UCreateSessionCallbackProxyAdvanced::Create | ||||
|  | ||||
| void UCreateSessionCallbackProxyAdvanced::Activate() | ||||
| { | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("CreateSession"), GEngine->GetWorldFromContextObject(WorldContextObject)); | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("CreateSession"), GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull)); | ||||
| 	 | ||||
| 	if (PlayerControllerWeakPtr.IsValid() ) | ||||
| 		Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
| @@ -79,8 +79,21 @@ void UCreateSessionCallbackProxyAdvanced::Activate() | ||||
| 			} | ||||
| 			 | ||||
| 			 | ||||
| 			if (!bDedicatedServer && PlayerControllerWeakPtr.IsValid() && Helper.UserID.IsValid()) | ||||
| 				Sessions->CreateSession(*Helper.UserID, GameSessionName, Settings); | ||||
| 			if (!bDedicatedServer ) | ||||
| 			{ | ||||
| 				if (PlayerControllerWeakPtr.IsValid() && Helper.UserID.IsValid()) | ||||
| 				{ | ||||
| 					Sessions->CreateSession(*Helper.UserID, GameSessionName, Settings); | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					FFrame::KismetExecutionMessage(TEXT("Invalid Player controller when attempting to start a session"), ELogVerbosity::Warning); | ||||
| 					Sessions->ClearOnCreateSessionCompleteDelegate_Handle(CreateCompleteDelegateHandle); | ||||
| 					 | ||||
| 					// Fail immediately | ||||
| 					OnFailure.Broadcast(); | ||||
| 				} | ||||
| 			} | ||||
| 			else | ||||
| 				Sessions->CreateSession(0, GameSessionName, Settings); | ||||
|  | ||||
| @@ -99,7 +112,7 @@ void UCreateSessionCallbackProxyAdvanced::Activate() | ||||
|  | ||||
| void UCreateSessionCallbackProxyAdvanced::OnCreateCompleted(FName SessionName, bool bWasSuccessful) | ||||
| { | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("CreateSessionCallback"), GEngine->GetWorldFromContextObject(WorldContextObject)); | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("CreateSessionCallback"), GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull)); | ||||
| 	//Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
|  | ||||
| 	if (Helper.OnlineSub != nullptr) | ||||
| @@ -128,8 +141,8 @@ void UCreateSessionCallbackProxyAdvanced::OnCreateCompleted(FName SessionName, b | ||||
|  | ||||
| void UCreateSessionCallbackProxyAdvanced::OnStartCompleted(FName SessionName, bool bWasSuccessful) | ||||
| { | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("StartSessionCallback"), GEngine->GetWorldFromContextObject(WorldContextObject)); | ||||
| 	Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("StartSessionCallback"), GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull)); | ||||
| 	//Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
|  | ||||
| 	if (Helper.OnlineSub != nullptr) | ||||
| 	{ | ||||
|   | ||||
| @@ -22,7 +22,7 @@ UEndSessionCallbackProxy* UEndSessionCallbackProxy::EndSession(UObject* WorldCon | ||||
|  | ||||
| void UEndSessionCallbackProxy::Activate() | ||||
| { | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("EndSession"), GEngine->GetWorldFromContextObject(WorldContextObject)); | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("EndSession"), GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull)); | ||||
| 	Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
|  | ||||
| 	if (Helper.IsValid()) | ||||
| @@ -56,7 +56,7 @@ void UEndSessionCallbackProxy::Activate() | ||||
|  | ||||
| void UEndSessionCallbackProxy::OnCompleted(FName SessionName, bool bWasSuccessful) | ||||
| { | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("EndSessionCallback"), GEngine->GetWorldFromContextObject(WorldContextObject)); | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("EndSessionCallback"), GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull)); | ||||
| 	Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
|  | ||||
| 	if (Helper.IsValid()) | ||||
|   | ||||
| @@ -34,7 +34,7 @@ UFindSessionsCallbackProxyAdvanced* UFindSessionsCallbackProxyAdvanced::FindSess | ||||
|  | ||||
| void UFindSessionsCallbackProxyAdvanced::Activate() | ||||
| { | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("FindSessions"), GEngine->GetWorldFromContextObject(WorldContextObject)); | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("FindSessions"), GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull)); | ||||
| 	Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
|  | ||||
| 	if (Helper.IsValid()) | ||||
| @@ -156,7 +156,7 @@ void UFindSessionsCallbackProxyAdvanced::Activate() | ||||
|  | ||||
| void UFindSessionsCallbackProxyAdvanced::OnCompleted(bool bSuccess) | ||||
| { | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("FindSessionsCallback"), GEngine->GetWorldFromContextObject(WorldContextObject)); | ||||
| 	FOnlineSubsystemBPCallHelperAdvanced Helper(TEXT("FindSessionsCallback"), GEngine->GetWorldFromContextObject(WorldContextObject, EGetWorldErrorMode::LogAndReturnNull)); | ||||
| 	Helper.QueryIDFromPlayerController(PlayerControllerWeakPtr.Get()); | ||||
|  | ||||
| 	if (!bRunSecondSearch && Helper.IsValid()) | ||||
| @@ -225,13 +225,20 @@ void UFindSessionsCallbackProxyAdvanced::OnCompleted(bool bSuccess) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (bRunSecondSearch && ServerSearchType == EBPServerPresenceSearchType::AllServers) | ||||
| 	if (Helper.IsValid() && bRunSecondSearch && ServerSearchType == EBPServerPresenceSearchType::AllServers) | ||||
| 	{ | ||||
| 		bRunSecondSearch = false; | ||||
| 		bIsOnSecondSearch = true; | ||||
| 		auto Sessions = Helper.OnlineSub->GetSessionInterface(); | ||||
| 		Sessions->FindSessions(*Helper.UserID, SearchObjectDedicated.ToSharedRef()); | ||||
| 	} | ||||
| 	else // We lost our player controller | ||||
| 	{ | ||||
| 		if (bSuccess && SessionSearchResults.Num() > 0) | ||||
| 			OnSuccess.Broadcast(SessionSearchResults); | ||||
| 		else | ||||
| 			OnFailure.Broadcast(SessionSearchResults); | ||||
| 	} | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -2,8 +2,8 @@ | ||||
|     "FileVersion" : 3, | ||||
|   | ||||
|     "FriendlyName" : "Advanced Steam Sessions", | ||||
|     "Version" : 1.9, | ||||
|     "VersionName": "1.9", | ||||
|     "Version" : 4.17, | ||||
|     "VersionName": "4.17", | ||||
|     "Description" : "Adds new blueprint functions to handle more advanced session operations in Steam. REQUIRES ADVANCED SESSIONS", | ||||
|     "Category" : "Advanced Sessions Plugin", | ||||
|     "CreatedBy" : "Joshua Statzer", | ||||
| @@ -16,5 +16,23 @@ | ||||
|             "Type" : "RunTime", | ||||
| 			"LoadingPhase" : "PreDefault" | ||||
|         }  | ||||
|     ] | ||||
|     ], | ||||
| 	"Plugins": [ | ||||
| 		{ | ||||
| 			"Name": "AdvancedSessions", | ||||
| 			"Enabled": true | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Name": "OnlineSubsystem", | ||||
| 			"Enabled": true | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Name": "OnlineSubsystemUtils", | ||||
| 			"Enabled": true | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Name": "OnlineSubsystemSteam", | ||||
| 			"Enabled": true | ||||
| 		} | ||||
| 	] | ||||
| } | ||||
| @@ -8,7 +8,7 @@ public class AdvancedSteamSessions : ModuleRules | ||||
|         PCHUsage = PCHUsageMode.UseExplicitOrSharedPCHs; | ||||
|         //bEnforceIWYU = true; | ||||
|  | ||||
|         Definitions.Add("WITH_ADVANCED_STEAM_SESSIONS=1"); | ||||
|         PublicDefinitions.Add("WITH_ADVANCED_STEAM_SESSIONS=1"); | ||||
|  | ||||
|         PublicDependencyModuleNames.AddRange(new string[] { "Core", "CoreUObject", "Engine", "InputCore", "OnlineSubsystem", "CoreUObject", "OnlineSubsystemUtils", "Networking", "Sockets", "AdvancedSessions"/*"Voice", "OnlineSubsystemSteam"*/ }); | ||||
|         PrivateDependencyModuleNames.AddRange(new string[] { "OnlineSubsystem", "Sockets", "Networking", "OnlineSubsystemUtils" /*"Voice", "Steamworks","OnlineSubsystemSteam"*/}); | ||||
|   | ||||
| @@ -29,6 +29,41 @@ enum class SteamAvatarSize : uint8 | ||||
| 	SteamAvatar_Large = 3 | ||||
| }; | ||||
|  | ||||
| UENUM(Blueprintable) | ||||
| enum class ESteamUserOverlayType : uint8 | ||||
| { | ||||
| 	/*Opens the overlay web browser to the specified user or groups profile.*/ | ||||
| 	steamid, | ||||
| 	/*Opens a chat window to the specified user, or joins the group chat.*/ | ||||
| 	chat, | ||||
| 	/*Opens a window to a Steam Trading session that was started with the ISteamEconomy / StartTrade Web API.*/ | ||||
| 	jointrade, | ||||
| 	/*Opens the overlay web browser to the specified user's stats.*/ | ||||
| 	stats, | ||||
| 	/*Opens the overlay web browser to the specified user's achievements.*/ | ||||
| 	achievements, | ||||
| 	/*Opens the overlay in minimal mode prompting the user to add the target user as a friend.*/ | ||||
| 	friendadd, | ||||
| 	/*Opens the overlay in minimal mode prompting the user to remove the target friend.*/ | ||||
| 	friendremove, | ||||
| 	/*Opens the overlay in minimal mode prompting the user to accept an incoming friend invite.*/ | ||||
| 	friendrequestaccept, | ||||
| 	/*Opens the overlay in minimal mode prompting the user to ignore an incoming friend invite.*/ | ||||
| 	friendrequestignore | ||||
| }; | ||||
|  | ||||
| static FString EnumToString(const FString& enumName, uint8 value) | ||||
| { | ||||
| 	const UEnum* EnumPtr = FindObject<UEnum>(ANY_PACKAGE, *enumName, true); | ||||
|  | ||||
| 	if (!EnumPtr) | ||||
| 		return FString(); | ||||
|  | ||||
| 	FString EnumName = EnumPtr->GetNameStringByIndex(value); | ||||
| 	return EnumName; | ||||
| } | ||||
|  | ||||
|  | ||||
| USTRUCT(BlueprintType, Category = "Online|SteamAPI|SteamGroups") | ||||
| struct FBPSteamGroupInfo | ||||
| { | ||||
| @@ -68,6 +103,10 @@ public: | ||||
| 	// Preloads the avatar and name of a steam friend, return whether it is already available or not, STEAM ONLY, Takes time to actually load everything after this is called. | ||||
| 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedFriends|SteamAPI") | ||||
| 	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); | ||||
| 	 | ||||
| 	// Gets the level of a friends steam account, STEAM ONLY, Returns -1 if the steam level is not known, might need RequestSteamFriendInfo called first. | ||||
| 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedFriends|SteamAPI") | ||||
| @@ -88,6 +127,7 @@ public: | ||||
| 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedFriends|SteamAPI", meta = (ExpandEnumAsExecs = "Result")) | ||||
| 	static void GetSteamFriendGamePlayed(const FBPUniqueNetId UniqueNetId, EBlueprintResultSwitch &Result, FString & GameName, int32 & AppID); | ||||
|  | ||||
| 	// Get a full list of steam groups | ||||
| 	UFUNCTION(BlueprintCallable, Category = "Online|SteamAPI|SteamGroups") | ||||
| 		static void GetSteamGroups(TArray<FBPSteamGroupInfo> & SteamGroups); | ||||
| };	 | ||||
|   | ||||
| @@ -13,6 +13,8 @@ | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(push) | ||||
| #pragma warning(disable:4996) | ||||
| // #TODO check back on this at some point | ||||
| #pragma warning(disable:4265) // SteamAPI CCallback< specifically, this warning is off by default but 4.17 turned it on.... | ||||
| #endif | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| @@ -20,8 +22,18 @@ | ||||
| #pragma push_macro("ARRAY_COUNT") | ||||
| #undef ARRAY_COUNT | ||||
|  | ||||
| #if USING_CODE_ANALYSIS | ||||
| MSVC_PRAGMA(warning(push)) | ||||
| MSVC_PRAGMA(warning(disable : ALL_CODE_ANALYSIS_WARNINGS)) | ||||
| #endif	// USING_CODE_ANALYSIS | ||||
|  | ||||
| #include <steam/steam_api.h> | ||||
|  | ||||
| #if USING_CODE_ANALYSIS | ||||
| MSVC_PRAGMA(warning(pop)) | ||||
| #endif	// USING_CODE_ANALYSIS | ||||
|  | ||||
|  | ||||
| #pragma pop_macro("ARRAY_COUNT") | ||||
|  | ||||
| #endif | ||||
| @@ -215,6 +227,25 @@ public: | ||||
| 		CreatorSteamID = FString::Printf(TEXT("%llu"), hUGCDetails.m_ulSteamIDOwner); | ||||
| 	} | ||||
|  | ||||
| 	FBPSteamWorkshopItemDetails(const SteamUGCDetails_t &hUGCDetails) | ||||
| 	{ | ||||
| 		ResultOfRequest = (FBPSteamResult)hUGCDetails.m_eResult; | ||||
| 		FileType = (FBPWorkshopFileType)hUGCDetails.m_eFileType; | ||||
| 		CreatorAppID = (int32)hUGCDetails.m_nCreatorAppID; | ||||
| 		ConsumerAppID = (int32)hUGCDetails.m_nConsumerAppID; | ||||
| 		Title = FString(hUGCDetails.m_rgchTitle, k_cchPublishedDocumentTitleMax); | ||||
| 		Description = FString(hUGCDetails.m_rgchDescription, k_cchPublishedDocumentDescriptionMax); | ||||
| 		ItemUrl = FString(hUGCDetails.m_rgchURL, k_cchPublishedFileURLMax); | ||||
| 		VotesUp = (int32)hUGCDetails.m_unVotesUp; | ||||
| 		VotesDown = (int32)hUGCDetails.m_unVotesDown; | ||||
| 		CalculatedScore = hUGCDetails.m_flScore; | ||||
| 		bBanned = hUGCDetails.m_bBanned; | ||||
| 		bAcceptedForUse = hUGCDetails.m_bAcceptedForUse; | ||||
| 		bTagsTruncated = hUGCDetails.m_bTagsTruncated; | ||||
|  | ||||
| 		CreatorSteamID = FString::Printf(TEXT("%llu"), hUGCDetails.m_ulSteamIDOwner); | ||||
| 	} | ||||
|  | ||||
| 	// Result of obtaining the details | ||||
| 	UPROPERTY(EditAnywhere, BlueprintReadOnly, Category = "Online|AdvancedSteamWorkshop") | ||||
| 		FBPSteamResult ResultOfRequest; | ||||
|   | ||||
| @@ -11,19 +11,33 @@ | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(push) | ||||
| #pragma warning(disable:4996) | ||||
| // #TODO check back on this at some point | ||||
| #pragma warning(disable:4265) // SteamAPI CCallback< specifically, this warning is off by default but 4.17 turned it on.... | ||||
| #endif | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
|  | ||||
| #include "OnlineSubsystemSteam.h" | ||||
|  | ||||
| #pragma push_macro("ARRAY_COUNT") | ||||
| #undef ARRAY_COUNT | ||||
|  | ||||
| #if USING_CODE_ANALYSIS | ||||
| MSVC_PRAGMA(warning(push)) | ||||
| MSVC_PRAGMA(warning(disable : ALL_CODE_ANALYSIS_WARNINGS)) | ||||
| #endif	// USING_CODE_ANALYSIS | ||||
|  | ||||
| #include <steam/steam_api.h> | ||||
|  | ||||
| #if USING_CODE_ANALYSIS | ||||
| MSVC_PRAGMA(warning(pop)) | ||||
| #endif	// USING_CODE_ANALYSIS | ||||
|  | ||||
|  | ||||
| #pragma pop_macro("ARRAY_COUNT") | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
| // @todo Steam: See above | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(pop) | ||||
| @@ -53,6 +67,8 @@ class USteamRequestGroupOfficersCallbackProxy : public UOnlineBlueprintCallProxy | ||||
| { | ||||
| 	GENERATED_UCLASS_BODY() | ||||
|  | ||||
| 	virtual ~USteamRequestGroupOfficersCallbackProxy(); | ||||
|  | ||||
| 	// Called when there is a successful results return | ||||
| 	UPROPERTY(BlueprintAssignable) | ||||
| 	FBlueprintGroupOfficerDetailsDelegate OnSuccess; | ||||
| @@ -61,7 +77,7 @@ class USteamRequestGroupOfficersCallbackProxy : public UOnlineBlueprintCallProxy | ||||
| 	UPROPERTY(BlueprintAssignable) | ||||
| 	FBlueprintGroupOfficerDetailsDelegate OnFailure; | ||||
|  | ||||
| 	// Retruns a list of steam group officers | ||||
| 	// Returns a list of steam group officers | ||||
| 	UFUNCTION(BlueprintCallable, meta=(BlueprintInternalUseOnly = "true", WorldContext="WorldContextObject"), Category = "Online|SteamAPI|SteamGroups") | ||||
| 	static USteamRequestGroupOfficersCallbackProxy* GetSteamGroupOfficerList(UObject* WorldContextObject, FBPUniqueNetId GroupUniqueNetID); | ||||
|  | ||||
| @@ -70,14 +86,15 @@ class USteamRequestGroupOfficersCallbackProxy : public UOnlineBlueprintCallProxy | ||||
| 	// End of UOnlineBlueprintCallProxyBase interface | ||||
|  | ||||
| private: | ||||
| 	 | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	void OnRequestGroupOfficerDetails( ClanOfficerListResponse_t *pResult, bool bIOFailure); | ||||
| 	CCallResult<USteamRequestGroupOfficersCallbackProxy, ClanOfficerListResponse_t> m_callResultGroupOfficerRequestDetails; | ||||
|  | ||||
| #endif | ||||
|  | ||||
| private: | ||||
|  | ||||
| 	FBPUniqueNetId GroupUniqueID; | ||||
| 	UObject* WorldContextObject; | ||||
| }; | ||||
| }; | ||||
| @@ -12,15 +12,29 @@ | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(push) | ||||
| #pragma warning(disable:4996) | ||||
| // #TODO check back on this at some point | ||||
| #pragma warning(disable:4265) // SteamAPI CCallback< specifically, this warning is off by default but 4.17 turned it on.... | ||||
| #endif | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
|  | ||||
| #include "OnlineSubsystemSteam.h" | ||||
|  | ||||
| #pragma push_macro("ARRAY_COUNT") | ||||
| #undef ARRAY_COUNT | ||||
|  | ||||
| #if USING_CODE_ANALYSIS | ||||
| MSVC_PRAGMA(warning(push)) | ||||
| MSVC_PRAGMA(warning(disable : ALL_CODE_ANALYSIS_WARNINGS)) | ||||
| #endif	// USING_CODE_ANALYSIS | ||||
|  | ||||
| #include <steam/steam_api.h> | ||||
|  | ||||
| #if USING_CODE_ANALYSIS | ||||
| MSVC_PRAGMA(warning(pop)) | ||||
| #endif	// USING_CODE_ANALYSIS | ||||
|  | ||||
|  | ||||
| #pragma pop_macro("ARRAY_COUNT") | ||||
|  | ||||
| #endif | ||||
| @@ -30,6 +44,7 @@ | ||||
| #pragma warning(pop) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #include "SteamWSRequestUGCDetailsCallbackProxy.generated.h" | ||||
|  | ||||
| DECLARE_DYNAMIC_MULTICAST_DELEGATE_OneParam(FBlueprintWorkshopDetailsDelegate, const FBPSteamWorkshopItemDetails&, WorkShopDetails); | ||||
|   | ||||
| @@ -9,6 +9,8 @@ | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(push) | ||||
| #pragma warning(disable:4996) | ||||
| // #TODO check back on this at some point | ||||
| #pragma warning(disable:4265) // SteamAPI CCallback< specifically, this warning is off by default but 4.17 turned it on.... | ||||
| #endif | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| @@ -16,7 +18,17 @@ | ||||
| #pragma push_macro("ARRAY_COUNT") | ||||
| #undef ARRAY_COUNT | ||||
|  | ||||
| #if USING_CODE_ANALYSIS | ||||
| MSVC_PRAGMA(warning(push)) | ||||
| MSVC_PRAGMA(warning(disable : ALL_CODE_ANALYSIS_WARNINGS)) | ||||
| #endif	// USING_CODE_ANALYSIS | ||||
|  | ||||
| #include <steam/steam_api.h> | ||||
|  | ||||
| #if USING_CODE_ANALYSIS | ||||
| MSVC_PRAGMA(warning(pop)) | ||||
| #endif	// USING_CODE_ANALYSIS | ||||
|  | ||||
| #include <steam/isteamapps.h> | ||||
| #include <steam/isteamapplist.h> | ||||
| #include <OnlineSubsystemSteamTypes.h> | ||||
| @@ -38,7 +50,7 @@ DEFINE_LOG_CATEGORY(AdvancedSteamFriendsLog); | ||||
| { | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid()) | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid() || UniqueNetId.UniqueNetId->GetType() != STEAM_SUBSYSTEM) | ||||
| 	{ | ||||
| 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("IsAFriend Had a bad UniqueNetId!")); | ||||
| 		return 0; | ||||
| @@ -116,7 +128,7 @@ void UAdvancedSteamFriendsLibrary::GetSteamFriendGamePlayed(const FBPUniqueNetId | ||||
| { | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid()) | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid() || UniqueNetId.UniqueNetId->GetType() != STEAM_SUBSYSTEM) | ||||
| 	{ | ||||
| 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("GetSteamFriendGamePlayed Had a bad UniqueNetId!")); | ||||
| 		Result = EBlueprintResultSwitch::OnFailure; | ||||
| @@ -156,7 +168,7 @@ int32 UAdvancedSteamFriendsLibrary::GetFriendSteamLevel(const FBPUniqueNetId Uni | ||||
| { | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid()) | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid() || UniqueNetId.UniqueNetId->GetType() != STEAM_SUBSYSTEM) | ||||
| 	{ | ||||
| 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("IsAFriend Had a bad UniqueNetId!")); | ||||
| 		return 0; | ||||
| @@ -177,7 +189,7 @@ FString UAdvancedSteamFriendsLibrary::GetSteamPersonaName(const FBPUniqueNetId U | ||||
| { | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid()) | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid() || UniqueNetId.UniqueNetId->GetType() != STEAM_SUBSYSTEM) | ||||
| 	{ | ||||
| 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("GetSteamPersonaName Had a bad UniqueNetId!")); | ||||
| 		return FString(TEXT("")); | ||||
| @@ -222,7 +234,7 @@ FBPUniqueNetId UAdvancedSteamFriendsLibrary::CreateSteamIDFromString(const FStri | ||||
| bool UAdvancedSteamFriendsLibrary::RequestSteamFriendInfo(const FBPUniqueNetId UniqueNetId, bool bRequireNameOnly) | ||||
| { | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid()) | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid() || UniqueNetId.UniqueNetId->GetType() != STEAM_SUBSYSTEM) | ||||
| 	{ | ||||
| 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("RequestSteamFriendInfo Had a bad UniqueNetId!")); | ||||
| 		return false; | ||||
| @@ -240,10 +252,33 @@ bool UAdvancedSteamFriendsLibrary::RequestSteamFriendInfo(const FBPUniqueNetId U | ||||
| 	return false; | ||||
| } | ||||
|  | ||||
|  | ||||
| bool UAdvancedSteamFriendsLibrary::OpenSteamUserOverlay(const FBPUniqueNetId UniqueNetId, ESteamUserOverlayType DialogType) | ||||
| { | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid() || UniqueNetId.UniqueNetId->GetType() != STEAM_SUBSYSTEM) | ||||
| 	{ | ||||
| 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("OpenSteamUserOverlay Had a bad UniqueNetId!")); | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	if (SteamAPI_Init()) | ||||
| 	{ | ||||
| 		uint64 id = *((uint64*)UniqueNetId.UniqueNetId->GetBytes()); | ||||
| 		FString DialogName = EnumToString("ESteamUserOverlayType", (uint8)DialogType); | ||||
| 		SteamFriends()->ActivateGameOverlayToUser(TCHAR_TO_ANSI(*DialogName), id); | ||||
| 		return true; | ||||
| 	} | ||||
| #endif | ||||
|  | ||||
| 	UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("OpenSteamUserOverlay Couldn't init steamAPI!")); | ||||
| 	return false; | ||||
| } | ||||
|  | ||||
| UTexture2D * UAdvancedSteamFriendsLibrary::GetSteamFriendAvatar(const FBPUniqueNetId UniqueNetId, EBlueprintAsyncResultSwitch &Result, SteamAvatarSize AvatarSize) | ||||
| { | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid()) | ||||
| 	if (!UniqueNetId.IsValid() || !UniqueNetId.UniqueNetId->IsValid() || UniqueNetId.UniqueNetId->GetType() != STEAM_SUBSYSTEM) | ||||
| 	{ | ||||
| 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("GetSteamFriendAvatar Had a bad UniqueNetId!")); | ||||
| 		Result = EBlueprintAsyncResultSwitch::OnFailure; | ||||
|   | ||||
| @@ -1,7 +1,9 @@ | ||||
| // Copyright 1998-2015 Epic Games, Inc. All Rights Reserved. | ||||
|  | ||||
| #include "SteamRequestGroupOfficersCallbackProxy.h" | ||||
| #include "CoreOnline.h" | ||||
| #include "OnlineSubSystemHeader.h" | ||||
| #include "OnlineSubsystemSteamTypes.h" | ||||
|  | ||||
| ////////////////////////////////////////////////////////////////////////// | ||||
| // UEndSessionCallbackProxy | ||||
| @@ -11,6 +13,9 @@ USteamRequestGroupOfficersCallbackProxy::USteamRequestGroupOfficersCallbackProxy | ||||
| { | ||||
| } | ||||
|  | ||||
| USteamRequestGroupOfficersCallbackProxy::~USteamRequestGroupOfficersCallbackProxy() | ||||
| { | ||||
| } | ||||
|  | ||||
| USteamRequestGroupOfficersCallbackProxy* USteamRequestGroupOfficersCallbackProxy::GetSteamGroupOfficerList(UObject* WorldContextObject, FBPUniqueNetId GroupUniqueNetID) | ||||
| { | ||||
| @@ -27,7 +32,7 @@ void USteamRequestGroupOfficersCallbackProxy::Activate() | ||||
| 	{ | ||||
| 		uint64 id = *((uint64*)GroupUniqueID.UniqueNetId->GetBytes()); | ||||
| 		SteamAPICall_t hSteamAPICall = SteamFriends()->RequestClanOfficerList(id); | ||||
|  | ||||
| 	 | ||||
| 		m_callResultGroupOfficerRequestDetails.Set(hSteamAPICall, this, &USteamRequestGroupOfficersCallbackProxy::OnRequestGroupOfficerDetails); | ||||
| 		return; | ||||
| 	} | ||||
| @@ -41,10 +46,20 @@ void USteamRequestGroupOfficersCallbackProxy::OnRequestGroupOfficerDetails(ClanO | ||||
| 	TArray<FBPSteamGroupOfficer> OfficerArray; | ||||
|  | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	 | ||||
| 	FOnlineSubsystemSteam* SteamSubsystem = (FOnlineSubsystemSteam*)(IOnlineSubsystem::Get(STEAM_SUBSYSTEM)); | ||||
|  | ||||
| 	if (bIOFailure || !pResult || !pResult->m_bSuccess) | ||||
| 	{ | ||||
| 		OnFailure.Broadcast(OfficerArray); | ||||
| 		if (SteamSubsystem != nullptr) | ||||
| 		{ | ||||
| 			SteamSubsystem->ExecuteNextTick([this]() | ||||
| 			{ | ||||
| 				TArray<FBPSteamGroupOfficer> FailureArray; | ||||
| 				OnFailure.Broadcast(FailureArray); | ||||
| 			}); | ||||
| 		} | ||||
| 		//OnFailure.Broadcast(OfficerArray); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| @@ -73,11 +88,31 @@ void USteamRequestGroupOfficersCallbackProxy::OnRequestGroupOfficerDetails(ClanO | ||||
| 			OfficerArray.Add(Officer); | ||||
| 		} | ||||
|  | ||||
| 		OnSuccess.Broadcast(OfficerArray); | ||||
| 		if (SteamSubsystem != nullptr) | ||||
| 		{ | ||||
| 			SteamSubsystem->ExecuteNextTick([OfficerArray, this]() | ||||
| 			{ | ||||
| 				OnSuccess.Broadcast(OfficerArray); | ||||
| 			}); | ||||
| 		} | ||||
|  | ||||
| 		//OnSuccess.Broadcast(OfficerArray); | ||||
| 		return; | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		if (SteamSubsystem != nullptr) | ||||
| 		{ | ||||
| 			SteamSubsystem->ExecuteNextTick([this]() | ||||
| 			{ | ||||
| 				TArray<FBPSteamGroupOfficer> FailureArray; | ||||
| 				OnFailure.Broadcast(FailureArray); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| #endif | ||||
|  | ||||
| 	OnFailure.Broadcast(OfficerArray); | ||||
| 	// Should never hit this anyway | ||||
| 	//OnFailure.Broadcast(OfficerArray); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -49,23 +49,51 @@ void USteamWSRequestUGCDetailsCallbackProxy::Activate() | ||||
| void USteamWSRequestUGCDetailsCallbackProxy::OnUGCRequestUGCDetails(SteamUGCQueryCompleted_t *pResult, bool bIOFailure) | ||||
| { | ||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | ||||
| 	 | ||||
| 	FOnlineSubsystemSteam* SteamSubsystem = (FOnlineSubsystemSteam*)(IOnlineSubsystem::Get(STEAM_SUBSYSTEM)); | ||||
|  | ||||
| 	if (bIOFailure || !pResult || pResult->m_unNumResultsReturned <= 0) | ||||
| 	{ | ||||
| 		OnFailure.Broadcast(FBPSteamWorkshopItemDetails()); | ||||
| 	{ | ||||
| 		if (SteamSubsystem != nullptr) | ||||
| 		{ | ||||
| 			SteamSubsystem->ExecuteNextTick([this]() | ||||
| 			{ | ||||
| 				OnFailure.Broadcast(FBPSteamWorkshopItemDetails()); | ||||
| 			}); | ||||
| 		} | ||||
| 		//OnFailure.Broadcast(FBPSteamWorkshopItemDetails()); | ||||
| 		return; | ||||
| 	} | ||||
| 	if (SteamAPI_Init()) | ||||
| 	{ | ||||
| 		SteamUGCDetails_t Details; | ||||
| 		if (SteamUGC()->GetQueryUGCResult(pResult->m_handle, 0, &Details)) | ||||
| 		{ | ||||
| 			OnSuccess.Broadcast(FBPSteamWorkshopItemDetails(Details)); | ||||
| 		{ | ||||
| 			if (SteamSubsystem != nullptr) | ||||
| 			{ | ||||
| 				SteamSubsystem->ExecuteNextTick([Details, this]() | ||||
| 				{ | ||||
| 					OnSuccess.Broadcast(FBPSteamWorkshopItemDetails(Details)); | ||||
| 				}); | ||||
| 			} | ||||
|  | ||||
| 			//OnSuccess.Broadcast(FBPSteamWorkshopItemDetails(Details)); | ||||
| 			return; | ||||
| 		} | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		if (SteamSubsystem != nullptr) | ||||
| 		{ | ||||
| 			SteamSubsystem->ExecuteNextTick([this]() | ||||
| 			{ | ||||
| 				OnFailure.Broadcast(FBPSteamWorkshopItemDetails()); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| #endif | ||||
|  | ||||
| 	OnFailure.Broadcast(FBPSteamWorkshopItemDetails()); | ||||
| 	// Not needed, should never hit here | ||||
| 	//OnFailure.Broadcast(FBPSteamWorkshopItemDetails()); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1 +1,7 @@ | ||||
| Readme and documentation will be worked on soon | ||||
| ### How do I use it? ### | ||||
|  | ||||
| **KantanDocGen Automatic Documentation ([KantanDocGen](http://kantandev.com/free/kantan-doc-gen))**  | ||||
|  | ||||
| **[AdvancedSessions](https://mordentral.bitbucket.io/AdvancedSessions/Advanced)** | ||||
|  | ||||
| **[AdvancedSteamSessions](https://mordentral.bitbucket.io/AdvancedSteamSessions/Advanced)** | ||||
|   | ||||
		Reference in New Issue
	
	Block a user