
Publisher
talkafk
WebBus (yandex games, crazy games, poki)
It's a plugin for the Godot engine. Use one plugin for several web platform SDKs. Supported platforms - Crazy games - Yandex games - Poki
This plugin has been mirrored from the Godot Asset Library.
The plugin author is in no way affiliated with Gadget.
If you are the author of this plugin and would like this mirror removed, please contact support@gadgetgodot.com.
WebBus

It's a plugin for the Godot engine. Use one plugin for several web platform SDKs.
This version is for Godot 4.x.
Contents
Supported platforms
- Crazy games
- Yandex games
- Poki
| Feature | Crazy Games | Yandex Games | Poki | 
|---|---|---|---|
| Fullscreen Advertisement | ✅ | ✅ | ✅ | 
| Rewarded Advertisement | ✅ | ✅ | ✅ | 
| Banner Advertisement | ✅ | ✅ | ❌ | 
| User Info | ✅ | ✅ | ❌ | 
| Leaderboards | ❌ | ✅ | ❌ | 
| Payments | ❌ | ✅ | ❌ | 
| Invite Links | ✅ | ❌ | ✅ | 
| Invite Button | ✅ | ❌ | ❌ | 
| Server time | ❌ | ✅ | ❌ | 
| Desktop shortcut | ❌ | ✅ | ❌ | 
Installation
- Download the plugin as a ZIP archive.
- Extract the ZIP archive and move the addons/folder it contains into your project folder.
- Enable the plugin in Project > Project Settings > Plugins.
Usage
You can explore the demo scene for a better understanding of how to use the plugin.
Initialization
[!WARNING] If you use any Webbus method in _ready() of an autoload script or the initial scene, you need to wait until the plugin is fully initialized before calling its method. See the example below.
var lang :String
func _ready() -> void:
	if !WebBus.is_init:
		await WebBus.inited
	WebBus.ready()
	lang = WebBus.get_language()
Advertisement
Fullscreen Advertisement
Calling full-screen advertisement:
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
WebBus.show_ad()
Rewarded Advertisement
Calling rewarded advertisement:
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
WebBus.show_rewarded_ad()
For full-screen and rewarded advertisements, there are 4 callback signals:
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
signal reward_added 
signal ad_closed
signal ad_error
signal ad_started
Full example
extends Node
func _ready():
	WebBus.ad_closed.connect(ad_closed)
	WebBus.ad_error.connect(ad_error)
	WebBus.ad_started.connect(ad_started)
	WebBus.reward_added.connect(reward_added)
	WebBus.show_ad()
func ad_started():
	AudioServer.set_bus_mute(0, true)
func ad_closed():
	AudioServer.set_bus_mute(0, false)
func ad_error():
	push_warning("ad_error")
func reward_added():
	$Player.add_gold(10)
Banner advertisement
Calling banner advertisement:
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
WebBus.show_banner()
Close banner advertisement:
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
WebBus.hide_banner()
For Crazy Games banner you can set the size and position in the Main Screen Menu
Game
The start_gameplay() function has to be called whenever the player starts playing or resumes playing after a break.
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
WebBus.start_gameplay()
The stop_gameplay() function has to be called on every game break, don't forget to call start_gameplay() when the gameplay resumes.
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
WebBus.stop_gameplay()
The happytime() method can be called on various player achievements.
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
WebBus.happytime()
The start_loading() function has to be called whenever you start loading your game.
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
WebBus.start_loading()
Ready
Call ready() when the game is fully loaded and ready to play. 
Note: For Crazy Games, calling
ready()is equivalent tosdkGameLoadingStop(). For Poki, this is equivalent togameLoadingFinished()
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
WebBus.ready()
User
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
user_info dictionary contains player's username and avatar link
print(WebBus.user_info)
# {"player_name": "NameOfPlayer", "avatar": "https://link/to/avatar.png"}
var name = WebBus.user_info.player_name
var avatar_link = WebBus.user_info.avatar
Other
Getting name of platform:
The function returns a String. Possible values are: "yandex", "crazy_games", "poki"
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
var platform_name = WebBus.get_platform()
Getting type of device:
The function returns a String, possible values: "desktop", "tablet", "mobile".
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
var device_type = WebBus.get_type_device()
Getting language:
The function returns 2-letter language code.
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
var language = WebBus.get_language()
Invite
Invite Links
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
Create invite links with your parameters:
var result = await WebBus.invite_link(params)
params : Dictionary type
result : Dictionary type, invite link on this platform
Get parameters from link:
var value = await WebBus.get_invite_param(params)
key : String type
result : Dictionary type, invite link on this platform
Invite Button
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
Show invite button:
WebBus.show_invite_button(params)
params : Dictionary type
Hide invite button:
WebBus.hide_invite_button(params)
Leaderboards
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
Features exclusive to Yandex games.
Get leaderboard description:
WebBus.leaderboard_info_recieved.connect(getting_leaderboard_info)
WebBus.get_leaderboard_info(name_leaderboard)
func getting_leaderboard_info(info):
	print(info)
