In this post we will look into integrating PlayFab login and create blueprints. We will focus specifically on blueprint logic rather than the design.
This is effectively equivalent to OWS login/register – so don’t do both.
You can find demo video showing login/register here.
Pre-requisites
The pre-requisites is that you register with PlayFab, login or register here: https://developer.playfab.com/en-us/login
Once you login you will be greeted with this screen:
data:image/s3,"s3://crabby-images/d8fe1/d8fe14fc7c2e39a3fab5be630da793d2dcb5af38" alt=""
Take note of the ID here, you will need it when setting up.
Next, click into it and you will see the following screen:
data:image/s3,"s3://crabby-images/5f338/5f33815dbc7bd7c3b2c51f6ff66b99a1dec8ea96" alt=""
Click on the cog and a small menu will pop up, choose Title settings.
Now you can select the Secret Keys on the dashboard and see the API keys here – create new one for your development. You should create a separate key usually for different purposes, e.g. development, test, production, etc.
data:image/s3,"s3://crabby-images/2285c/2285c2fa96e95b3d0ca4892ea71b384e5dafda2e" alt=""
Now you have title ID and title secret key available.
Next, download the plugin for your Unreal Engine
https://www.unrealengine.com/marketplace/en-US/product/playfab-sdk
data:image/s3,"s3://crabby-images/48124/481248f40ce404da00dc7a2e7ce577439dc6b33c" alt="Playfab unreal engine plugin"
Once you’ve installed it to the engine, we’re ready to configure it in your project.
Open your project, click Edit -> Plugins
data:image/s3,"s3://crabby-images/d96f1/d96f174a8b48ec7a4d8669e47b0e8a9b35e38922" alt=""
data:image/s3,"s3://crabby-images/952cf/952cf78cc3ab03576380f01922543a1dc1b1f2ff" alt=""
Search for the playfab plugin and enable it.
After enabling the plugin, click Edit -> Project Settings and locate Playfab under Plugins section.
data:image/s3,"s3://crabby-images/8fd61/8fd617ee54b48bf205bd1d747cd99434386be8ca" alt=""
Enter the title ID and the secret key you’ve located in the earlier steps.
You’ve now configured Playfab to be used in your project!
Login Widget
data:image/s3,"s3://crabby-images/a1011/a10114aadfc422a0c9fd0174c3f3e07f01cd01e9" alt=""
Here’s a simple widget design for Login screen.
There are 3 buttons, let’s look at the blueprints for each.
data:image/s3,"s3://crabby-images/141e1/141e1ba066c391907e4bfc7267d69c151ad63a96" alt=""
The Quit and Register buttons are simple; on quit, close the game.
When you click Register, we want to open up the register widget (which we’ll look at implementation soon).
The Go to register function is as follows:
data:image/s3,"s3://crabby-images/3f647/3f6477d6e6926a83967b9e3f6dd2a1c51df12067" alt=""
Now let’s look into the login implementation, which utilizes Playfab.
data:image/s3,"s3://crabby-images/3a89a/3a89aeb007ad26fc76093b1b368d07ca1a167555" alt="Handle login with playfab functionality"
There are a few things utilized here, let’s go in order.
First, Login with Play Fab – this is a function from the PlayFab blueprint. It expects you to make a ClientLoginWithPlayFabRequest.
We just need to provide it with Username and Password that are extracted from the textboxes in the UI.
The Login with Play Fab function expects you to setup an event for success and error scenario – it will only callback to one of them on each request.
Let’s do the error one first.
data:image/s3,"s3://crabby-images/36677/366779b8194c2f9b7b8b1bf7b23a47eb7918a30f" alt="create error widget"
This simply creates a custom error widget to feedback the results to user.
The design:
data:image/s3,"s3://crabby-images/cdc05/cdc05f55e0abb2b08a4b0c9436e3a76999de4edf" alt="error widget design"
And the implementation:
data:image/s3,"s3://crabby-images/c1824/c1824bc464325c106931ca7bd0ddd46f19e032b5" alt="error widget blueprints"
This error widget is used across multiple places, including login, register, create character, etc.
The Login Success will respond us with a payload:
data:image/s3,"s3://crabby-images/8abe6/8abe6ba7c0e8192aff54b4a120982a40db7e7a56" alt="handle login success"
You can see what kind of information it holds:
data:image/s3,"s3://crabby-images/4c4ee/4c4eeadb0d97647de4c027d5bde06a94f88d2029" alt="client login result definition"
We don’t need all of it at this stage, but we will add it to our game instance for us to be able to use this info throughout the game project.
In case you’re not sure how to create game instance, right click and select to create new blueprint.
Then search for ‘game instance’ and select that for parent.
data:image/s3,"s3://crabby-images/0b9a8/0b9a880e925058e6b94f2235912f9e77ce0a8f78" alt="creating game instance"
Then click Edit -> Project Settings and search ‘Game instance’ and select it
data:image/s3,"s3://crabby-images/693dc/693dcefb89c3b10c262067a710fc0bc493875be0" alt="setting game instance in project settings"
All you need to do is add variable of type Client Login Result to your Game Instance class
data:image/s3,"s3://crabby-images/bd296/bd2963ac800fdc3b60535ca08f498e2d2fe0d983" alt="Adding login info to main game instance"
Finally, when successful, you can go to Character Selection screen – which will be covered in the next post.
data:image/s3,"s3://crabby-images/ba7c7/ba7c7c26f3964b5757df8da7bf2db1cb4a9bf932" alt="Go to character select function"
Register Widget
data:image/s3,"s3://crabby-images/0849b/0849b34392dc93c6dee536fe402207b6d3680611" alt="Register widget design"
In this screen, we want to register a user. For this, we will take username, email and password.
Let’s look at the Back button first:
data:image/s3,"s3://crabby-images/b4054/b4054df959fa77dbb08640323048de4245206225" alt=""
data:image/s3,"s3://crabby-images/c9ca7/c9ca7f8473b26595c192f0481dc7a9adacf475f6" alt="Go to login widget"
This is simply navigating back to Login widget and closing self.
Let’s check the blueprints for clicking register.
data:image/s3,"s3://crabby-images/f44a3/f44a3255f7960782ed300e0278c34d4b504c4b78" alt="Handle register with PlayFab functionality"
When clicking the Register button, we mainly want to invoke the Register Play Fab User function, from the Play fab plugin.
This requires the Client Register Play Fab User Request payload.
We just need to assign the email, password and username here.
Now we need to define the success and error custom events – in the same fashion as we did with Login.
When there’s an error, we will handle it by creating the error widget and assigning the error message – it’s the same function.
On success, we simply navigate back to login – this is the same functionality as clicking back. You may want to do something else here too, like provide success message to user, then navigate back.
That’s it for Login and Register!
In the next post we will look at how to create characters for this new user.
Pingback: 35. Unreal + PlayFab: create/get character – Unreal game dev with Yaz