@appzung/react-native-code-push 9.0.2 → 10.0.0-rc1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CodePush.js +22 -19
- package/LICENSE.md +1 -1
- package/README.md +159 -298
- package/android/app/.gradle/config.properties +2 -0
- package/android/app/build.gradle +1 -1
- package/android/app/local.properties +8 -0
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePush.java +27 -21
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushBuilder.java +5 -5
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushConstants.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushDialog.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushInstallMode.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushInvalidPublicKeyException.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushInvalidUpdateException.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushMalformedDataException.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushNativeModule.java +5 -5
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushNotInitializedException.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushTelemetryManager.java +14 -14
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUnknownException.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUpdateManager.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUpdateState.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUpdateUtils.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUtils.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/DownloadProgress.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/DownloadProgressCallback.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/FileUtils.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/ReactInstanceHolder.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/SettingsManager.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/TLSSocketFactory.java +1 -1
- package/android/build.gradle +1 -1
- package/android/codepush.gradle +3 -3
- package/docs/advanced-usage.md +56 -0
- package/docs/api-android.md +12 -75
- package/docs/api-ios.md +5 -17
- package/docs/api-js.md +18 -55
- package/docs/setup-android.md +15 -397
- package/docs/setup-ios.md +24 -198
- package/docs/setup-windows.md +7 -74
- package/ios/CodePush/CodePush.h +4 -4
- package/ios/CodePush/CodePush.m +8 -8
- package/ios/CodePush/CodePushConfig.m +14 -11
- package/ios/CodePush/CodePushPackage.m +60 -60
- package/ios/CodePush/CodePushTelemetryManager.m +13 -13
- package/ios/CodePush.xcodeproj/project.pbxproj +1 -562
- package/package.json +27 -24
- package/react-native.config.js +1 -1
- package/scripts/generateBundledResourcesHash.js +1 -1
- package/scripts/getFilesInFolder.js +1 -1
- package/scripts/recordFilesBeforeBundleCommand.js +1 -1
- package/typings/react-native-code-push.d.ts +22 -22
- package/windows/CodePush/CodePushConfig.cpp +3 -3
- package/windows/CodePush/CodePushConfig.h +3 -3
- package/windows/CodePush/CodePushNativeModule.cpp +27 -27
- package/windows/CodePush/CodePushNativeModule.h +4 -4
- package/windows/CodePush/CodePushTelemetryManager.cpp +12 -12
- package/windows/CodePush/CodePushTelemetryManager.h +1 -1
- package/.azurepipelines/build-rn-code-push-1es.yml +0 -104
- package/.azurepipelines/test-rn-code-push.yml +0 -94
- package/.config/CredScanSuppressions.json +0 -14
- package/SECURITY.md +0 -41
- package/docs/multi-deployment-testing-android.md +0 -148
- package/docs/multi-deployment-testing-ios.md +0 -59
- package/ios/CodePush/Base64/Base64/MF_Base64Additions.h +0 -34
- package/ios/CodePush/Base64/Base64/MF_Base64Additions.m +0 -252
- package/ios/CodePush/Base64/README.md +0 -47
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithm.h +0 -69
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithmFactory.h +0 -16
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithmFactory.m +0 -51
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithmNone.h +0 -15
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithmNone.m +0 -55
- package/ios/CodePush/JWT/Core/Algorithms/ESFamily/JWTAlgorithmESBase.h +0 -24
- package/ios/CodePush/JWT/Core/Algorithms/ESFamily/JWTAlgorithmESBase.m +0 -41
- package/ios/CodePush/JWT/Core/Algorithms/HSFamily/JWTAlgorithmHSBase.h +0 -28
- package/ios/CodePush/JWT/Core/Algorithms/HSFamily/JWTAlgorithmHSBase.m +0 -205
- package/ios/CodePush/JWT/Core/Algorithms/Holders/JWTAlgorithmDataHolder.h +0 -103
- package/ios/CodePush/JWT/Core/Algorithms/Holders/JWTAlgorithmDataHolder.m +0 -322
- package/ios/CodePush/JWT/Core/Algorithms/Holders/JWTAlgorithmDataHolderChain.h +0 -37
- package/ios/CodePush/JWT/Core/Algorithms/Holders/JWTAlgorithmDataHolderChain.m +0 -145
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/JWTAlgorithmRSBase.h +0 -35
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/JWTAlgorithmRSBase.m +0 -551
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/JWTRSAlgorithm.h +0 -23
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoKey.h +0 -43
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoKey.m +0 -230
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoKeyExtractor.h +0 -31
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoKeyExtractor.m +0 -113
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoSecurity.h +0 -38
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoSecurity.m +0 -500
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaim.h +0 -18
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaim.m +0 -214
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSet.h +0 -23
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSet.m +0 -29
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSetSerializer.h +0 -19
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSetSerializer.m +0 -68
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSetVerifier.h +0 -18
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSetVerifier.m +0 -72
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+ResultTypes.h +0 -67
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+ResultTypes.m +0 -111
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionOne.h +0 -119
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionOne.m +0 -307
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionThree.h +0 -94
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionThree.m +0 -619
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionTwo.h +0 -164
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionTwo.m +0 -514
- package/ios/CodePush/JWT/Core/Coding/JWTCoding.h +0 -24
- package/ios/CodePush/JWT/Core/Coding/JWTCoding.m +0 -11
- package/ios/CodePush/JWT/Core/FrameworkSupplement/JWT.h +0 -52
- package/ios/CodePush/JWT/Core/FrameworkSupplement/Map.modulemap +0 -5
- package/ios/CodePush/JWT/Core/Supplement/JWTBase64Coder.h +0 -28
- package/ios/CodePush/JWT/Core/Supplement/JWTBase64Coder.m +0 -70
- package/ios/CodePush/JWT/Core/Supplement/JWTDeprecations.h +0 -22
- package/ios/CodePush/JWT/Core/Supplement/JWTErrorDescription.h +0 -34
- package/ios/CodePush/JWT/Core/Supplement/JWTErrorDescription.m +0 -73
- package/ios/CodePush/JWT/LICENSE +0 -19
- package/ios/CodePush/JWT/README.md +0 -489
- package/ios/CodePush/SSZipArchive/Info.plist +0 -26
- package/ios/CodePush/SSZipArchive/README.md +0 -1
- package/ios/CodePush/SSZipArchive/SSZipArchive.h +0 -178
- package/ios/CodePush/SSZipArchive/SSZipArchive.m +0 -1496
- package/ios/CodePush/SSZipArchive/SSZipCommon.h +0 -71
- package/ios/CodePush/SSZipArchive/Supporting Files/PrivacyInfo.xcprivacy +0 -23
- package/ios/CodePush/SSZipArchive/include/ZipArchive.h +0 -25
- package/ios/CodePush/SSZipArchive/minizip/LICENSE +0 -17
- package/ios/CodePush/SSZipArchive/minizip/mz.h +0 -273
- package/ios/CodePush/SSZipArchive/minizip/mz_compat.c +0 -1306
- package/ios/CodePush/SSZipArchive/minizip/mz_compat.h +0 -346
- package/ios/CodePush/SSZipArchive/minizip/mz_crypt.c +0 -187
- package/ios/CodePush/SSZipArchive/minizip/mz_crypt.h +0 -65
- package/ios/CodePush/SSZipArchive/minizip/mz_crypt_apple.c +0 -526
- package/ios/CodePush/SSZipArchive/minizip/mz_os.c +0 -348
- package/ios/CodePush/SSZipArchive/minizip/mz_os.h +0 -176
- package/ios/CodePush/SSZipArchive/minizip/mz_os_posix.c +0 -350
- package/ios/CodePush/SSZipArchive/minizip/mz_strm.c +0 -556
- package/ios/CodePush/SSZipArchive/minizip/mz_strm.h +0 -132
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_buf.c +0 -383
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_buf.h +0 -42
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_mem.c +0 -269
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_mem.h +0 -48
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_os.h +0 -40
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_os_posix.c +0 -203
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_pkcrypt.c +0 -334
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_pkcrypt.h +0 -46
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_split.c +0 -429
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_split.h +0 -43
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_wzaes.c +0 -360
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_wzaes.h +0 -46
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_zlib.c +0 -389
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_zlib.h +0 -43
- package/ios/CodePush/SSZipArchive/minizip/mz_zip.c +0 -2782
- package/ios/CodePush/SSZipArchive/minizip/mz_zip.h +0 -262
- package/ios/CodePush/SSZipArchive/minizip/mz_zip_rw.c +0 -1942
- package/ios/CodePush/SSZipArchive/minizip/mz_zip_rw.h +0 -285
- package/scripts/postlink/android/postlink.js +0 -87
- package/scripts/postlink/ios/postlink.js +0 -116
- package/scripts/postlink/run.js +0 -11
- package/scripts/postunlink/android/postunlink.js +0 -74
- package/scripts/postunlink/ios/postunlink.js +0 -87
- package/scripts/postunlink/run.js +0 -11
- package/scripts/tools/linkToolsAndroid.js +0 -57
- package/scripts/tools/linkToolsIos.js +0 -130
- package/windows-legacy/CodePush/CodePush.csproj +0 -128
- package/windows-legacy/CodePush/CodePushUtils.cs +0 -47
- package/windows-legacy/CodePush/FileUtils.cs +0 -40
- package/windows-legacy/CodePush/Properties/AssemblyInfo.cs +0 -29
- package/windows-legacy/CodePush/Properties/CodePush.rd.xml +0 -33
- package/windows-legacy/CodePush/UpdateManager.cs +0 -305
- package/windows-legacy/CodePush/UpdateUtils.cs +0 -46
- package/windows-legacy/CodePush.Net46/Adapters/Http/HttpProgress.cs +0 -28
- package/windows-legacy/CodePush.Net46/Adapters/Storage/ApplicationDataContainer.cs +0 -106
- package/windows-legacy/CodePush.Net46/CodePush.Net46.csproj +0 -103
- package/windows-legacy/CodePush.Net46/CodePushUtils.cs +0 -158
- package/windows-legacy/CodePush.Net46/FileUtils.cs +0 -55
- package/windows-legacy/CodePush.Net46/Properties/AssemblyInfo.cs +0 -36
- package/windows-legacy/CodePush.Net46/UpdateManager.cs +0 -330
- package/windows-legacy/CodePush.Net46/UpdateUtils.cs +0 -70
- package/windows-legacy/CodePush.Net46/packages.config +0 -5
- package/windows-legacy/CodePush.Net46.Test/ApplicationDataContainerTest.cs +0 -105
- package/windows-legacy/CodePush.Net46.Test/CodePush.Net46.Test.csproj +0 -137
- package/windows-legacy/CodePush.Net46.Test/Properties/AssemblyInfo.cs +0 -36
- package/windows-legacy/CodePush.Net46.Test/TelemetryManagerTest.cs +0 -117
- package/windows-legacy/CodePush.Net46.Test/app.config +0 -11
- package/windows-legacy/CodePush.Net46.Test/packages.config +0 -4
- package/windows-legacy/CodePush.Shared/CodePush.Shared.projitems +0 -22
- package/windows-legacy/CodePush.Shared/CodePush.Shared.shproj +0 -13
- package/windows-legacy/CodePush.Shared/CodePushConstants.cs +0 -35
- package/windows-legacy/CodePush.Shared/CodePushNativeModule.cs +0 -329
- package/windows-legacy/CodePush.Shared/CodePushReactPackage.cs +0 -235
- package/windows-legacy/CodePush.Shared/CodePushUtils.cs +0 -70
- package/windows-legacy/CodePush.Shared/InstallMode.cs +0 -9
- package/windows-legacy/CodePush.Shared/MinimumBackgroundListener.cs +0 -44
- package/windows-legacy/CodePush.Shared/SettingsManager.cs +0 -148
- package/windows-legacy/CodePush.Shared/TelemetryManager.cs +0 -250
- package/windows-legacy/CodePush.Shared/UpdateState.cs +0 -9
|
@@ -1,305 +0,0 @@
|
|
|
1
|
-
using Newtonsoft.Json;
|
|
2
|
-
using Newtonsoft.Json.Linq;
|
|
3
|
-
using System;
|
|
4
|
-
using System.IO;
|
|
5
|
-
using System.IO.Compression;
|
|
6
|
-
using System.Threading;
|
|
7
|
-
using System.Threading.Tasks;
|
|
8
|
-
using Windows.Storage;
|
|
9
|
-
using Windows.Storage.Streams;
|
|
10
|
-
using Windows.Web.Http;
|
|
11
|
-
|
|
12
|
-
namespace CodePush.ReactNative
|
|
13
|
-
{
|
|
14
|
-
internal class UpdateManager
|
|
15
|
-
{
|
|
16
|
-
#region Internal methods
|
|
17
|
-
|
|
18
|
-
internal async Task ClearUpdatesAsync()
|
|
19
|
-
{
|
|
20
|
-
await (await GetCodePushFolderAsync().ConfigureAwait(false)).DeleteAsync().AsTask().ConfigureAwait(false);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
internal async Task DownloadPackageAsync(JObject updatePackage, string expectedBundleFileName, Progress<HttpProgress> downloadProgress)
|
|
24
|
-
{
|
|
25
|
-
// Using its hash, get the folder where the new update will be saved
|
|
26
|
-
StorageFolder codePushFolder = await GetCodePushFolderAsync().ConfigureAwait(false);
|
|
27
|
-
var newUpdateHash = (string)updatePackage[CodePushConstants.PackageHashKey];
|
|
28
|
-
StorageFolder newUpdateFolder = await GetPackageFolderAsync(newUpdateHash, false).ConfigureAwait(false);
|
|
29
|
-
if (newUpdateFolder != null)
|
|
30
|
-
{
|
|
31
|
-
// This removes any stale data in newUpdateFolder that could have been left
|
|
32
|
-
// uncleared due to a crash or error during the download or install process.
|
|
33
|
-
await newUpdateFolder.DeleteAsync().AsTask().ConfigureAwait(false);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
newUpdateFolder = await GetPackageFolderAsync(newUpdateHash, true).ConfigureAwait(false);
|
|
37
|
-
StorageFile newUpdateMetadataFile = await newUpdateFolder.CreateFileAsync(CodePushConstants.PackageFileName).AsTask().ConfigureAwait(false);
|
|
38
|
-
var downloadUrlString = (string)updatePackage[CodePushConstants.DownloadUrlKey];
|
|
39
|
-
StorageFile downloadFile = await GetDownloadFileAsync().ConfigureAwait(false);
|
|
40
|
-
var downloadUri = new Uri(downloadUrlString);
|
|
41
|
-
|
|
42
|
-
// Download the file and send progress event asynchronously
|
|
43
|
-
var request = new HttpRequestMessage(HttpMethod.Get, downloadUri);
|
|
44
|
-
var client = new HttpClient();
|
|
45
|
-
var cancellationTokenSource = new CancellationTokenSource();
|
|
46
|
-
using (HttpResponseMessage response = await client.SendRequestAsync(request).AsTask(cancellationTokenSource.Token, downloadProgress).ConfigureAwait(false))
|
|
47
|
-
using (IInputStream inputStream = await response.Content.ReadAsInputStreamAsync().AsTask().ConfigureAwait(false))
|
|
48
|
-
using (IRandomAccessStream downloadFileStream = await downloadFile.OpenAsync(FileAccessMode.ReadWrite).AsTask().ConfigureAwait(false))
|
|
49
|
-
{
|
|
50
|
-
await RandomAccessStream.CopyAsync(inputStream, downloadFileStream).AsTask().ConfigureAwait(false);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
try
|
|
54
|
-
{
|
|
55
|
-
// Unzip the downloaded file and then delete the zip
|
|
56
|
-
StorageFolder unzippedFolder = await CreateUnzippedFolderAsync().ConfigureAwait(false);
|
|
57
|
-
ZipFile.ExtractToDirectory(downloadFile.Path, unzippedFolder.Path);
|
|
58
|
-
await downloadFile.DeleteAsync().AsTask().ConfigureAwait(false);
|
|
59
|
-
|
|
60
|
-
// Merge contents with current update based on the manifest
|
|
61
|
-
StorageFile diffManifestFile = (StorageFile)await unzippedFolder.TryGetItemAsync(CodePushConstants.DiffManifestFileName).AsTask().ConfigureAwait(false);
|
|
62
|
-
if (diffManifestFile != null)
|
|
63
|
-
{
|
|
64
|
-
StorageFolder currentPackageFolder = await GetCurrentPackageFolderAsync().ConfigureAwait(false);
|
|
65
|
-
if (currentPackageFolder == null)
|
|
66
|
-
{
|
|
67
|
-
throw new InvalidDataException("Received a diff update, but there is no current version to diff against.");
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
await UpdateUtils.CopyNecessaryFilesFromCurrentPackageAsync(diffManifestFile, currentPackageFolder, newUpdateFolder).ConfigureAwait(false);
|
|
71
|
-
await diffManifestFile.DeleteAsync().AsTask().ConfigureAwait(false);
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
await FileUtils.MergeFoldersAsync(unzippedFolder, newUpdateFolder).ConfigureAwait(false);
|
|
75
|
-
await unzippedFolder.DeleteAsync().AsTask().ConfigureAwait(false);
|
|
76
|
-
|
|
77
|
-
// For zip updates, we need to find the relative path to the jsBundle and save it in the
|
|
78
|
-
// metadata so that we can find and run it easily the next time.
|
|
79
|
-
string relativeBundlePath = await UpdateUtils.FindJSBundleInUpdateContentsAsync(newUpdateFolder, expectedBundleFileName).ConfigureAwait(false);
|
|
80
|
-
if (relativeBundlePath == null)
|
|
81
|
-
{
|
|
82
|
-
throw new InvalidDataException("Update is invalid - A JS bundle file named \"" + expectedBundleFileName + "\" could not be found within the downloaded contents. Please check that you are releasing your CodePush updates using the exact same JS bundle file name that was shipped with your app's binary.");
|
|
83
|
-
}
|
|
84
|
-
else
|
|
85
|
-
{
|
|
86
|
-
if (diffManifestFile != null)
|
|
87
|
-
{
|
|
88
|
-
// TODO verify hash for diff update
|
|
89
|
-
// CodePushUpdateUtils.verifyHashForDiffUpdate(newUpdateFolderPath, newUpdateHash);
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
updatePackage[CodePushConstants.RelativeBundlePathKey] = relativeBundlePath;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
catch (InvalidDataException)
|
|
96
|
-
{
|
|
97
|
-
// Downloaded file is not a zip, assume it is a jsbundle
|
|
98
|
-
await downloadFile.RenameAsync(expectedBundleFileName).AsTask().ConfigureAwait(false);
|
|
99
|
-
await downloadFile.MoveAsync(newUpdateFolder).AsTask().ConfigureAwait(false);
|
|
100
|
-
}
|
|
101
|
-
/*TODO: ZipFile.ExtractToDirectory is not reliable and throws exceptions if:
|
|
102
|
-
- path is too long
|
|
103
|
-
it needs to be handled
|
|
104
|
-
*/
|
|
105
|
-
|
|
106
|
-
// Save metadata to the folder
|
|
107
|
-
await FileIO.WriteTextAsync(newUpdateMetadataFile, JsonConvert.SerializeObject(updatePackage)).AsTask().ConfigureAwait(false);
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
internal async Task<JObject> GetCurrentPackageAsync()
|
|
111
|
-
{
|
|
112
|
-
string packageHash = await GetCurrentPackageHashAsync().ConfigureAwait(false);
|
|
113
|
-
return packageHash == null ? null : await GetPackageAsync(packageHash).ConfigureAwait(false);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
internal async Task<StorageFile> GetCurrentPackageBundleAsync(string bundleFileName)
|
|
117
|
-
{
|
|
118
|
-
StorageFolder packageFolder = await GetCurrentPackageFolderAsync().ConfigureAwait(false);
|
|
119
|
-
if (packageFolder == null)
|
|
120
|
-
{
|
|
121
|
-
return null;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
JObject currentPackage = await GetCurrentPackageAsync().ConfigureAwait(false);
|
|
125
|
-
var relativeBundlePath = (string)currentPackage[CodePushConstants.RelativeBundlePathKey];
|
|
126
|
-
|
|
127
|
-
return relativeBundlePath == null
|
|
128
|
-
? await packageFolder.GetFileAsync(bundleFileName).AsTask().ConfigureAwait(false)
|
|
129
|
-
: await packageFolder.GetFileAsync(relativeBundlePath).AsTask().ConfigureAwait(false);
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
internal async Task<string> GetCurrentPackageHashAsync()
|
|
133
|
-
{
|
|
134
|
-
JObject info = await GetCurrentPackageInfoAsync().ConfigureAwait(false);
|
|
135
|
-
string currentPackageShortHash = (string)info[CodePushConstants.CurrentPackageKey];
|
|
136
|
-
if (currentPackageShortHash == null)
|
|
137
|
-
{
|
|
138
|
-
return null;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
JObject currentPackageMetadata = await GetPackageAsync(currentPackageShortHash).ConfigureAwait(false);
|
|
142
|
-
return currentPackageMetadata == null ? null : (string)currentPackageMetadata[CodePushConstants.PackageHashKey];
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
internal async Task<JObject> GetPackageAsync(string packageHash)
|
|
146
|
-
{
|
|
147
|
-
StorageFolder packageFolder = await GetPackageFolderAsync(packageHash, false).ConfigureAwait(false);
|
|
148
|
-
if (packageFolder == null)
|
|
149
|
-
{
|
|
150
|
-
return null;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
try
|
|
154
|
-
{
|
|
155
|
-
StorageFile packageFile = await packageFolder.GetFileAsync(CodePushConstants.PackageFileName).AsTask().ConfigureAwait(false);
|
|
156
|
-
return await CodePushUtils.GetJObjectFromFileAsync(packageFile).ConfigureAwait(false);
|
|
157
|
-
}
|
|
158
|
-
catch (IOException)
|
|
159
|
-
{
|
|
160
|
-
return null;
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
internal async Task<StorageFolder> GetPackageFolderAsync(string packageHash, bool createIfNotExists)
|
|
165
|
-
{
|
|
166
|
-
StorageFolder codePushFolder = await GetCodePushFolderAsync().ConfigureAwait(false);
|
|
167
|
-
try
|
|
168
|
-
{
|
|
169
|
-
packageHash = ShortenPackageHash(packageHash);
|
|
170
|
-
return createIfNotExists
|
|
171
|
-
? await codePushFolder.CreateFolderAsync(packageHash, CreationCollisionOption.OpenIfExists).AsTask().ConfigureAwait(false)
|
|
172
|
-
: await codePushFolder.GetFolderAsync(packageHash).AsTask().ConfigureAwait(false);
|
|
173
|
-
}
|
|
174
|
-
catch (FileNotFoundException)
|
|
175
|
-
{
|
|
176
|
-
return null;
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
internal async Task<JObject> GetPreviousPackageAsync()
|
|
181
|
-
{
|
|
182
|
-
string packageHash = await GetPreviousPackageHashAsync().ConfigureAwait(false);
|
|
183
|
-
return packageHash == null ? null : await GetPackageAsync(packageHash).ConfigureAwait(false);
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
internal async Task<string> GetPreviousPackageHashAsync()
|
|
187
|
-
{
|
|
188
|
-
JObject info = await GetCurrentPackageInfoAsync().ConfigureAwait(false);
|
|
189
|
-
string previousPackageShortHash = (string)info[CodePushConstants.PreviousPackageKey];
|
|
190
|
-
if (previousPackageShortHash == null)
|
|
191
|
-
{
|
|
192
|
-
return null;
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
JObject previousPackageMetadata = await GetPackageAsync(previousPackageShortHash).ConfigureAwait(false);
|
|
196
|
-
return previousPackageMetadata == null ? null : (string)previousPackageMetadata[CodePushConstants.PackageHashKey];
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
internal async Task InstallPackageAsync(JObject updatePackage, bool currentUpdateIsPending)
|
|
200
|
-
{
|
|
201
|
-
var packageHash = (string)updatePackage[CodePushConstants.PackageHashKey];
|
|
202
|
-
JObject info = await GetCurrentPackageInfoAsync().ConfigureAwait(false);
|
|
203
|
-
if (currentUpdateIsPending)
|
|
204
|
-
{
|
|
205
|
-
// Don't back up current update to the "previous" position because
|
|
206
|
-
// it is an unverified update which should not be rolled back to.
|
|
207
|
-
StorageFolder currentPackageFolder = await GetCurrentPackageFolderAsync().ConfigureAwait(false);
|
|
208
|
-
if (currentPackageFolder != null)
|
|
209
|
-
{
|
|
210
|
-
await currentPackageFolder.DeleteAsync().AsTask().ConfigureAwait(false);
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
else
|
|
214
|
-
{
|
|
215
|
-
string previousPackageHash = await GetPreviousPackageHashAsync().ConfigureAwait(false);
|
|
216
|
-
if (previousPackageHash != null && !previousPackageHash.Equals(packageHash))
|
|
217
|
-
{
|
|
218
|
-
StorageFolder previousPackageFolder = await GetPackageFolderAsync(previousPackageHash, false).ConfigureAwait(false);
|
|
219
|
-
if (previousPackageFolder != null)
|
|
220
|
-
{
|
|
221
|
-
await previousPackageFolder.DeleteAsync().AsTask().ConfigureAwait(false);
|
|
222
|
-
}
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
info[CodePushConstants.PreviousPackageKey] = info[CodePushConstants.CurrentPackageKey];
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
info[CodePushConstants.CurrentPackageKey] = packageHash;
|
|
229
|
-
await UpdateCurrentPackageInfoAsync(info).ConfigureAwait(false);
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
internal async Task RollbackPackageAsync()
|
|
233
|
-
{
|
|
234
|
-
JObject info = await GetCurrentPackageInfoAsync().ConfigureAwait(false);
|
|
235
|
-
StorageFolder currentPackageFolder = await GetCurrentPackageFolderAsync().ConfigureAwait(false);
|
|
236
|
-
if (currentPackageFolder != null)
|
|
237
|
-
{
|
|
238
|
-
await currentPackageFolder.DeleteAsync().AsTask().ConfigureAwait(false);
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
info[CodePushConstants.CurrentPackageKey] = info[CodePushConstants.PreviousPackageKey];
|
|
242
|
-
info[CodePushConstants.PreviousPackageKey] = null;
|
|
243
|
-
await UpdateCurrentPackageInfoAsync(info).ConfigureAwait(false);
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
#endregion
|
|
247
|
-
|
|
248
|
-
#region Private methods
|
|
249
|
-
|
|
250
|
-
private async Task<StorageFolder> GetCodePushFolderAsync()
|
|
251
|
-
{
|
|
252
|
-
return await ApplicationData.Current.LocalFolder.CreateFolderAsync(CodePushConstants.CodePushFolderPrefix, CreationCollisionOption.OpenIfExists).AsTask().ConfigureAwait(false);
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
private async Task<StorageFolder> GetCurrentPackageFolderAsync()
|
|
256
|
-
{
|
|
257
|
-
JObject info = await GetCurrentPackageInfoAsync().ConfigureAwait(false);
|
|
258
|
-
var packageHash = (string)info[CodePushConstants.CurrentPackageKey];
|
|
259
|
-
return packageHash == null ? null : await GetPackageFolderAsync(packageHash, false).ConfigureAwait(false);
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
private async Task<JObject> GetCurrentPackageInfoAsync()
|
|
263
|
-
{
|
|
264
|
-
StorageFile statusFile = await GetStatusFileAsync().ConfigureAwait(false);
|
|
265
|
-
return await CodePushUtils.GetJObjectFromFileAsync(statusFile).ConfigureAwait(false);
|
|
266
|
-
}
|
|
267
|
-
|
|
268
|
-
private async Task<StorageFile> GetDownloadFileAsync()
|
|
269
|
-
{
|
|
270
|
-
var codePushFolder = await GetCodePushFolderAsync().ConfigureAwait(false);
|
|
271
|
-
return await codePushFolder.CreateFileAsync(CodePushConstants.DownloadFileName, CreationCollisionOption.OpenIfExists).AsTask().ConfigureAwait(false);
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
private async Task<StorageFile> GetStatusFileAsync()
|
|
275
|
-
{
|
|
276
|
-
StorageFolder codePushFolder = await GetCodePushFolderAsync().ConfigureAwait(false);
|
|
277
|
-
return await codePushFolder.CreateFileAsync(CodePushConstants.StatusFileName, CreationCollisionOption.OpenIfExists).AsTask().ConfigureAwait(false);
|
|
278
|
-
}
|
|
279
|
-
|
|
280
|
-
private async Task<StorageFolder> CreateUnzippedFolderAsync()
|
|
281
|
-
{
|
|
282
|
-
StorageFolder codePushFolder = await GetCodePushFolderAsync().ConfigureAwait(false);
|
|
283
|
-
var unzippedFolder = await codePushFolder.TryGetItemAsync(CodePushConstants.UnzippedFolderName).AsTask().ConfigureAwait(false);
|
|
284
|
-
|
|
285
|
-
if (unzippedFolder != null)
|
|
286
|
-
{
|
|
287
|
-
await unzippedFolder.DeleteAsync();
|
|
288
|
-
}
|
|
289
|
-
|
|
290
|
-
return await codePushFolder.CreateFolderAsync(CodePushConstants.UnzippedFolderName, CreationCollisionOption.OpenIfExists).AsTask().ConfigureAwait(false);
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
private string ShortenPackageHash(string longPackageHash)
|
|
294
|
-
{
|
|
295
|
-
return longPackageHash.Substring(0, 8);
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
private async Task UpdateCurrentPackageInfoAsync(JObject packageInfo)
|
|
299
|
-
{
|
|
300
|
-
await FileIO.WriteTextAsync(await GetStatusFileAsync().ConfigureAwait(false), JsonConvert.SerializeObject(packageInfo)).AsTask().ConfigureAwait(false);
|
|
301
|
-
}
|
|
302
|
-
|
|
303
|
-
#endregion
|
|
304
|
-
}
|
|
305
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
using Newtonsoft.Json.Linq;
|
|
2
|
-
using System;
|
|
3
|
-
using System.IO;
|
|
4
|
-
using System.Threading.Tasks;
|
|
5
|
-
using Windows.Storage;
|
|
6
|
-
|
|
7
|
-
namespace CodePush.ReactNative
|
|
8
|
-
{
|
|
9
|
-
internal class UpdateUtils
|
|
10
|
-
{
|
|
11
|
-
internal async static Task CopyNecessaryFilesFromCurrentPackageAsync(StorageFile diffManifestFile, StorageFolder currentPackageFolder, StorageFolder newPackageFolder)
|
|
12
|
-
{
|
|
13
|
-
await FileUtils.MergeFoldersAsync(currentPackageFolder, newPackageFolder).ConfigureAwait(false);
|
|
14
|
-
JObject diffManifest = await CodePushUtils.GetJObjectFromFileAsync(diffManifestFile).ConfigureAwait(false);
|
|
15
|
-
var deletedFiles = (JArray)diffManifest["deletedFiles"];
|
|
16
|
-
foreach (string fileNameToDelete in deletedFiles)
|
|
17
|
-
{
|
|
18
|
-
StorageFile fileToDelete = await newPackageFolder.GetFileAsync(fileNameToDelete.Replace("/", "\\")).AsTask().ConfigureAwait(false);
|
|
19
|
-
await fileToDelete.DeleteAsync().AsTask().ConfigureAwait(false);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
internal async static Task<string> FindJSBundleInUpdateContentsAsync(StorageFolder updateFolder, string expectedFileName)
|
|
24
|
-
{
|
|
25
|
-
foreach (StorageFile file in await updateFolder.GetFilesAsync().AsTask().ConfigureAwait(false))
|
|
26
|
-
{
|
|
27
|
-
string fileName = file.Name;
|
|
28
|
-
if (fileName.Equals(expectedFileName))
|
|
29
|
-
{
|
|
30
|
-
return fileName;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
foreach (StorageFolder folder in await updateFolder.GetFoldersAsync().AsTask().ConfigureAwait(false))
|
|
35
|
-
{
|
|
36
|
-
string mainBundlePathInSubFolder = await FindJSBundleInUpdateContentsAsync(folder, expectedFileName).ConfigureAwait(false);
|
|
37
|
-
if (mainBundlePathInSubFolder != null)
|
|
38
|
-
{
|
|
39
|
-
return Path.Combine(folder.Name, mainBundlePathInSubFolder);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
return null;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
using System;
|
|
2
|
-
|
|
3
|
-
namespace CodePush.Net46.Adapters.Http
|
|
4
|
-
{
|
|
5
|
-
public enum HttpProgressStage
|
|
6
|
-
{
|
|
7
|
-
None = 0,
|
|
8
|
-
DetectingProxy = 10,
|
|
9
|
-
ResolvingName = 20,
|
|
10
|
-
ConnectingToServer = 30,
|
|
11
|
-
NegotiatingSsl = 40,
|
|
12
|
-
SendingHeaders = 50,
|
|
13
|
-
SendingContent = 60,
|
|
14
|
-
WaitingForResponse = 70,
|
|
15
|
-
ReceivingHeaders = 80,
|
|
16
|
-
ReceivingContent = 90
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
public struct HttpProgress
|
|
20
|
-
{
|
|
21
|
-
public UInt64 BytesReceived;
|
|
22
|
-
public UInt64 BytesSent;
|
|
23
|
-
public UInt32 Retries;
|
|
24
|
-
public HttpProgressStage Stage;
|
|
25
|
-
public UInt64? TotalBytesToReceive;
|
|
26
|
-
public UInt64? TotalBytesToSend;
|
|
27
|
-
}
|
|
28
|
-
}
|
|
@@ -1,106 +0,0 @@
|
|
|
1
|
-
using CodePush.ReactNative;
|
|
2
|
-
using Newtonsoft.Json;
|
|
3
|
-
using Newtonsoft.Json.Linq;
|
|
4
|
-
using PCLStorage;
|
|
5
|
-
using System;
|
|
6
|
-
using System.Collections.Generic;
|
|
7
|
-
using System.Threading;
|
|
8
|
-
using System.Threading.Tasks;
|
|
9
|
-
|
|
10
|
-
namespace CodePush.Net46.Adapters.Storage
|
|
11
|
-
{
|
|
12
|
-
public enum ApplicationDataCreateDisposition
|
|
13
|
-
{
|
|
14
|
-
Always = 0,
|
|
15
|
-
Existing = 1
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
public class DictionaryWithDefault<TKey, TValue> : Dictionary<TKey, TValue>
|
|
19
|
-
{
|
|
20
|
-
TValue _default;
|
|
21
|
-
public TValue DefaultValue
|
|
22
|
-
{
|
|
23
|
-
get { return _default; }
|
|
24
|
-
set { _default = value; }
|
|
25
|
-
}
|
|
26
|
-
public DictionaryWithDefault() : base() { }
|
|
27
|
-
public DictionaryWithDefault(TValue defaultValue) : base()
|
|
28
|
-
{
|
|
29
|
-
_default = defaultValue;
|
|
30
|
-
}
|
|
31
|
-
public new TValue this[TKey key]
|
|
32
|
-
{
|
|
33
|
-
get
|
|
34
|
-
{
|
|
35
|
-
TValue t;
|
|
36
|
-
return base.TryGetValue(key, out t) ? t : _default;
|
|
37
|
-
}
|
|
38
|
-
set
|
|
39
|
-
{
|
|
40
|
-
base[key] = value;
|
|
41
|
-
DataChanged(this, null);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
public new bool Remove(TKey key)
|
|
46
|
-
{
|
|
47
|
-
var found = base.Remove(key);
|
|
48
|
-
if (found)
|
|
49
|
-
DataChanged(this, null);
|
|
50
|
-
|
|
51
|
-
return found;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
public event EventHandler DataChanged;
|
|
55
|
-
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
// A naive implementation of Windows.Storage.ApplicationDataContainer
|
|
59
|
-
public class ApplicationDataContainer
|
|
60
|
-
{
|
|
61
|
-
public DictionaryWithDefault<string, string> Values;
|
|
62
|
-
private readonly SemaphoreSlim mutex = new SemaphoreSlim(1, 1);
|
|
63
|
-
|
|
64
|
-
const string STORAGE_NAME = "AppStorage.data";
|
|
65
|
-
string storageFileName = null;
|
|
66
|
-
|
|
67
|
-
public ApplicationDataContainer(string name = STORAGE_NAME)
|
|
68
|
-
{
|
|
69
|
-
storageFileName = name;
|
|
70
|
-
var storageFile = FileSystem.Current.LocalStorage.CreateFileAsync(storageFileName, CreationCollisionOption.OpenIfExists).Result;
|
|
71
|
-
var data = CodePushUtils.GetJObjectFromFileAsync(storageFile).Result;
|
|
72
|
-
|
|
73
|
-
if (data != null)
|
|
74
|
-
{
|
|
75
|
-
Values = data.ToObject<DictionaryWithDefault<string, string>>();
|
|
76
|
-
}
|
|
77
|
-
else
|
|
78
|
-
{
|
|
79
|
-
Values = new DictionaryWithDefault<string, string>();
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
Values.DataChanged += async (s, e) => await SaveAsync();
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
~ApplicationDataContainer()
|
|
86
|
-
{
|
|
87
|
-
mutex.Dispose();
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
async Task SaveAsync()
|
|
91
|
-
{
|
|
92
|
-
await mutex.WaitAsync().ConfigureAwait(false);
|
|
93
|
-
var jobject = JObject.FromObject(Values);
|
|
94
|
-
var storageFile = await FileSystem.Current.LocalStorage.CreateFileAsync(storageFileName, CreationCollisionOption.OpenIfExists).ConfigureAwait(false);
|
|
95
|
-
await storageFile.WriteAllTextAsync(JsonConvert.SerializeObject(jobject)).ConfigureAwait(false);
|
|
96
|
-
mutex.Release();
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
public async Task DeleteAsync()
|
|
100
|
-
{
|
|
101
|
-
Values.Clear();
|
|
102
|
-
var storageFile = await FileSystem.Current.LocalStorage.CreateFileAsync(storageFileName, CreationCollisionOption.OpenIfExists).ConfigureAwait(false);
|
|
103
|
-
await storageFile.DeleteAsync().ConfigureAwait(false);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
}
|
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
<?xml version="1.0" encoding="utf-8"?>
|
|
2
|
-
<Project ToolsVersion="14.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
|
3
|
-
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
|
|
4
|
-
<PropertyGroup>
|
|
5
|
-
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
|
6
|
-
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
|
7
|
-
<ProjectGuid>{4DFE3F9F-5E15-4F17-8FD4-33FF0519348E}</ProjectGuid>
|
|
8
|
-
<OutputType>Library</OutputType>
|
|
9
|
-
<AppDesignerFolder>Properties</AppDesignerFolder>
|
|
10
|
-
<RootNamespace>CodePush.Net46</RootNamespace>
|
|
11
|
-
<AssemblyName>CodePush.Net46</AssemblyName>
|
|
12
|
-
<TargetFrameworkVersion>v4.6</TargetFrameworkVersion>
|
|
13
|
-
<FileAlignment>512</FileAlignment>
|
|
14
|
-
<TargetFrameworkProfile />
|
|
15
|
-
</PropertyGroup>
|
|
16
|
-
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'">
|
|
17
|
-
<DebugSymbols>true</DebugSymbols>
|
|
18
|
-
<OutputPath>bin\x86\Debug\</OutputPath>
|
|
19
|
-
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
|
20
|
-
<DebugType>full</DebugType>
|
|
21
|
-
<PlatformTarget>x86</PlatformTarget>
|
|
22
|
-
<ErrorReport>prompt</ErrorReport>
|
|
23
|
-
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
|
24
|
-
</PropertyGroup>
|
|
25
|
-
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x86'">
|
|
26
|
-
<OutputPath>bin\x86\Release\</OutputPath>
|
|
27
|
-
<DefineConstants>TRACE</DefineConstants>
|
|
28
|
-
<Optimize>true</Optimize>
|
|
29
|
-
<DebugType>pdbonly</DebugType>
|
|
30
|
-
<PlatformTarget>x86</PlatformTarget>
|
|
31
|
-
<ErrorReport>prompt</ErrorReport>
|
|
32
|
-
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
|
33
|
-
</PropertyGroup>
|
|
34
|
-
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x64'">
|
|
35
|
-
<DebugSymbols>true</DebugSymbols>
|
|
36
|
-
<OutputPath>bin\x64\Debug\</OutputPath>
|
|
37
|
-
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
|
38
|
-
<DebugType>full</DebugType>
|
|
39
|
-
<PlatformTarget>x64</PlatformTarget>
|
|
40
|
-
<ErrorReport>prompt</ErrorReport>
|
|
41
|
-
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
|
42
|
-
</PropertyGroup>
|
|
43
|
-
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Release|x64'">
|
|
44
|
-
<OutputPath>bin\x64\Release\</OutputPath>
|
|
45
|
-
<DefineConstants>TRACE</DefineConstants>
|
|
46
|
-
<Optimize>true</Optimize>
|
|
47
|
-
<DebugType>pdbonly</DebugType>
|
|
48
|
-
<PlatformTarget>x64</PlatformTarget>
|
|
49
|
-
<ErrorReport>prompt</ErrorReport>
|
|
50
|
-
<CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet>
|
|
51
|
-
</PropertyGroup>
|
|
52
|
-
<ItemGroup>
|
|
53
|
-
<Reference Include="Newtonsoft.Json, Version=13.0.1.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL">
|
|
54
|
-
<HintPath>$(SolutionDir)\packages\Newtonsoft.Json.13.0.1\lib\net45\Newtonsoft.Json.dll</HintPath>
|
|
55
|
-
<Private>True</Private>
|
|
56
|
-
</Reference>
|
|
57
|
-
<Reference Include="PCLStorage, Version=1.0.2.0, Culture=neutral, PublicKeyToken=286fe515a2c35b64, processorArchitecture=MSIL">
|
|
58
|
-
<SpecificVersion>False</SpecificVersion>
|
|
59
|
-
<HintPath>$(SolutionDir)\packages\PCLStorage.1.0.2\lib\net45\PCLStorage.dll</HintPath>
|
|
60
|
-
<Private>True</Private>
|
|
61
|
-
</Reference>
|
|
62
|
-
<Reference Include="PCLStorage.Abstractions, Version=1.0.2.0, Culture=neutral, PublicKeyToken=286fe515a2c35b64, processorArchitecture=MSIL">
|
|
63
|
-
<SpecificVersion>False</SpecificVersion>
|
|
64
|
-
<HintPath>$(SolutionDir)\packages\PCLStorage.1.0.2\lib\net45\PCLStorage.Abstractions.dll</HintPath>
|
|
65
|
-
<Private>True</Private>
|
|
66
|
-
</Reference>
|
|
67
|
-
<Reference Include="System" />
|
|
68
|
-
<Reference Include="System.Core" />
|
|
69
|
-
<Reference Include="System.IO.Compression" />
|
|
70
|
-
<Reference Include="System.IO.Compression.FileSystem" />
|
|
71
|
-
<Reference Include="System.Management" />
|
|
72
|
-
<Reference Include="System.Data.DataSetExtensions" />
|
|
73
|
-
<Reference Include="System.Data" />
|
|
74
|
-
<Reference Include="System.Net.Http" />
|
|
75
|
-
</ItemGroup>
|
|
76
|
-
<ItemGroup>
|
|
77
|
-
<Compile Include="Adapters\Http\HttpProgress.cs" />
|
|
78
|
-
<Compile Include="Adapters\Storage\ApplicationDataContainer.cs" />
|
|
79
|
-
<Compile Include="CodePushUtils.cs" />
|
|
80
|
-
<Compile Include="FileUtils.cs" />
|
|
81
|
-
<Compile Include="Properties\AssemblyInfo.cs" />
|
|
82
|
-
<Compile Include="UpdateManager.cs" />
|
|
83
|
-
<Compile Include="UpdateUtils.cs" />
|
|
84
|
-
</ItemGroup>
|
|
85
|
-
<ItemGroup>
|
|
86
|
-
<None Include="packages.config" />
|
|
87
|
-
</ItemGroup>
|
|
88
|
-
<ItemGroup>
|
|
89
|
-
<ProjectReference Include="..\..\..\react-native-windows\ReactWindows\ReactNative.Net46\ReactNative.Net46.csproj">
|
|
90
|
-
<Project>{22cbff9c-fe36-43e8-a246-266c7635e662}</Project>
|
|
91
|
-
<Name>ReactNative.Net46</Name>
|
|
92
|
-
</ProjectReference>
|
|
93
|
-
</ItemGroup>
|
|
94
|
-
<Import Project="..\CodePush.Shared\CodePush.Shared.projitems" Label="Shared" />
|
|
95
|
-
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
|
96
|
-
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.
|
|
97
|
-
Other similar extension points exist, see Microsoft.Common.targets.
|
|
98
|
-
<Target Name="BeforeBuild">
|
|
99
|
-
</Target>
|
|
100
|
-
<Target Name="AfterBuild">
|
|
101
|
-
</Target>
|
|
102
|
-
-->
|
|
103
|
-
</Project>
|