Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

AppKit is now part of the core solution #1259

Merged
merged 44 commits into from
Jan 16, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
9bd8f5c
Everything is broken
kantagara Dec 9, 2024
d0dda2a
Added AppKit directly inside of our package.
kantagara Dec 10, 2024
7253ed7
Merge branch 'dev' into nikola/appkit-implementation-1210
kantagara Dec 10, 2024
fe9281c
Merges from dev
kantagara Dec 10, 2024
2c2efa0
Small tweaks
kantagara Dec 10, 2024
febbb7e
Starting the process of creation of the app kit package
kantagara Dec 11, 2024
4267b2f
REsuming the work
kantagara Dec 11, 2024
0d03c4e
Package successfully created!
kantagara Dec 12, 2024
de35fce
Upgraded our Reown in core project to the newer version
kantagara Dec 12, 2024
92c10cd
Removed AppKit, made it part of the core package! Yay!
kantagara Dec 12, 2024
e15a222
Cleaning things up.
kantagara Dec 12, 2024
ca0ef84
Fixing bugs!
kantagara Dec 12, 2024
37c010b
Adding debug log
kantagara Dec 12, 2024
2c0a4d6
Added loader package.
kantagara Dec 12, 2024
e2c7ce9
Added newget dependency
kantagara Dec 12, 2024
aa313c8
More testing
kantagara Dec 12, 2024
89122bd
Hmm
kantagara Dec 12, 2024
f9d605a
MOre
kantagara Dec 12, 2024
eae619a
Final test!
kantagara Dec 12, 2024
13ec809
dont remove the loader one
kantagara Dec 12, 2024
9ea1121
Fix
kantagara Dec 12, 2024
06eda18
Fixing import bugs
kantagara Dec 13, 2024
dd86f48
Removing anything related to the new input system because it can caus…
kantagara Dec 13, 2024
c064f59
Removing metamask provider
kantagara Dec 13, 2024
79b5aa7
moved the playerprefs check to the constructor, if the user wants to …
kantagara Dec 13, 2024
d5b9c80
Fixing compiler errors
kantagara Dec 13, 2024
f02c3f5
Merge branch 'dev' into nikola/appkit-implementation-1210
kantagara Dec 13, 2024
7798a4c
Run setup.sh
kantagara Dec 13, 2024
f03a42e
Fixing All the PR suggestions
kantagara Dec 16, 2024
8d4eda4
Fixing signmessage bug.
kantagara Dec 16, 2024
8346157
More descriptive names for classes.
kantagara Dec 16, 2024
d4cd87c
Fixing error Juan got.
kantagara Dec 16, 2024
2348664
Reverted this since we're already in editor
kantagara Dec 16, 2024
a306524
Prebuild process for webgl.
kantagara Dec 16, 2024
30d94fb
Fixing compiler errors with non-webgl platforms
kantagara Dec 16, 2024
437db49
Fixing build errors finally.
kantagara Dec 16, 2024
a239e9d
Fixing the switch network bug.
kantagara Dec 16, 2024
91b1f88
Addressing Oleks comments, fixing web3 unity prefab
kantagara Dec 17, 2024
5d2c3f3
Updated appkit to 1.2.0
kantagara Jan 8, 2025
15c761b
Merge remote-tracking branch 'origin/dev' into nikola/appkit-implemen…
kantagara Jan 14, 2025
8ab4fd7
Merge branch 'dev' into nikola/appkit-implementation-1210
kantagara Jan 16, 2025
90e6523
Fixing errors.
kantagara Jan 16, 2025
ac5ca60
Merge branch 'dev' into nikola/appkit-implementation-1210
kantagara Jan 16, 2025
c555c11
Fixing Merge Conflicts
kantagara Jan 16, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file not shown.
12 changes: 12 additions & 0 deletions Packages/io.chainsafe.web3-unity.loader/Editor.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
using UnityEditor;
using UnityEngine;
using System.IO;
using System.Linq;
using System.Text;
using Newtonsoft.Json.Linq;

