mirror of
				https://github.com/mordentral/AdvancedSessionsPlugin.git
				synced 2025-10-26 18:04:07 +00:00 
			
		
		
		
	Compare commits
	
		
			3 Commits
		
	
	
		
			4.24_Locke
			...
			4.20_Locke
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 525e6411a6 | ||
|   | 6b4ac8d00c | ||
|   | 50752d2a95 | 
| @@ -18,7 +18,13 @@ class UCreateSessionCallbackProxyAdvanced : public UOnlineBlueprintCallProxyBase | |||||||
| 	UPROPERTY(BlueprintAssignable) | 	UPROPERTY(BlueprintAssignable) | ||||||
| 	FEmptyOnlineDelegate OnFailure; | 	FEmptyOnlineDelegate OnFailure; | ||||||
|  |  | ||||||
| 	// Creates a session with the default online subsystem with advanced optional inputs, for dedicated servers leave UsePresence as false and set IsDedicatedServer to true. Dedicated servers don't use presence. | 	/** | ||||||
|  | 	 *    Creates a session with the default online subsystem with advanced optional inputs, for dedicated servers leave UsePresence as false and set IsDedicatedServer to true. Dedicated servers don't use presence. | ||||||
|  | 	 *    @param PublicConnections	When doing a 'listen' server, this must be >=2 (ListenServer itself counts as a connection) | ||||||
|  | 	 *    @param bUseLAN			When you want to play LAN, the level to play on must be loaded with option 'bIsLanMatch' | ||||||
|  | 	 *    @param bUsePresence		Must be true for a 'listen' server (Map must be loaded with option 'listen'), false for a 'dedicated' server. | ||||||
|  | 	 *	  @param bShouldAdvertise	Set to true when the OnlineSubsystem should list your server when someone is searching for servers. Otherwise the server is hidden and only join via invite is possible. | ||||||
|  | 	 */ | ||||||
| 	UFUNCTION(BlueprintCallable, meta=(BlueprintInternalUseOnly = "true", WorldContext="WorldContextObject",AutoCreateRefTerm="ExtraSettings"), Category = "Online|AdvancedSessions") | 	UFUNCTION(BlueprintCallable, meta=(BlueprintInternalUseOnly = "true", WorldContext="WorldContextObject",AutoCreateRefTerm="ExtraSettings"), Category = "Online|AdvancedSessions") | ||||||
| 	static UCreateSessionCallbackProxyAdvanced* CreateAdvancedSession(UObject* WorldContextObject, const TArray<FSessionPropertyKeyPair> &ExtraSettings, class APlayerController* PlayerController = NULL, int32 PublicConnections = 100, int32 PrivateConnections = 0, bool bUseLAN = false, bool bAllowInvites = true, bool bIsDedicatedServer = false, bool bUsePresence = true, bool bAllowJoinViaPresence = true, bool bAllowJoinViaPresenceFriendsOnly = false, bool bAntiCheatProtected = false, bool bUsesStats = false, bool bShouldAdvertise = true); | 	static UCreateSessionCallbackProxyAdvanced* CreateAdvancedSession(UObject* WorldContextObject, const TArray<FSessionPropertyKeyPair> &ExtraSettings, class APlayerController* PlayerController = NULL, int32 PublicConnections = 100, int32 PrivateConnections = 0, bool bUseLAN = false, bool bAllowInvites = true, bool bIsDedicatedServer = false, bool bUsePresence = true, bool bAllowJoinViaPresence = true, bool bAllowJoinViaPresenceFriendsOnly = false, bool bAntiCheatProtected = false, bool bUsesStats = false, bool bShouldAdvertise = true); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -246,6 +246,41 @@ enum class SteamAvatarSize : uint8 | |||||||
| 	SteamAvatar_Large = 3 | 	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") | USTRUCT(BlueprintType, Category = "Online|SteamAPI|SteamGroups") | ||||||
| struct FBPSteamGroupInfo | struct FBPSteamGroupInfo | ||||||
| { | { | ||||||
| @@ -284,6 +319,10 @@ public: | |||||||
| 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedFriends|SteamAPI") | 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedFriends|SteamAPI") | ||||||
| 	static bool RequestSteamFriendInfo(const FBPUniqueNetId UniqueNetId, bool bRequireNameOnly = false); | 	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. | 	// 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") | 	UFUNCTION(BlueprintCallable, Category = "Online|AdvancedFriends|SteamAPI") | ||||||
| 	static int32 GetFriendSteamLevel(const FBPUniqueNetId UniqueNetId); | 	static int32 GetFriendSteamLevel(const FBPUniqueNetId UniqueNetId); | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ DEFINE_LOG_CATEGORY(AdvancedSteamFriendsLog); | |||||||
| { | { | ||||||
|  |  | ||||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | #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!")); | 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("IsAFriend Had a bad UniqueNetId!")); | ||||||
| 		return 0; | 		return 0; | ||||||
| @@ -91,7 +91,7 @@ void UAdvancedSteamFriendsLibrary::GetSteamFriendGamePlayed(const FBPUniqueNetId | |||||||
| { | { | ||||||
|  |  | ||||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | #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!")); | 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("GetSteamFriendGamePlayed Had a bad UniqueNetId!")); | ||||||
| 		Result = EBlueprintResultSwitch::OnFailure; | 		Result = EBlueprintResultSwitch::OnFailure; | ||||||
| @@ -133,7 +133,7 @@ int32 UAdvancedSteamFriendsLibrary::GetFriendSteamLevel(const FBPUniqueNetId Uni | |||||||
| { | { | ||||||
|  |  | ||||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | #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!")); | 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("IsAFriend Had a bad UniqueNetId!")); | ||||||
| 		return 0; | 		return 0; | ||||||
| @@ -154,7 +154,7 @@ FString UAdvancedSteamFriendsLibrary::GetSteamPersonaName(const FBPUniqueNetId U | |||||||
| { | { | ||||||
|  |  | ||||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | #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!")); | 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("GetSteamPersonaName Had a bad UniqueNetId!")); | ||||||
| 		return FString(TEXT("")); | 		return FString(TEXT("")); | ||||||
| @@ -199,7 +199,7 @@ FBPUniqueNetId UAdvancedSteamFriendsLibrary::CreateSteamIDFromString(const FStri | |||||||
| bool UAdvancedSteamFriendsLibrary::RequestSteamFriendInfo(const FBPUniqueNetId UniqueNetId, bool bRequireNameOnly) | bool UAdvancedSteamFriendsLibrary::RequestSteamFriendInfo(const FBPUniqueNetId UniqueNetId, bool bRequireNameOnly) | ||||||
| { | { | ||||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | #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!")); | 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("RequestSteamFriendInfo Had a bad UniqueNetId!")); | ||||||
| 		return false; | 		return false; | ||||||
| @@ -217,10 +217,33 @@ bool UAdvancedSteamFriendsLibrary::RequestSteamFriendInfo(const FBPUniqueNetId U | |||||||
| 	return false; | 	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) | UTexture2D * UAdvancedSteamFriendsLibrary::GetSteamFriendAvatar(const FBPUniqueNetId UniqueNetId, EBlueprintAsyncResultSwitch &Result, SteamAvatarSize AvatarSize) | ||||||
| { | { | ||||||
| #if PLATFORM_WINDOWS || PLATFORM_MAC || PLATFORM_LINUX | #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!")); | 		UE_LOG(AdvancedSteamFriendsLog, Warning, TEXT("GetSteamFriendAvatar Had a bad UniqueNetId!")); | ||||||
| 		Result = EBlueprintAsyncResultSwitch::OnFailure; | 		Result = EBlueprintAsyncResultSwitch::OnFailure; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user