diff --git a/extensions/community/IPRetriever.json b/extensions/community/IPRetriever.json new file mode 100644 index 000000000..05dc56ccc --- /dev/null +++ b/extensions/community/IPRetriever.json @@ -0,0 +1,329 @@ +{ + "author": "", + "category": "Network", + "extensionNamespace": "", + "fullName": "IPRetriever", + "gdevelopVersion": "", + "helpPath": "", + "iconUrl": "", + "name": "IPRetriever", + "previewIconUrl": "https://asset-resources.gdevelop.io/public-resources/Icons/Line Hero Pack/Master/SVG/Maps and Navigation/ad277c3633357d2dbadf29e04f9b4c38d22e1cf43eef6206c15130f556e2c117_Maps and Navigation_location_pin.svg", + "shortDescription": "Adds a way to get the user's IP address by sending a web request and extracting the result.", + "version": "1.0.1", + "description": [ + "This extension gets the user's public IP address via a web request to ipify.", + "", + "**⚠️ Important:** Before storing any IP address in a database, it is strongly recommended to hash it. This helps protect user privacy and prevents unauthorized access to raw IP addresses. ⚠️", + "", + "## Instructions (how to use it)", + "", + "### Actions", + "- Call `IP_Adress::GetIP` to fetch the IP.", + "", + "### Conditions", + "- Use `IP Adress is ready` to check if the IP has been retrieved.", + "- Use `Failed to get the user's IP Adress` to check if the action has failed.", + "", + "### Expressions", + "- Use `IP_Adress::Adress()` to get the parsed IP as a string.", + "- Use `IP_Adress::Error()` to get the error message if an error occurred.", + "", + "**Example:** ", + "When combined with a database system such as Firebase Realtime Database, this extension can be used to implement IP-based bans. This allows developers to prevent users from rejoining a multiplayer lobby after engaging in fraudulent or disruptive behavior, ensuring a safer and more secure gameplay environment." + ], + "tags": [ + "IP", + "Network", + "Web Requests" + ], + "authorIds": [ + "15O5wfq5PBMlNvG7m04ZZx7ecgv1" + ], + "dependencies": [], + "globalVariables": [], + "sceneVariables": [ + { + "name": "__RequestValues", + "type": "structure", + "children": [ + { + "name": "Adress", + "type": "structure", + "children": [] + }, + { + "name": "Error", + "type": "string", + "value": "None" + }, + { + "name": "Response", + "type": "string", + "value": "None" + } + ] + } + ], + "eventsFunctions": [ + { + "description": "Send a web request to get the user's IP address and store the response values in variables.", + "fullName": "Get the user's public IP address", + "functionType": "Action", + "name": "GetIP", + "sentence": "Get the user's IP address", + "events": [ + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [], + "actions": [ + { + "type": { + "value": "SetStringVariable" + }, + "parameters": [ + "__RequestValues.Adress", + "=", + "\"\"" + ] + }, + { + "type": { + "value": "SetStringVariable" + }, + "parameters": [ + "__RequestValues.Error", + "=", + "\"None\"" + ] + }, + { + "type": { + "value": "SetStringVariable" + }, + "parameters": [ + "__RequestValues.Response", + "=", + "\"None\"" + ] + }, + { + "type": { + "await": true, + "value": "SendAsyncRequest" + }, + "parameters": [ + "\"https://api.ipify.org?format=json\"", + "\"\"", + "\"GET\"", + "\"\"", + "__RequestValues.Response", + "__RequestValues.Error" + ] + }, + { + "type": { + "value": "JSONToVariableStructure2" + }, + "parameters": [ + "__RequestValues.Response", + "__RequestValues.Adress" + ] + } + ] + } + ], + "parameters": [], + "objectGroups": [] + }, + { + "description": "Return the IP address of the current user.", + "fullName": "IP address of the user", + "functionType": "StringExpression", + "name": "Adress", + "sentence": "", + "events": [ + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [], + "actions": [ + { + "type": { + "value": "SetReturnString" + }, + "parameters": [ + "__RequestValues.Adress[\"ip\"]" + ] + } + ] + } + ], + "expressionType": { + "type": "string" + }, + "parameters": [], + "objectGroups": [] + }, + { + "description": "Errors if there are any.", + "fullName": "Displays any errors", + "functionType": "StringExpression", + "name": "Error", + "sentence": "", + "events": [ + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [], + "actions": [ + { + "type": { + "value": "SetReturnString" + }, + "parameters": [ + "__RequestValues.Error" + ] + } + ] + } + ], + "expressionType": { + "type": "string" + }, + "parameters": [], + "objectGroups": [] + }, + { + "description": "Check if the extension failed to get the user's IP address.", + "fullName": "Failed to get the user's IP address", + "functionType": "Condition", + "name": "HasFailed", + "sentence": "IP address could not be retrieved", + "events": [ + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [ + { + "type": { + "value": "StringVariable" + }, + "parameters": [ + "__RequestValues.Error", + "!=", + "\"None\"" + ] + } + ], + "actions": [ + { + "type": { + "value": "SetStringVariable" + }, + "parameters": [ + "__RequestValues.Error", + "=", + "\"Error: Failed to get the user's IP Adress.\"" + ] + }, + { + "type": { + "value": "SetReturnBoolean" + }, + "parameters": [ + "True" + ] + } + ] + }, + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [ + { + "type": { + "value": "StringVariable" + }, + "parameters": [ + "__RequestValues.Error", + "=", + "\"None\"" + ] + } + ], + "actions": [ + { + "type": { + "value": "SetReturnBoolean" + }, + "parameters": [ + "False" + ] + } + ] + } + ], + "parameters": [], + "objectGroups": [] + }, + { + "description": "Check if the IP address is ready to be used.", + "fullName": "IP address is ready", + "functionType": "Condition", + "name": "IsReady", + "sentence": "IP address is ready to be used", + "events": [ + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [ + { + "type": { + "value": "StringVariable" + }, + "parameters": [ + "__RequestValues.Adress[\"ip\"]", + "!=", + "\"\"" + ] + } + ], + "actions": [ + { + "type": { + "value": "SetReturnBoolean" + }, + "parameters": [ + "True" + ] + } + ] + }, + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [ + { + "type": { + "value": "StringVariable" + }, + "parameters": [ + "__RequestValues.Adress[\"ip\"]", + "=", + "\"\"" + ] + } + ], + "actions": [ + { + "type": { + "value": "SetReturnBoolean" + }, + "parameters": [ + "False" + ] + } + ] + } + ], + "parameters": [], + "objectGroups": [] + } + ], + "eventsBasedBehaviors": [], + "eventsBasedObjects": [] +} \ No newline at end of file