[InitializeOnLoad]
public static class ScopedRegistryAndDependencyInstaller
{
private static readonly string RegistryName = "package.openupm.com";
private static readonly string RegistryUrl = "https://package.openupm.com";
private static readonly string[] RequiredScopes =
{
"com.reown",
"com.nethereum.unity"
};

// The Git dependency to add
private const string ChainsafeDependencyKey = "io.chainsafe.web3-unity";
private const string ChainsafeLoaderDependencyKey = "io.chainsafe.web3-unity.loader";
private const string ChainsafeDependencyUrl = "https://github.com/ChainSafe/web3.unity.git?path=/Packages/io.chainsafe.web3-unity#nikola/appkit-implementation-1210";
creeppak marked this conversation as resolved.
Show resolved Hide resolved
private const string DependenciesKey = "Dependencies Installed";
static ScopedRegistryAndDependencyInstaller()
{
// Check if we've already installed the registry and dependencies
if (PlayerPrefs.GetInt(DependenciesKey, 0) == 1)
kantagara marked this conversation as resolved.
Show resolved Hide resolved
return;

InstallDependencies();
}

[MenuItem("Edit/Install dependencies")]
public static void InstallDependencies()
{

try
{
// Set EditorPref so we don't run again if we run into an error.
PlayerPrefs.SetInt(DependenciesKey, 1);
string manifestPath = Path.Combine(Application.dataPath, "../Packages/manifest.json");
string manifestJson = File.ReadAllText(manifestPath, Encoding.UTF8);
JObject manifest = JObject.Parse(manifestJson);

// Ensure scopedRegistries node exists
if (manifest["scopedRegistries"] == null)
{
manifest["scopedRegistries"] = new JArray();
}

var scopedRegistries = (JArray)manifest["scopedRegistries"];

// Find if our registry already exists
var existingRegistry = scopedRegistries
.OfType<JObject>()
.FirstOrDefault(r =>
r["name"] != null &&
r["name"].Value<string>().Equals(RegistryName, System.StringComparison.OrdinalIgnoreCase));

if (existingRegistry == null)
{
// Create a new registry entry
existingRegistry = new JObject
{
["name"] = RegistryName,
["url"] = RegistryUrl,
["scopes"] = new JArray(RequiredScopes)
};
scopedRegistries.Add(existingRegistry);
}
else
{
// Registry exists, ensure scopes are present
JArray scopesArray = (JArray)existingRegistry["scopes"];
var currentScopes = scopesArray.Select(s => s.Value<string>()).ToList();

foreach (var scope in RequiredScopes)
{
if (!currentScopes.Contains(scope))
{
scopesArray.Add(scope);
}
}
}

// Add the Chainsafe Git dependency
if (manifest["dependencies"] == null)
{
manifest["dependencies"] = new JObject();
}

JObject dependencies = (JObject)manifest["dependencies"];

// If not present or differs, add/update it
if (dependencies[ChainsafeDependencyKey] == null || dependencies[ChainsafeDependencyKey].Value<string>() != ChainsafeDependencyUrl)
{
dependencies[ChainsafeDependencyKey] = ChainsafeDependencyUrl;
}

dependencies.Remove(ChainsafeLoaderDependencyKey);

// Write changes back
File.WriteAllText(manifestPath, manifest.ToString(), Encoding.UTF8);


// Refresh to ensure Unity sees the new dependencies
AssetDatabase.Refresh();
// Clear the key because maybe some other project you get will have the same name so since all the things inside of the editor
// have been installed, you can be safely removed.
PlayerPrefs.DeleteKey(DependenciesKey);
}
catch (System.Exception ex)
{
Debug.LogError($"Failed to install scoped registries or Chainsafe dependency: {ex.Message}\n{ex.StackTrace}");
}
}
}

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
{
"name": "io.chainsafe.web3-unity.loader.editor",
"rootNamespace": "",
"references": [],
"includePlatforms": [
"Editor"
],
"excludePlatforms": [],
"allowUnsafeCode": false,
"overrideReferences": false,
"precompiledReferences": [],
"autoReferenced": true,
"defineConstraints": [],
"versionDefines": [],
"noEngineReferences": false
}

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

22 changes: 22 additions & 0 deletions Packages/io.chainsafe.web3-unity.loader/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
{
"name": "io.chainsafe.web3-unity.loader",
"version": "3.1.0",
"displayName": "web3.unity SDK Loader",
"description": "Loads chaisnafe sdk in unity from git.",
"license": "LGPL-3.0-only",
"licensesUrl": "https://github.com/ChainSafe/web3.unity/blob/main/LICENSE",
"documentationUrl": "https://docs.gaming.chainsafe.io/",
"dependencies": {
"com.unity.nuget.newtonsoft-json": "3.0.2"
},
"keywords": [
"web3",
"ethereum",
"evm"
],
"author": {
"name": "ChainSafe Gaming",
"email": "[email protected]",
"url": "https://gaming.chainsafe.io/"
}
}
7 changes: 7 additions & 0 deletions Packages/io.chainsafe.web3-unity.loader/package.json.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Binary file not shown.
Binary file not shown.
Binary file not shown.
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
#if UNITY_WEBGL
using ChainSafe.Gaming.UnityPackage.Connection;
using UnityEditor;
using UnityEditor.Build;
using UnityEditor.Build.Reporting;
using UnityEngine;

namespace ChainSafe.Gaming.Editor.Reown
{
public class ReownWebGLPreBuild : IPreprocessBuildWithReport
{
public int callbackOrder { get; }

public void OnPreprocessBuild(BuildReport report)
{
// Use AssetDatabase to load the TextAsset from Editor/Resources
string assetPath = "Packages/io.chainsafe.web3-unity/Editor/Resources/ViemChain.txt";
TextAsset file = AssetDatabase.LoadAssetAtPath<TextAsset>(assetPath);

if (file != null)
{
ReownConnectionProvider provider = Resources.Load<ReownConnectionProvider>("ReownConnectionProvider");
provider.PopulateViemNames(file.text);
}
else
{
Debug.LogError($"Could not load ViemChain.txt from path: {assetPath}");
}
}

}
}
#endif

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 8 additions & 0 deletions Packages/io.chainsafe.web3-unity/Editor/Resources.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading