Etherlinker for UE4
- Interact with Ethereum blockchain from Unreal Engine 4
- Compile new solidity contracts or integration server directly from UE4 Editor
- Start/Stop/Restart/Check integration server from UE4 Editor
- Contract deployment support
- ETH transfer support
- Wallet balance checking support
- Wallet creation support
- Custom solidity contracts support
- ERC20 token contract template with Premium Items and Subscriptions support
- ERC721 token contract template to make unique in-game entities, like pets
- Donations contract template - raise funds for your projects without paying commissions to third party providers
- Execute multiple operations on Ethereum blockchain from UE4 with a single batch request
- Lots of template widgets (compatible with VR and multiplayer) to speed up your development
- Lots of ways to create or load Ethereum wallets.
- Data encryption methods on both UE4 and integration server sides (SSL, AES-256, RSA, ECDSA, HMAC)
- External database support for integration server (Default is H2, recommended PostgreSQL)
- Integration server monitoring via Java Melody
- Geth/Parity support for those, who don't want to use Infura Network
- Multiplayer Support
- VR Support
Why you may need this project:
- You want to add an additional source of income for your project (without any royalties to third-party providers)
- You want to store some data on Ethereum blockchain and use it in your projects
- You need to implement some logic in solidity contracts and interact with them in UE4
- You want to make blockchain-powered games
- You want to make a virtual store in VR and sell your real-world products in it
- You are an enterprise developer and want to use it for *** (removed due to NDA)
- You want to use some examples (not related to blockchain) from it in your projects
To start using Etherlinker for UE4, you need:
- Unreal Engine 4.20 or above (Can be installed from Epic Games Launcher: https://www.epicgames.com/unrealtournament/download)
- OpenJDK 11 - to compile and run integration server (https://jdk.java.net/11/) - read F.A.Q for instructions.
- Get access URL from Infura (https://infura.io/) to be able to interact with Ethereum blockchain from integration server or use Geth/Parity for the same purposes.
If you want to add custom contracts, change plugin's or server code:
- Visual Studio 2017 or above (https://docs.unrealengine.com/en-us/Programming/Development/VisualStudioSetup)
- IntelliJ IDEA or similar IDE - to modify code of integration server.
Additionally in production:
- Generate SSL certificate and put it here: EtherlinkerServer\Stratum\src\main\resources, then configure application.properties in the same directory. Or use existing certificate for debug purposes. - It will give you secure communication between UE4 application and integration server. Look FAQ for more details.
How it works
The project contains two parts:
Integration server, written in Java, which interacts with Ethereum blockchain.
UE4 Plugin, which sends requests to the integration server and getting responses from it.
Currently, integration server is using Infura to interact with Ethereum blockchain, but you can add your solution as well by modifying the code of integration server.
UE4 Plugin interacts with the integration server via JSON requests via HTTPS. You also can change this behavior by adapting the plugin's code to your own needs.
You can pack the integration server with your project so that it will be installed on the end-user machine. This way is preferred for small indie teams without a budget because it excludes costs for server maintenance.
You can also install the integration server on your dedicated server so that it could handle multiple projects.
It's also possible to install UE4 Plugin only on the server side to add additional security and scalability layer for complex multiplayer projects.
By default, all operations on the integration server generate signed transactions and send them to the infura network. It means that if you're using integration server locally on end-user PC, no credentials will be sent outside of integration server. In this case, you should distribute JRE with your project in order to run the integration server on end-user PC.
If you have remote integration server, then you should securely transfer wallet credentials to it from end-user PC. You can use SSL encryption or add an additional custom encryption level over it. However, many users may not want to expose their wallet credentials in such a manner, so it's not the best approach. In this case, it's better to create and manage separate wallets on your server and give users the ability to sign in to their accounts in order to use their in-game wallets. If it's required, they can transfer funds from other wallets to in-game wallets by using external tools and use them in your project. Remote wallets will help you to achieve this.
It's also possible to use both local and remote server in one application by specifying different server address for different purposes. For example, do all operations with funds on a local server, but execute some read-only contract methods on the server side.
Supported platforms: Windows, Mac, Android, iOS
Supported engine versions: 4.20, 4.21