mirror of
https://github.com/zhigang1992/react-native-code-push.git
synced 2026-05-19 19:39:54 +08:00
Added support react-native-windows dotNet Added example for react-native-windows UWP based Added example for react-native-windows dotNet based Project structure: CodePush.Shared - shared code between UWP and dotNet CodePush - UWP specific code CodePush.Net46 - dotNet specific code For UWP solution it needs to be added the following projects: CodePush.Shared CodePush For dotNet solution it needs to be added the following projects: CodePush.Shared CodePush.Net46 Examples: Examples\CodePushDemoApp\windows\CodePushDemoApp.sln the solution contains both examples (UWP and dotNet). Notes Example for ARM configuration has not been tested. Since there is no changes in UWP part of implementation, there is low risk of failure. In this implementation we tried to reuse UWP library as much as possible. The following issues are relevant for both platforms: ZipFile.ExtractToDirectory is not reliable and throws exception if: folder exists already path is too long (> 250 chars) Un-zipping is quite long operation. Does it make sense for async? await UpdateUtils.UnzipBundleAsync(downloadFile.Path, unzippedFolder.Path);
54 lines
1.5 KiB
C#
54 lines
1.5 KiB
C#
using Newtonsoft.Json.Linq;
|
|
using PCLStorage;
|
|
using System;
|
|
using System.Management;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace CodePush.ReactNative
|
|
{
|
|
internal partial class CodePushUtils
|
|
{
|
|
internal async static Task<JObject> GetJObjectFromFileAsync(IFile file)
|
|
{
|
|
string jsonString = await file.ReadAllTextAsync().ConfigureAwait(false);
|
|
if (jsonString.Length == 0)
|
|
{
|
|
return new JObject();
|
|
}
|
|
|
|
try
|
|
{
|
|
return JObject.Parse(jsonString);
|
|
}
|
|
catch (Exception)
|
|
{
|
|
return null;
|
|
}
|
|
}
|
|
|
|
static string GetDeviceIdImpl()
|
|
{
|
|
ManagementObjectSearcher mos = new ManagementObjectSearcher("SELECT * FROM Win32_BaseBoard");
|
|
ManagementObjectCollection moc = mos.Get();
|
|
string mbId = String.Empty;
|
|
foreach (ManagementObject mo in moc)
|
|
{
|
|
mbId = (string)mo["SerialNumber"];
|
|
break;
|
|
}
|
|
|
|
ManagementObjectCollection mbsList = null;
|
|
ManagementObjectSearcher mbs = new ManagementObjectSearcher("Select * From Win32_processor");
|
|
mbsList = mbs.Get();
|
|
string procId = string.Empty;
|
|
foreach (ManagementObject mo in mbsList)
|
|
{
|
|
procId = mo["ProcessorID"].ToString();
|
|
break;
|
|
}
|
|
|
|
return procId + "-" + mbId;
|
|
}
|
|
}
|
|
}
|