name_leaderboard : String type
info : Dictionary type
Get leaderboard player entry:
WebBus.leaderboard_player_entry_recieved.connect(getting_leaderboard_player_entry)
WebBus.get_leaderboard_player_entry(name_leaderboard)
func getting_leaderboard_player_entry(info):
	print(info.score)
name_leaderboard : String type
info : Dictionary type
Get leaderboard entries:
WebBus.leaderboard_entries_recieved.connect(getting_leaderboard_entries)
WebBus.get_leaderboard_entries(name_leaderboard, include_user=true, quantity_around=5, quantity_top=5)
func getting_leaderboard_entries(info):
	print(info.userRank)
name_leaderboard : String type
include_user : bool type, optional parameter
quantity_around : int type, optional parameter
quantity_top : int type, optional parameter
info : Dictionary type
Save score in leaderboard:
WebBus.set_leaderboard_score(name_leaderboard, score, extra_data)
name_leaderboard : String type
score : int type
extra_data : optional parameter, String type
Payments
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
Init yandex payments
await WebBus.init_payments(signed)
signed: optional parameter, bool type
Make purchase
var purchase:Dictionary = await WebBus.purchase(product_id, developer_payload)
product_id: String type
developer_payload: optional parameter, String type
Get player's purchase list
var purchase_list:Array = await WebBus.get_purchases()
Get product list
var product_list:Array = await WebBus.get_catalog()
Consume purchase
var success:bool = await WebBus.consume_purchase(token)
token: String type
Purchase example
await WebBus.init_payments()
var purchase:Dictionary = await WebBus.purchase("your_purchase_id")
if ! purchase.get("error", false): # Check if the purchase was successful
	player.add_gold(500)
	WebBus.consume_purchase(purchase.purchase_token)
Server time
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
Get server time
var time:int = WebBus.get_server_time() # Example: 1720613073778
Game Rating
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
Check if the player can provide feedback:
var feedback_info = await WebBus.can_rewiew()
print(feedback_info.value) # bool
Request feedback from the player:
var feedback_request = await WebBus.request_review()
print(feedback_request.feedback_sent) # bool
Desktop shortcut
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
Check if the player can show a prompt:
var prompt = await WebBus.can_show_prompt()
print(prompt.can_show) # true or false
Show a prompt to the player:
var result = await WebBus.show_prompt()
print(result.outcome) # "accepted"
Pause
| Platform | Supported | 
|---|---|
| Crazy Games | |
| Yandex Games | |
| Poki | 
[!NOTE] This function works on any hosting, including the test server Godot.
Sometimes the built-in Godot focus tracking tools may not work under specific conditions. To avoid unwanted behavior in such cases, this plugin provides signals:
- focused
- unfocused
Example:
WebBus.focused.connect(func():
	get_tree().set_pause(false))
WebBus.unfocused.connect(func():
	get_tree().set_pause(true))
Main Screen Menu
In the main screen menu you can set your settings.
You can enable automatic build archiving, but make sure the export folder does not contain any extraneous files.
