From afa817c39e59154ffa674ee7091b7c105763a73f Mon Sep 17 00:00:00 2001 From: JohnMcPMS Date: Fri, 11 Oct 2024 16:04:59 -0700 Subject: [PATCH 1/7] Make adding overlapping ARP range a hard error (#4870) ## Change Implements two independent but related changes: 1. Makes adding/updating an overlapping ARP range a hard error 2. Adds `AddOrUpdate` functionality to the index so that callers don't need to know if the manifest is already present ## Validation Added/updated unit tests for ARP overlap. Added unit and interop test for AddOrUpdate. --- src/AppInstallerCLITests/SQLiteIndex.cpp | 83 +++++++++++++++++- .../Microsoft/SQLiteIndex.cpp | 44 ++++++++++ .../Microsoft/SQLiteIndex.h | 15 ++++ .../Microsoft/Schema/1_5/Interface.h | 7 +- .../Microsoft/Schema/1_5/Interface_1_5.cpp | 86 +++++++++++++++---- src/WinGetUtil/Exports.cpp | 20 +++++ src/WinGetUtil/Source.def | 1 + src/WinGetUtil/WinGetUtil.h | 8 ++ .../APIUnitTests/SQLiteIndexUnitTests.cs | 23 ++++- .../Api/WinGetSQLiteIndex.cs | 37 ++++++++ .../Interfaces/IWinGetSQLiteIndex.cs | 8 ++ 11 files changed, 310 insertions(+), 22 deletions(-) diff --git a/src/AppInstallerCLITests/SQLiteIndex.cpp b/src/AppInstallerCLITests/SQLiteIndex.cpp index 97589be506..defb5bc206 100644 --- a/src/AppInstallerCLITests/SQLiteIndex.cpp +++ b/src/AppInstallerCLITests/SQLiteIndex.cpp @@ -3241,7 +3241,7 @@ TEST_CASE("SQLiteIndex_RemoveManifestArpVersionKeepUsedDeleteUnused", "[sqlitein } } -TEST_CASE("SQLiteIndex_ManifestArpVersion_CheckConsistency", "[sqliteindex]") +TEST_CASE("SQLiteIndex_ManifestArpVersionConflict_AddThrows", "[sqliteindex]") { TempFile tempFile{ "repolibtest_tempdb"s, ".db"s }; INFO("Using temporary file named: " << tempFile.GetPath()); @@ -3267,9 +3267,44 @@ TEST_CASE("SQLiteIndex_ManifestArpVersion_CheckConsistency", "[sqliteindex]") // Add a conflicting one manifest.Version = "10.1"; + REQUIRE_THROWS_HR(index.AddManifest(manifest, "path2"), APPINSTALLER_CLI_ERROR_ARP_VERSION_VALIDATION_FAILED); +} + +TEST_CASE("SQLiteIndex_ManifestArpVersionConflict_UpdateThrows", "[sqliteindex]") +{ + TempFile tempFile{ "repolibtest_tempdb"s, ".db"s }; + INFO("Using temporary file named: " << tempFile.GetPath()); + + SQLiteIndex index = CreateTestIndex(tempFile, SQLiteVersion::Latest()); + + Manifest manifest; + manifest.Id = "Foo"; + manifest.Version = "10.0"; + manifest.DefaultLocalization.Add("ArpVersionCheckConsistencyTest"); + manifest.Moniker = "testmoniker"; + manifest.Installers.push_back({}); + manifest.Installers[0].BaseInstallerType = InstallerTypeEnum::Exe; + manifest.Installers[0].AppsAndFeaturesEntries.push_back({}); + manifest.Installers[0].AppsAndFeaturesEntries[0].DisplayVersion = "1.0"; + manifest.Installers[0].AppsAndFeaturesEntries.push_back({}); + manifest.Installers[0].AppsAndFeaturesEntries[1].DisplayVersion = "1.1"; + + index.AddManifest(manifest, "path"); + REQUIRE(index.CheckConsistency(true)); + + // Add another version + manifest.Version = "10.1"; + manifest.Installers[0].AppsAndFeaturesEntries[0].DisplayVersion = "2.0"; + manifest.Installers[0].AppsAndFeaturesEntries[1].DisplayVersion = "2.1"; + index.AddManifest(manifest, "path2"); + REQUIRE(index.CheckConsistency(true)); - REQUIRE_FALSE(index.CheckConsistency(true)); + // Update to a conflict + manifest.Installers[0].AppsAndFeaturesEntries[0].DisplayVersion = "1.0"; + manifest.Installers[0].AppsAndFeaturesEntries[1].DisplayVersion = "2.1"; + + REQUIRE_THROWS_HR(index.UpdateManifest(manifest, "path2"), APPINSTALLER_CLI_ERROR_ARP_VERSION_VALIDATION_FAILED); } TEST_CASE("SQLiteIndex_ManifestArpVersion_ValidateManifestAgainstIndex", "[sqliteindex]") @@ -3856,3 +3891,47 @@ TEST_CASE("SQLiteIndex_DependencyWithCaseMismatch", "[sqliteindex][V1_4]") index.AddManifest(manifest, GetPathFromManifest(manifest)); } + +TEST_CASE("SQLiteIndex_AddOrUpdateManifest", "[sqliteindex]") +{ + TempFile tempFile{ "repolibtest_tempdb"s, ".db"s }; + INFO("Using temporary file named: " << tempFile.GetPath()); + + std::string manifestPath = "test/id/test.id-1.0.0.yaml"; + Manifest manifest; + manifest.Installers.push_back({}); + manifest.Id = "test.id"; + manifest.DefaultLocalization.Add < Localization::PackageName>("Test Name"); + manifest.Moniker = "testmoniker"; + manifest.Version = "1.0.0"; + manifest.Channel = "test"; + manifest.DefaultLocalization.Add({ "t1", "t2" }); + manifest.Installers[0].Commands = { "test1", "test2" }; + + { + auto version = GENERATE(SQLiteVersion{ 1, 0 }, SQLiteVersion::Latest()); + SQLiteIndex index = SQLiteIndex::CreateNew(tempFile, version); + + REQUIRE(index.AddOrUpdateManifest(manifest, manifestPath)); + } + + { + SQLiteIndex index = SQLiteIndex::Open(tempFile, SQLiteStorageBase::OpenDisposition::ReadWrite); + + // Update with no updates should return false + REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); + + manifest.DefaultLocalization.Add("description2"); + + // Update with no indexed updates should return false + REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); + + // Update with indexed changes + manifest.DefaultLocalization.Add("Test Name2"); + manifest.Moniker = "testmoniker2"; + manifest.DefaultLocalization.Add({ "t1", "t2", "t3" }); + manifest.Installers[0].Commands = {}; + + REQUIRE(index.AddOrUpdateManifest(manifest, manifestPath)); + } +} diff --git a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp index e9cc717bc3..bbd3305d81 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp +++ b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp @@ -109,6 +109,11 @@ namespace AppInstaller::Repository::Microsoft SQLiteIndex::IdType SQLiteIndex::AddManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath) { std::lock_guard lockInterface{ *m_interfaceLock }; + return AddManifestInternalHoldingLock(manifest, relativePath); + } + + SQLiteIndex::IdType SQLiteIndex::AddManifestInternalHoldingLock(const Manifest::Manifest& manifest, const std::optional& relativePath) + { AICLI_LOG(Repo, Verbose, << "Adding manifest for [" << manifest.Id << ", " << manifest.Version << "] at relative path [" << relativePath.value_or("") << "]"); SQLite::Savepoint savepoint = SQLite::Savepoint::Create(m_dbconn, "sqliteindex_addmanifest"); @@ -143,6 +148,11 @@ namespace AppInstaller::Repository::Microsoft bool SQLiteIndex::UpdateManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath) { std::lock_guard lockInterface{ *m_interfaceLock }; + return UpdateManifestInternalHoldingLock(manifest, relativePath); + } + + bool SQLiteIndex::UpdateManifestInternalHoldingLock(const Manifest::Manifest& manifest, const std::optional& relativePath) + { AICLI_LOG(Repo, Verbose, << "Updating manifest for [" << manifest.Id << ", " << manifest.Version << "] at relative path [" << relativePath.value_or("") << "]"); SQLite::Savepoint savepoint = SQLite::Savepoint::Create(m_dbconn, "sqliteindex_updatemanifest"); @@ -159,6 +169,40 @@ namespace AppInstaller::Repository::Microsoft return result; } + bool SQLiteIndex::AddOrUpdateManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath) + { + AICLI_LOG(Repo, Verbose, << "Adding or Updating manifest from file [" << manifestPath << "]"); + + Manifest::Manifest manifest = Manifest::YamlParser::CreateFromPath(manifestPath); + return AddOrUpdateManifestInternal(manifest, relativePath); + } + + bool SQLiteIndex::AddOrUpdateManifest(const Manifest::Manifest& manifest, const std::filesystem::path& relativePath) + { + return AddOrUpdateManifestInternal(manifest, relativePath); + } + + bool SQLiteIndex::AddOrUpdateManifest(const Manifest::Manifest& manifest) + { + return AddOrUpdateManifestInternal(manifest, {}); + } + + bool SQLiteIndex::AddOrUpdateManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath) + { + std::lock_guard lockInterface{ *m_interfaceLock }; + AICLI_LOG(Repo, Verbose, << "Adding or Updating manifest for [" << manifest.Id << ", " << manifest.Version << "] at relative path [" << relativePath.value_or("") << "]"); + + if (m_interface->GetManifestIdByManifest(m_dbconn, manifest)) + { + return UpdateManifestInternalHoldingLock(manifest, relativePath); + } + else + { + AddManifestInternalHoldingLock(manifest, relativePath); + return true; + } + } + void SQLiteIndex::RemoveManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath) { AICLI_LOG(Repo, Verbose, << "Removing manifest from file [" << manifestPath << "]"); diff --git a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h index 6494e3b38a..e60262800b 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h +++ b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h @@ -94,6 +94,18 @@ namespace AppInstaller::Repository::Microsoft // The return value indicates whether the index was modified by the function. bool UpdateManifest(const Manifest::Manifest& manifest); + // Adds or updates the manifest with matching { Id, Version, Channel } in the index. + // The return value indicates whether the index was modified by the function. + bool AddOrUpdateManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath); + + // Updates the manifest with matching { Id, Version, Channel } in the index. + // The return value indicates whether the index was modified by the function. + bool AddOrUpdateManifest(const Manifest::Manifest& manifest, const std::filesystem::path& relativePath); + + // Updates the manifest with matching { Id, Version, Channel } in the index. + // The return value indicates whether the index was modified by the function. + bool AddOrUpdateManifest(const Manifest::Manifest& manifest); + // Removes the manifest with matching { Id, Version, Channel } from the index. void RemoveManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath); @@ -176,7 +188,10 @@ namespace AppInstaller::Repository::Microsoft // Internal functions to normalize on the relativePath being present. IdType AddManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath); + IdType AddManifestInternalHoldingLock(const Manifest::Manifest& manifest, const std::optional& relativePath); bool UpdateManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath); + bool UpdateManifestInternalHoldingLock(const Manifest::Manifest& manifest, const std::optional& relativePath); + bool AddOrUpdateManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath); std::unique_ptr m_interface; Schema::SQLiteIndexContextData m_contextData; diff --git a/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface.h b/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface.h index e102184bf5..932a472b10 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface.h +++ b/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface.h @@ -26,8 +26,11 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 // Gets a property already knowing that the manifest id is valid. std::optional GetPropertyByManifestIdInternal(const SQLite::Connection& connection, SQLite::rowid_t manifestId, PackageVersionProperty property) const override; - private: + private: + // Gets the ARP version ranges for the given package identifier. + std::vector GetArpVersionRanges(const SQLite::Connection& connection, SQLite::rowid_t packageIdentifier) const; + // Semantic check to validate all arp version ranges within the index bool ValidateArpVersionConsistency(const SQLite::Connection& connection, bool log) const; }; -} \ No newline at end of file +} diff --git a/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface_1_5.cpp b/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface_1_5.cpp index 105486ced8..db6a274026 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface_1_5.cpp +++ b/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface_1_5.cpp @@ -4,6 +4,7 @@ #include "Microsoft/Schema/1_5/Interface.h" #include "Microsoft/Schema/1_5/ArpVersionVirtualTable.h" #include "Microsoft/Schema/1_0/ManifestTable.h" +#include "Microsoft/Schema/1_0/IdTable.h" #include "Microsoft/Schema/1_0/VersionTable.h" namespace AppInstaller::Repository::Microsoft::Schema::V1_5 @@ -36,8 +37,32 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 SQLite::rowid_t manifestId = V1_4::Interface::AddManifest(connection, manifest, relativePath); auto arpVersionRange = manifest.GetArpVersionRange(); - Manifest::string_t arpMinVersion = arpVersionRange.IsEmpty() ? "" : arpVersionRange.GetMinVersion().ToString(); - Manifest::string_t arpMaxVersion = arpVersionRange.IsEmpty() ? "" : arpVersionRange.GetMaxVersion().ToString(); + Manifest::string_t arpMinVersion, arpMaxVersion; + + if (!arpVersionRange.IsEmpty()) + { + // Check to see if adding this version range will create a conflict + SQLite::rowid_t packageIdentifier = V1_0::ManifestTable::GetIdById(connection, manifestId).value(); + std::vector ranges = GetArpVersionRanges(connection, packageIdentifier); + ranges.push_back(arpVersionRange); + + if (Utility::HasOverlapInVersionRanges(ranges)) + { + AICLI_LOG(Repo, Error, << "Overlapped Arp version ranges found for package. All ranges currently in index followed by new range:\n" << [&]() { + std::stringstream stream; + for (const auto& range : ranges) + { + stream << '[' << range.GetMinVersion().ToString() << "] - [" << range.GetMaxVersion().ToString() << "]\n"; + } + return std::move(stream).str(); + }()); + THROW_HR(APPINSTALLER_CLI_ERROR_ARP_VERSION_VALIDATION_FAILED); + } + + arpMinVersion = arpVersionRange.GetMinVersion().ToString(); + arpMaxVersion = arpVersionRange.GetMaxVersion().ToString(); + } + SQLite::rowid_t arpMinVersionId = V1_0::VersionTable::EnsureExists(connection, arpMinVersion); SQLite::rowid_t arpMaxVersionId = V1_0::VersionTable::EnsureExists(connection, arpMaxVersion); V1_0::ManifestTable::UpdateValueIdById(connection, manifestId, arpMinVersionId); @@ -82,6 +107,27 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 indexModified = true; } + if (!arpVersionRange.IsEmpty()) + { + // Check to see if the new set of version ranges created a conflict. + // We could have done this before attempting the update but it would be more complex and SQLite gives us easy rollback. + SQLite::rowid_t packageIdentifier = V1_0::ManifestTable::GetIdById(connection, manifestId).value(); + std::vector ranges = GetArpVersionRanges(connection, packageIdentifier); + + if (Utility::HasOverlapInVersionRanges(ranges)) + { + AICLI_LOG(Repo, Error, << "Overlapped Arp version ranges found for package. Ranges that would be present with attempted upgrade:\n" << [&]() { + std::stringstream stream; + for (const auto& range : ranges) + { + stream << '[' << range.GetMinVersion().ToString() << "] - [" << range.GetMaxVersion().ToString() << "]\n"; + } + return std::move(stream).str(); + }()); + THROW_HR(APPINSTALLER_CLI_ERROR_ARP_VERSION_VALIDATION_FAILED); + } + } + if (cleanOldMinVersionId && NotNeeded(connection, V1_0::VersionTable::TableName(), V1_0::VersionTable::ValueName(), oldMinVersionId)) { V1_0::VersionTable::DeleteById(connection, oldMinVersionId); @@ -181,6 +227,26 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 } } + std::vector Interface::GetArpVersionRanges(const SQLite::Connection& connection, SQLite::rowid_t packageIdentifier) const + { + std::vector ranges; + auto versionKeys = GetVersionKeysById(connection, packageIdentifier); + for (auto const& versionKey : versionKeys) + { + auto arpMinVersion = GetPropertyByPrimaryId(connection, versionKey.ManifestId, PackageVersionProperty::ArpMinVersion).value_or(""); + auto arpMaxVersion = GetPropertyByPrimaryId(connection, versionKey.ManifestId, PackageVersionProperty::ArpMaxVersion).value_or(""); + + // Either both empty or both not empty + THROW_HR_IF(E_UNEXPECTED, arpMinVersion.empty() != arpMaxVersion.empty()); + + if (!arpMinVersion.empty() && !arpMaxVersion.empty()) + { + ranges.emplace_back(Utility::VersionRange{ Utility::Version{ std::move(arpMinVersion) }, Utility::Version{ std::move(arpMaxVersion) } }); + } + } + return ranges; + } + bool Interface::ValidateArpVersionConsistency(const SQLite::Connection& connection, bool log) const { try @@ -193,21 +259,7 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 for (auto const& match : searchResult.Matches) { // Get arp version ranges for each package to check - std::vector ranges; - auto versionKeys = GetVersionKeysById(connection, match.first); - for (auto const& versionKey : versionKeys) - { - auto arpMinVersion = GetPropertyByPrimaryId(connection, versionKey.ManifestId, PackageVersionProperty::ArpMinVersion).value_or(""); - auto arpMaxVersion = GetPropertyByPrimaryId(connection, versionKey.ManifestId, PackageVersionProperty::ArpMaxVersion).value_or(""); - - // Either both empty or both not empty - THROW_HR_IF(E_UNEXPECTED, arpMinVersion.empty() != arpMaxVersion.empty()); - - if (!arpMinVersion.empty() && !arpMaxVersion.empty()) - { - ranges.emplace_back(Utility::VersionRange{ Utility::Version{ std::move(arpMinVersion) }, Utility::Version{ std::move(arpMaxVersion) } }); - } - } + std::vector ranges = GetArpVersionRanges(connection, match.first); // Check overlap if (Utility::HasOverlapInVersionRanges(ranges)) diff --git a/src/WinGetUtil/Exports.cpp b/src/WinGetUtil/Exports.cpp index bef1c56b59..091f795d1e 100644 --- a/src/WinGetUtil/Exports.cpp +++ b/src/WinGetUtil/Exports.cpp @@ -192,6 +192,26 @@ extern "C" } CATCH_RETURN() + WINGET_UTIL_API WinGetSQLiteIndexAddOrUpdateManifest( + WINGET_SQLITE_INDEX_HANDLE index, + WINGET_STRING manifestPath, + WINGET_STRING relativePath, + BOOL* indexModified) try + { + THROW_HR_IF(E_INVALIDARG, !index); + THROW_HR_IF(E_INVALIDARG, !manifestPath); + THROW_HR_IF(E_INVALIDARG, !relativePath); + + bool result = reinterpret_cast(index)->AddOrUpdateManifest(manifestPath, relativePath); + if (indexModified) + { + *indexModified = (result ? TRUE : FALSE); + } + + return S_OK; + } + CATCH_RETURN() + WINGET_UTIL_API WinGetSQLiteIndexRemoveManifest( WINGET_SQLITE_INDEX_HANDLE index, WINGET_STRING manifestPath, diff --git a/src/WinGetUtil/Source.def b/src/WinGetUtil/Source.def index bc42f3dc6d..2ec0f6637d 100644 --- a/src/WinGetUtil/Source.def +++ b/src/WinGetUtil/Source.def @@ -7,6 +7,7 @@ EXPORTS WinGetSQLiteIndexClose WinGetSQLiteIndexAddManifest WinGetSQLiteIndexUpdateManifest + WinGetSQLiteIndexAddOrUpdateManifest WinGetSQLiteIndexRemoveManifest WinGetSQLiteIndexPrepareForPackaging WinGetSQLiteIndexCheckConsistency diff --git a/src/WinGetUtil/WinGetUtil.h b/src/WinGetUtil/WinGetUtil.h index 13c548085d..86a69f1c04 100644 --- a/src/WinGetUtil/WinGetUtil.h +++ b/src/WinGetUtil/WinGetUtil.h @@ -158,6 +158,14 @@ extern "C" WINGET_STRING relativePath, BOOL* indexModified); + // Adds or Updates the manifest with matching { Id, Version, Channel } in the index. + // The return value indicates whether the index was modified by the function. + WINGET_UTIL_API WinGetSQLiteIndexAddOrUpdateManifest( + WINGET_SQLITE_INDEX_HANDLE index, + WINGET_STRING manifestPath, + WINGET_STRING relativePath, + BOOL* indexModified); + // Removes the manifest with matching { Id, Version, Channel } from the index. // Path is currently ignored. WINGET_UTIL_API WinGetSQLiteIndexRemoveManifest( diff --git a/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs b/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs index ed8596e29d..d2ae335ac4 100644 --- a/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs +++ b/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs @@ -1,4 +1,4 @@ -// ----------------------------------------------------------------------------- +// ----------------------------------------------------------------------------- // // Copyright (c) Microsoft Corporation. Licensed under the MIT License. // @@ -179,6 +179,27 @@ public void UpdateManifest() }); } + /// + /// Verify that add or update works both times. + /// + [Fact] + [DisplayTestMethodName] + public void AddOrUpdateManifest() + { + this.CreateIndexHelperForIndexTest((wrapper) => + { + // Add manifest. + string addManifest = Path.Combine(this.indexTestDataPath, PackageTest); + wrapper.AddOrUpdateManifest(addManifest, PackageTestRelativePath); + + // Update manifest. name is different, should return true. + string updateManifest = Path.Combine(this.indexTestDataPath, PackageTestNewName); + Assert.True(wrapper.AddOrUpdateManifest(updateManifest, PackageTestRelativePath)); + + return true; + }); + } + /// /// Verify that updating a manifest in the index with the exact same information succeeds. /// diff --git a/src/WinGetUtilInterop/Api/WinGetSQLiteIndex.cs b/src/WinGetUtilInterop/Api/WinGetSQLiteIndex.cs index 86c77f08a0..8a39390435 100644 --- a/src/WinGetUtilInterop/Api/WinGetSQLiteIndex.cs +++ b/src/WinGetUtilInterop/Api/WinGetSQLiteIndex.cs @@ -89,6 +89,27 @@ public bool UpdateManifest(string manifestPath, string relativePath) } } + /// + public bool AddOrUpdateManifest(string manifestPath, string relativePath) + { + try + { + // For now, modifying a manifest implies that the file didn't got moved in the repository. So only + // contents of the file are modified. However, in the future we might support moving which requires + // oldManifestPath, oldRelativePath, newManifestPath and oldManifestPath. + WinGetSQLiteIndexAddOrUpdateManifest( + this.indexHandle, + manifestPath, + relativePath, + out bool indexModified); + return indexModified; + } + catch (Exception e) + { + throw new WinGetSQLiteIndexException(e); + } + } + /// public void RemoveManifest(string manifestPath, string relativePath) { @@ -216,6 +237,22 @@ private static extern IntPtr WinGetSQLiteIndexUpdateManifest( string relativePath, [MarshalAs(UnmanagedType.U1)] out bool indexModified); + /// + /// Adds or Updates the manifest at the repository relative path in the index. + /// The out value indicates whether the index was modified by the function. + /// + /// Handle of the index. + /// Manifest path. + /// Relative path in the container. + /// Out bool if the index is modified. + /// HRESULT. + [DllImport(Constants.DllName, CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Unicode, PreserveSig = false)] + private static extern IntPtr WinGetSQLiteIndexAddOrUpdateManifest( + IntPtr index, + string manifestPath, + string relativePath, + [MarshalAs(UnmanagedType.U1)] out bool indexModified); + /// /// Removes the manifest at the repository relative path from the index. /// diff --git a/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs b/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs index 68bc65d167..96a5661765 100644 --- a/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs +++ b/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs @@ -62,6 +62,14 @@ public interface IWinGetSQLiteIndex : IDisposable /// True if index was modified. bool UpdateManifest(string manifestPath, string relativePath); + /// + /// Adds or Updates manifest in the index. + /// + /// Path to manifest. + /// Path of the manifest in the repository. + /// True if index was modified. + bool AddOrUpdateManifest(string manifestPath, string relativePath); + /// /// Delete manifest from index. /// From 40d358ae2d3577a6fc67b2edd6d0319ebf5c00b6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Flor=20Chac=C3=B3n?= <14323496+florelis@users.noreply.github.com> Date: Mon, 14 Oct 2024 22:39:55 -0700 Subject: [PATCH 2/7] Update package with CVEs (#4881) Update dependency System.IO.Packaging due to CVE-2024-43484, CVE-2024-43483 ###### Microsoft Reviewers: [Open in CodeFlow](https://microsoft.github.io/open-pr/?codeflow=https://github.com/microsoft/winget-cli/pull/4881) --- src/AppInstallerCLIE2ETests/AppInstallerCLIE2ETests.csproj | 1 + .../Microsoft.Management.Configuration.Processor.csproj | 1 + 2 files changed, 2 insertions(+) diff --git a/src/AppInstallerCLIE2ETests/AppInstallerCLIE2ETests.csproj b/src/AppInstallerCLIE2ETests/AppInstallerCLIE2ETests.csproj index 8e2d2bc20a..f2a23a382a 100644 --- a/src/AppInstallerCLIE2ETests/AppInstallerCLIE2ETests.csproj +++ b/src/AppInstallerCLIE2ETests/AppInstallerCLIE2ETests.csproj @@ -40,6 +40,7 @@ + diff --git a/src/Microsoft.Management.Configuration.Processor/Microsoft.Management.Configuration.Processor.csproj b/src/Microsoft.Management.Configuration.Processor/Microsoft.Management.Configuration.Processor.csproj index be076e2138..21857afea0 100644 --- a/src/Microsoft.Management.Configuration.Processor/Microsoft.Management.Configuration.Processor.csproj +++ b/src/Microsoft.Management.Configuration.Processor/Microsoft.Management.Configuration.Processor.csproj @@ -51,6 +51,7 @@ all + From 37c645814ab6fcf7f9b4668d02a9c57490f454d8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Flor=20Chac=C3=B3n?= <14323496+florelis@users.noreply.github.com> Date: Tue, 15 Oct 2024 16:15:41 -0700 Subject: [PATCH 3/7] Add ADMX policies for security features in App Installer (#4726) ###### Microsoft Reviewers: [Open in CodeFlow](https://microsoft.github.io/open-pr/?codeflow=https://github.com/microsoft/winget-cli/pull/4726) --- doc/admx/DesktopAppInstaller.admx | 82 +++++++++++++++++++++++++ doc/admx/en-US/DesktopAppInstaller.adml | 45 ++++++++++---- 2 files changed, 115 insertions(+), 12 deletions(-) diff --git a/doc/admx/DesktopAppInstaller.admx b/doc/admx/DesktopAppInstaller.admx index 9cad850345..c692c37061 100644 --- a/doc/admx/DesktopAppInstaller.admx +++ b/doc/admx/DesktopAppInstaller.admx @@ -183,5 +183,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/doc/admx/en-US/DesktopAppInstaller.adml b/doc/admx/en-US/DesktopAppInstaller.adml index 5c3142ab6b..746b678784 100644 --- a/doc/admx/en-US/DesktopAppInstaller.adml +++ b/doc/admx/en-US/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ Desktop App Installer - Enable App Installer + Enable Windows Package Manager This policy controls whether the Windows Package Manager can be used by users. If you enable or do not configure this setting, users will be able to use the Windows Package Manager. If you disable this setting, users will not be able to use the Windows Package Manager. - Enable App Installer Settings + Enable Windows Package Manager Settings This policy controls whether users can change their settings. If you enable or do not configure this setting, users will be able to change settings for the Windows Package Manager. If you disable this setting, users will not be able to change settings for the Windows Package Manager. - Enable App Installer Experimental Features + Enable Windows Package Manager Experimental Features This policy controls whether users can enable experimental features in the Windows Package Manager. If you enable or do not configure this setting, users will be able to enable experimental features for the Windows Package Manager. If you disable this setting, users will not be able to enable experimental features for the Windows Package Manager. - Enable App Installer Local Manifest Files + Enable Windows Package Manager Local Manifest Files This policy controls whether users can install packages with local manifest files. If you enable or do not configure this setting, users will be able to install packages with local manifests using the Windows Package Manager. If you disable this setting, users will not be able to install packages with local manifests using the Windows Package Manager. - Enable App Installer Microsoft Store Source Certificate Validation Bypass + Enable Windows Package Manager Microsoft Store Source Certificate Validation Bypass This policy controls whether the Windows Package Manager will validate the Microsoft Store certificate hash matches to a known Microsoft Store certificate when initiating a connection to the Microsoft Store Source. If you enable this policy, the Windows Package Manager will bypass the Microsoft Store certificate validation. If you disable this policy, the Windows Package Manager will validate the Microsoft Store certificate used is valid and belongs to the Microsoft Store before communicating with the Microsoft Store source. If you do not configure this policy, the Windows Package Manager administrator settings will be adhered to. - Enable App Installer Hash Override + Enable Windows Package Manager Hash Override This policy controls whether or not the Windows Package Manager can be configured to enable the ability override the SHA256 security validation in settings. If you enable or do not configure this policy, users will be able to enable the ability override the SHA256 security validation in the Windows Package Manager settings. If you disable this policy, users will not be able to enable the ability override the SHA256 security validation in the Windows Package Manager settings. - Enable App Installer Local Archive Malware Scan Override + Enable Windows Package Manager Local Archive Malware Scan Override This policy controls the ability to override malware vulnerability scans when installing an archive file using a local manifest using the command line arguments. If you enable this policy, users can override the malware scan when performing a local manifest install of an archive file. If you disable this policy, users will be unable to override the malware scan of an archive file when installing using a local manifest. If you do not configure this policy, the Windows Package Manager administrator settings will be adhered to. - Enable App Installer Default Source + Enable Windows Package Manager Default Source This policy controls the default source included with the Windows Package Manager. If you do not configure this setting, the default source for the Windows Package Manager will be available and can be removed. @@ -59,7 +59,7 @@ If you do not configure this setting, the default source for the Windows Package If you enable this setting, the default source for the Windows Package Manager will be available and cannot be removed. If you disable this setting the default source for the Windows Package Manager will not be available. - Enable App Installer Microsoft Store Source + Enable Windows Package Manager Microsoft Store Source This policy controls the Microsoft Store source included with the Windows Package Manager. If you do not configure this setting, the Microsoft Store source for the Windows Package manager will be available and can be removed. @@ -67,13 +67,13 @@ If you do not configure this setting, the Microsoft Store source for the Windows If you enable this setting, the Microsoft Store source for the Windows Package Manager will be available and cannot be removed. If you disable this setting the Microsoft Store source for the Windows Package Manager will not be available. - Set App Installer Source Auto Update Interval In Minutes + Set Windows Package Manager Source Auto Update Interval In Minutes This policy controls the auto-update interval for package-based sources. The default source for Windows Package Manager is configured such that an index of the packages is cached on the local machine. The index is downloaded when a user invokes a command, and the interval has passed. If you disable or do not configure this setting, the default interval or the value specified in the Windows Package Manager settings will be used. If you enable this setting, the number of minutes specified will be used by the Windows Package Manager. - Enable App Installer Additional Sources + Enable Windows Package Manager Additional Sources This policy controls additional sources provided by the enterprise IT administrator. If you do not configure this policy, no additional sources will be configured for the Windows Package Manager. @@ -81,7 +81,7 @@ If you do not configure this policy, no additional sources will be configured fo If you enable this policy, the additional sources will be added to the Windows Package Manager and cannot be removed. The representation for each additional source can be obtained from installed sources using 'winget source export'. If you disable this policy, no additional sources can be configured for the Windows Package Manager. - Enable App Installer Allowed Sources + Enable Windows Package Manager Allowed Sources This policy controls additional sources allowed by the enterprise IT administrator. If you do not configure this policy, users will be able to add or remove additional sources other than those configured by policy. @@ -122,6 +122,20 @@ If you disable this setting, users will not be able to use the Windows Package M If you disable or do not configure this setting, no proxy will be used by default. If you enable this setting, the specified proxy will be used by default. + Enable App Installer Allowed Zones for MSIX Packages + This policy controls whether App Installer allows installing packages originating from specific URL Zones. A package's origin is determined by its URI and whether a Mart-of-the-Web (MotW) is present. If multiple URIs are involved, all of them are considered; for example, when using a .appinstaller file that involves redirection. + +If you enable this policy, users will be able to install MSIX packages according to the configuration for each zone. + +If you disable or do not configure this policy, users will be able to install MSIX packages from any zone except for Untrusted. + Allow + Block + Enable Microsoft SmartScreen checks for MSIX Packages + This policy controls whether App Installer performs Microsoft SmartScreen checks when installing MSIX packages. + +If you enable or do not configure this policy, the package URI will be evaluated with Microsoft SmartScreen before installation. This check is only done for packages that come from the internet. + +If you disable, Microsoft SmartScreen will not be consulted before installing a package. @@ -138,6 +152,13 @@ If you enable this setting, the specified proxy will be used by default.Default Proxy + + Local Machine + Intranet + Trusted Sites + Internet + Untrusted Sites + From cc410c3fc23b2d59e14ef6766236417ae1c54985 Mon Sep 17 00:00:00 2001 From: JohnMcPMS Date: Wed, 16 Oct 2024 08:46:06 -0700 Subject: [PATCH 4/7] Consume all input during extract sequence (#4882) ## Change When extracting a sequence, consume all (up to 1KB really) input even if it doesn't start with an escape character. This was spurred by an issue where the `peek` call was not returning (waiting for input). Pressing Enter broke it out of that wait, but other input was now at the front and blocked future attempts to extract the sequence. The best solution to this would be to move all input handling to its own dedicated thread, but that is a much larger change. --- src/AppInstallerCLICore/VTSupport.cpp | 40 +++++++++++++-------------- 1 file changed, 20 insertions(+), 20 deletions(-) diff --git a/src/AppInstallerCLICore/VTSupport.cpp b/src/AppInstallerCLICore/VTSupport.cpp index 1908497bae..3f3fcbc705 100644 --- a/src/AppInstallerCLICore/VTSupport.cpp +++ b/src/AppInstallerCLICore/VTSupport.cpp @@ -61,31 +61,31 @@ namespace AppInstaller::CLI::VirtualTerminal // Extracts a VT sequence, expected one of the form ESCAPE + prefix + result + suffix, returning the result part. std::string ExtractSequence(std::istream& inStream, std::string_view prefix, std::string_view suffix) { - std::string result; + // Force discovery of available input + std::ignore = inStream.peek(); - if (inStream.peek() == AICLI_VT_ESCAPE[0]) - { - result.resize(4095); - inStream.readsome(&result[0], result.size()); - THROW_HR_IF(E_UNEXPECTED, static_cast(inStream.gcount()) >= result.size()); + static constexpr std::streamsize s_bufferSize = 1024; + char buffer[s_bufferSize]; + std::streamsize bytesRead = inStream.readsome(buffer, s_bufferSize); + THROW_HR_IF(E_UNEXPECTED, bytesRead >= s_bufferSize); - result.resize(static_cast(inStream.gcount())); + std::string_view resultView{ buffer, static_cast(bytesRead) }; + size_t escapeIndex = resultView.find(AICLI_VT_ESCAPE[0]); + if (escapeIndex == std::string_view::npos) + { + return {}; + } - std::string_view resultView = result; - size_t overheadLength = 1 + prefix.length() + suffix.length(); - if (resultView.length() <= overheadLength || - resultView.substr(1, prefix.length()) != prefix || - resultView.substr(resultView.length() - suffix.length()) != suffix) - { - result.clear(); - } - else - { - result = result.substr(1 + prefix.length(), result.length() - overheadLength); - } + resultView = resultView.substr(escapeIndex); + size_t overheadLength = 1 + prefix.length() + suffix.length(); + if (resultView.length() <= overheadLength || + resultView.substr(1, prefix.length()) != prefix || + resultView.substr(resultView.length() - suffix.length()) != suffix) + { + return {}; } - return result; + return std::string{ resultView.substr(1 + prefix.length(), resultView.length() - overheadLength) }; } } From 1e7c4038d4d621ddb1a6ac179a8a93a933b1210d Mon Sep 17 00:00:00 2001 From: JohnMcPMS Date: Wed, 16 Oct 2024 11:53:20 -0700 Subject: [PATCH 5/7] Change meaning of AddOrUpdate return bool (#4885) ## Issue The requestor of this new (1.10) API needs to know whether the operation was an add or an update. At the same time, the "was the index modified" return value from Update has always been true for any changes since the manifest hash was added. ## Change Return `true` when adding and `false` when updating. --- src/AppInstallerCLITests/SQLiteIndex.cpp | 8 ++++---- src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp | 3 ++- src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h | 6 +++--- src/WinGetUtil/WinGetUtil.h | 2 +- .../APIUnitTests/SQLiteIndexUnitTests.cs | 8 ++++---- src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs | 2 +- 6 files changed, 15 insertions(+), 14 deletions(-) diff --git a/src/AppInstallerCLITests/SQLiteIndex.cpp b/src/AppInstallerCLITests/SQLiteIndex.cpp index defb5bc206..fb381ebb72 100644 --- a/src/AppInstallerCLITests/SQLiteIndex.cpp +++ b/src/AppInstallerCLITests/SQLiteIndex.cpp @@ -3918,20 +3918,20 @@ TEST_CASE("SQLiteIndex_AddOrUpdateManifest", "[sqliteindex]") { SQLiteIndex index = SQLiteIndex::Open(tempFile, SQLiteStorageBase::OpenDisposition::ReadWrite); - // Update with no updates should return false + // Update should return false REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); manifest.DefaultLocalization.Add("description2"); - // Update with no indexed updates should return false + // Update should return false REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); - // Update with indexed changes + // Update with indexed changes should still return false manifest.DefaultLocalization.Add("Test Name2"); manifest.Moniker = "testmoniker2"; manifest.DefaultLocalization.Add({ "t1", "t2", "t3" }); manifest.Installers[0].Commands = {}; - REQUIRE(index.AddOrUpdateManifest(manifest, manifestPath)); + REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); } } diff --git a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp index bbd3305d81..ba4c089158 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp +++ b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp @@ -194,7 +194,8 @@ namespace AppInstaller::Repository::Microsoft if (m_interface->GetManifestIdByManifest(m_dbconn, manifest)) { - return UpdateManifestInternalHoldingLock(manifest, relativePath); + UpdateManifestInternalHoldingLock(manifest, relativePath); + return false; } else { diff --git a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h index e60262800b..6dc3cac54e 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h +++ b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h @@ -95,15 +95,15 @@ namespace AppInstaller::Repository::Microsoft bool UpdateManifest(const Manifest::Manifest& manifest); // Adds or updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the index was modified by the function. + // The return value indicates whether the manifest was added (true) or updated (false). bool AddOrUpdateManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath); // Updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the index was modified by the function. + // The return value indicates whether the manifest was added (true) or updated (false). bool AddOrUpdateManifest(const Manifest::Manifest& manifest, const std::filesystem::path& relativePath); // Updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the index was modified by the function. + // The return value indicates whether the manifest was added (true) or updated (false). bool AddOrUpdateManifest(const Manifest::Manifest& manifest); // Removes the manifest with matching { Id, Version, Channel } from the index. diff --git a/src/WinGetUtil/WinGetUtil.h b/src/WinGetUtil/WinGetUtil.h index 86a69f1c04..fe60ca77ed 100644 --- a/src/WinGetUtil/WinGetUtil.h +++ b/src/WinGetUtil/WinGetUtil.h @@ -159,7 +159,7 @@ extern "C" BOOL* indexModified); // Adds or Updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the index was modified by the function. + // The return value indicates whether the manifest was added (true) or updated (false). WINGET_UTIL_API WinGetSQLiteIndexAddOrUpdateManifest( WINGET_SQLITE_INDEX_HANDLE index, WINGET_STRING manifestPath, diff --git a/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs b/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs index d2ae335ac4..929562737b 100644 --- a/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs +++ b/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs @@ -188,13 +188,13 @@ public void AddOrUpdateManifest() { this.CreateIndexHelperForIndexTest((wrapper) => { - // Add manifest. + // Add manifest; should return true. string addManifest = Path.Combine(this.indexTestDataPath, PackageTest); - wrapper.AddOrUpdateManifest(addManifest, PackageTestRelativePath); + Assert.True(wrapper.AddOrUpdateManifest(addManifest, PackageTestRelativePath)); - // Update manifest. name is different, should return true. + // Update manifest. name is different, should return false. string updateManifest = Path.Combine(this.indexTestDataPath, PackageTestNewName); - Assert.True(wrapper.AddOrUpdateManifest(updateManifest, PackageTestRelativePath)); + Assert.False(wrapper.AddOrUpdateManifest(updateManifest, PackageTestRelativePath)); return true; }); diff --git a/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs b/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs index 96a5661765..15c1e30d6f 100644 --- a/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs +++ b/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs @@ -67,7 +67,7 @@ public interface IWinGetSQLiteIndex : IDisposable /// /// Path to manifest. /// Path of the manifest in the repository. - /// True if index was modified. + /// True if added; false if updated. bool AddOrUpdateManifest(string manifestPath, string relativePath); /// From b2cd6c03de6023d9e3b876b9042745b4c9af078c Mon Sep 17 00:00:00 2001 From: Madhusudhan-MSFT <53235553+Madhusudhan-MSFT@users.noreply.github.com> Date: Mon, 21 Oct 2024 14:42:33 -0700 Subject: [PATCH 6/7] Fix for Source Argument Validation in SourceWorkflow for Default Source Type (#4891) Fix for Source Argument Validation in SourceWorkflow for Default Source Type [Issues:] The current validation in the source flow correctly detects duplicate source names. However, when the source argument is validated along with the source type, it allows different source names with the same arguments for the empty source type. This happens because, during source type comparison, if the source type is not provided, it defaults to an empty string, which is compared against the default type (Microsoft.PreIndexed). This allows multiple different source names with the same argument to be considered valid sources. For an empty source type, the default source type is assigned during the source add operation, not beforehand. Consequently, after the source add operation is finished, the source will have some source arguments, but only the name will differ. [Fix:] For an empty source type, we should compare against the default source to prevent different source names with the same arguments for the default types. During validation, we obtain the default type to replace the empty source type and use it for comparison to validate argument duplication. - Extended source tests to validate the duplicate source argument scenario for the default source type. - Fixed additional failing source origin tests with appropriate fixes. [How Validated:] - Compiled the latest modifications and deployed the AppInstallerCLIPackage. - Executed CLI SourceTests to ensure all tests pass without issues. **[Manual validation:]** **Before fix:** ![image](https://github.com/user-attachments/assets/591b3ec2-ae6c-42ac-8258-169596657c4a) **After fix:** ![image](https://github.com/user-attachments/assets/2078b72a-d746-440c-a44e-2ec05c812e26) - [x] I have signed the [Contributor License Agreement](https://cla.opensource.microsoft.com/microsoft/winget-pkgs). - [ ] This pull request is related to an issue. ----- ###### Microsoft Reviewers: [Open in CodeFlow](https://microsoft.github.io/open-pr/?codeflow=https://github.com/microsoft/winget-cli/pull/4891) --- .../Workflows/SourceFlow.cpp | 12 ++++++++++++ src/AppInstallerCLIE2ETests/SourceCommand.cs | 18 ++++++++++++++++++ .../Public/winget/RepositorySource.h | 3 +++ .../RepositorySource.cpp | 7 ++++++- 4 files changed, 39 insertions(+), 1 deletion(-) diff --git a/src/AppInstallerCLICore/Workflows/SourceFlow.cpp b/src/AppInstallerCLICore/Workflows/SourceFlow.cpp index a6a1dee6d4..7d8df61ffd 100644 --- a/src/AppInstallerCLICore/Workflows/SourceFlow.cpp +++ b/src/AppInstallerCLICore/Workflows/SourceFlow.cpp @@ -52,6 +52,18 @@ namespace AppInstaller::CLI::Workflow std::string_view arg = context.Args.GetArg(Args::Type::SourceArg); std::string_view type = context.Args.GetArg(Args::Type::SourceType); + // In the absence of a specified type, the default is Microsoft.PreIndexed.Package for comparison. + // The default type assignment to the source takes place during the add operation (Source::Add in Repository.cpp). + // This is necessary for the comparison to function correctly; otherwise, it would allow the addition of multiple + // sources with different names but the same argument for all default type cases. + // For example, the following commands would be allowed, but they acts as different alias to same source: + // winget source add "mysource1" "https:\\mysource" --trust - level trusted + // winget source add "mysource2" "https:\\mysource" --trust - level trusted + if (type.empty()) + { + type = Repository::Source::GetDefaultSourceType(); + } + for (const auto& details : sourceList) { if (Utility::ICUCaseInsensitiveEquals(details.Name, name)) diff --git a/src/AppInstallerCLIE2ETests/SourceCommand.cs b/src/AppInstallerCLIE2ETests/SourceCommand.cs index 27ee083e13..c873a6d72b 100644 --- a/src/AppInstallerCLIE2ETests/SourceCommand.cs +++ b/src/AppInstallerCLIE2ETests/SourceCommand.cs @@ -45,6 +45,9 @@ public void SourceAdd() [Test] public void SourceAddWithTrustLevel() { + // Remove the test source. + TestCommon.RunAICLICommand("source remove", Constants.TestSourceName); + var result = TestCommon.RunAICLICommand("source add", $"SourceTest {Constants.TestSourceUrl} --trust-level trusted"); Assert.AreEqual(Constants.ErrorCode.S_OK, result.ExitCode); Assert.True(result.StdOut.Contains("Done")); @@ -62,6 +65,9 @@ public void SourceAddWithTrustLevel() [Test] public void SourceAddWithStoreOriginTrustLevel() { + // Remove the test source. + TestCommon.RunAICLICommand("source remove", Constants.TestSourceName); + var result = TestCommon.RunAICLICommand("source add", $"SourceTest {Constants.TestSourceUrl} --trust-level storeOrigin"); Assert.AreEqual(Constants.ErrorCode.ERROR_SOURCE_DATA_INTEGRITY_FAILURE, result.ExitCode); Assert.True(result.StdOut.Contains("The source data is corrupted or tampered")); @@ -103,6 +109,18 @@ public void SourceAddWithDuplicateName() Assert.True(result.StdOut.Contains("A source with the given name already exists and refers to a different location")); } + /// + /// Test source add with duplicate source url. + /// + [Test] + public void SourceAddWithDuplicateSourceUrl() + { + // Add source with duplicate url should fail + var result = TestCommon.RunAICLICommand("source add", $"TestSource2 {Constants.TestSourceUrl}"); + Assert.AreEqual(Constants.ErrorCode.ERROR_SOURCE_ARG_ALREADY_EXISTS, result.ExitCode); + Assert.True(result.StdOut.Contains("A source with a different name already refers to this location")); + } + /// /// Test source add with invalid url. /// diff --git a/src/AppInstallerRepositoryCore/Public/winget/RepositorySource.h b/src/AppInstallerRepositoryCore/Public/winget/RepositorySource.h index 3bdcdb2822..c01a1611f9 100644 --- a/src/AppInstallerRepositoryCore/Public/winget/RepositorySource.h +++ b/src/AppInstallerRepositoryCore/Public/winget/RepositorySource.h @@ -335,6 +335,9 @@ namespace AppInstaller::Repository // Get a list of all available SourceDetails. static std::vector GetCurrentSources(); + // Get a default source type is the source type used when adding a source without specifying a type. + static std::string_view GetDefaultSourceType(); + private: void InitializeSourceReference(std::string_view name); diff --git a/src/AppInstallerRepositoryCore/RepositorySource.cpp b/src/AppInstallerRepositoryCore/RepositorySource.cpp index 5c279f4de0..d178b6890d 100644 --- a/src/AppInstallerRepositoryCore/RepositorySource.cpp +++ b/src/AppInstallerRepositoryCore/RepositorySource.cpp @@ -880,7 +880,7 @@ namespace AppInstaller::Repository // AddSourceForDetails will also check for empty, but we need the actual type before that for validation. if (sourceDetails.Type.empty()) { - sourceDetails.Type = ISourceFactory::GetForType("")->TypeName(); + sourceDetails.Type = GetDefaultSourceType(); } AICLI_LOG(Repo, Info, << "Adding source: Name[" << sourceDetails.Name << "], Type[" << sourceDetails.Type << "], Arg[" << sourceDetails.Arg << "]"); @@ -1040,6 +1040,11 @@ namespace AppInstaller::Repository } } + std::string_view Source::GetDefaultSourceType() + { + return ISourceFactory::GetForType("")->TypeName(); + } + #ifndef AICLI_DISABLE_TEST_HOOKS void TestHook_SetSourceFactoryOverride(const std::string& type, std::function()>&& factory) { From c89879d4fb8eeaa6fcafaf5ac6553bbb211001bf Mon Sep 17 00:00:00 2001 From: Ryan <69221034+ryfu-msft@users.noreply.github.com> Date: Mon, 21 Oct 2024 17:51:11 -0400 Subject: [PATCH 7/7] add latest localized strings (#4892) --- .../Policies/de-DE/DesktopAppInstaller.adml | 45 ++++++++++++++----- .../Policies/es-ES/DesktopAppInstaller.adml | 45 ++++++++++++++----- .../Policies/fr-FR/DesktopAppInstaller.adml | 45 ++++++++++++++----- .../Policies/it-IT/DesktopAppInstaller.adml | 45 ++++++++++++++----- .../Policies/ja-JP/DesktopAppInstaller.adml | 45 ++++++++++++++----- .../Policies/ko-KR/DesktopAppInstaller.adml | 45 ++++++++++++++----- .../Policies/pt-BR/DesktopAppInstaller.adml | 45 ++++++++++++++----- .../Policies/ru-RU/DesktopAppInstaller.adml | 45 ++++++++++++++----- .../Policies/zh-CN/DesktopAppInstaller.adml | 45 ++++++++++++++----- .../Policies/zh-TW/DesktopAppInstaller.adml | 45 ++++++++++++++----- Localization/Resources/de-DE/winget.resw | 9 ++++ Localization/Resources/es-ES/winget.resw | 9 ++++ Localization/Resources/fr-FR/winget.resw | 9 ++++ Localization/Resources/it-IT/winget.resw | 9 ++++ Localization/Resources/ja-JP/winget.resw | 9 ++++ Localization/Resources/ko-KR/winget.resw | 9 ++++ Localization/Resources/pt-BR/winget.resw | 9 ++++ Localization/Resources/ru-RU/winget.resw | 9 ++++ Localization/Resources/zh-CN/winget.resw | 9 ++++ Localization/Resources/zh-TW/winget.resw | 9 ++++ 20 files changed, 420 insertions(+), 120 deletions(-) diff --git a/Localization/Policies/de-DE/DesktopAppInstaller.adml b/Localization/Policies/de-DE/DesktopAppInstaller.adml index 41869407b0..a4489b6f64 100644 --- a/Localization/Policies/de-DE/DesktopAppInstaller.adml +++ b/Localization/Policies/de-DE/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ Desktop-App-Installer - App-Installer aktivieren + Windows-Paket-Manager aktivieren Mit dieser Richt Linie wird gesteuert, ob der Windows-Paket-Manager von Benutzern verwendet werden kann. Wenn Sie diese Einstellung aktivieren oder nicht konfigurieren, können Benutzer die Windows-Paket-Manager verwenden. Wenn Sie diese Einstellung deaktivieren, können Benutzer den Windows-Paket-Manager nicht verwenden. - Einstellungen für den App-Installer aktivieren + Einstellungen des Windows-Paket-Manager aktivieren Mit dieser Richt Linie wird gesteuert, ob Benutzer Ihre Einstellungen ändern können. Wenn Sie diese Einstellung aktivieren oder nicht konfigurieren, können Benutzer Einstellungen für die Windows-Paket-Manager ändern. Wenn Sie diese Einstellung deaktivieren, können Benutzer Einstellungen für die Windows-Paket-Manager nicht ändern. - Experimentelle Features für den App-Installer aktivieren + Enable Windows Package Manager Experimental Features Mit dieser Richt Linie wird gesteuert, ob Benutzer Experiment elle Funktionen in der Windows-Paket-Manager aktivieren können. Wenn Sie diese Einstellung aktivieren oder nicht konfigurieren, können Benutzer Experiment elle Features für die Windows-Paket-Manager aktivieren. Wenn Sie diese Einstellung deaktivieren, können Benutzer Experiment elle Features für die Windows-Paket-Manager nicht aktivieren. - Lokale Manifestdateien für App-Installer aktivieren + Enable Windows Package Manager Local Manifest Files Mit dieser Richt Linie wird gesteuert, ob Benutzer Pakete mit lokalen Manifestdateien installieren können. Wenn Sie diese Einstellung aktivieren oder nicht konfigurieren, können Benutzer Pakete mit lokalen Manifeste mithilfe des Windows-Paket-Manager installieren. Wenn Sie diese Einstellung deaktivieren, können Benutzer keine Pakete mit lokalen Manifeste unter Verwendung des Windows-Paket-Manager installieren. - App-Installer Microsoft Store Umgehung der Quellzertifikatüberprüfung aktivieren + Enable Windows Package Manager Microsoft Store Source Certificate Validation Bypass Diese Richtlinie steuert, ob der Windows-Paket-Manager beim Initiieren einer Verbindung mit der Microsoft Speicherquelle überprüft, ob der Microsoft Speicherzertifikathash mit einem bekannten Microsoft Speicherzertifikat übereinstimmt. Wenn Sie diese Richtlinie aktivieren, umgehen die Windows-Paket-Manager die Überprüfung des Microsoft Speicherzertifikats. Wenn Sie diese Richtlinie deaktivieren, überprüft der Windows-Paket-Manager, ob das verwendete Microsoft Speicherzertifikat gültig ist und zum Microsoft Speicher gehört, bevor mit der Microsoft Store-Quelle kommuniziert wird. Wenn Sie diese Richtlinie nicht konfigurieren, werden die Windows-Paket-Manager Administratoreinstellungen eingehalten. - Hash-Überschreibung für den App-Installer aktivieren + Enable Windows Package Manager Hash Override Diese Richtlinie steuert, ob der Windows-Paket-Manager so konfiguriert werden kann, dass die Fähigkeit „SHA256-Sicherheitsvalidierung überschreiben“ in den Einstellungen aktiviert werden kann. Wenn Sie diese Richtlinie aktivieren oder nicht konfigurieren, können Benutzer die Fähigkeit „SHA256-Sicherheitsvalidierung überschreiben“ in den Windows-Paket-Manager-Einstellungen aktivieren. Wenn Sie diese Richtlinie deaktivieren, können Benutzer die Fähigkeit „SHA256-Sicherheitsvalidierung überschreiben“ in den Windows-Paket-Manager-Einstellungen nicht aktivieren. - Außerkraftsetzung der App-Installer Local Archive Malware Scan aktivieren + Enable Windows Package Manager Local Archive Malware Scan Override Diese Richtlinie steuert die Möglichkeit, Überprüfungen auf Sicherheitsrisiken durch Schadsoftware außer Kraft zu setzen, wenn eine Archivdatei mithilfe eines lokalen Manifests mithilfe der Befehlszeilenargumente installiert wird. Wenn Sie diese Richtlinie aktivieren, können Benutzer die Überprüfung auf Schadsoftware außer Kraft setzen, wenn sie eine lokale Manifestinstallation einer Archivdatei ausführen. Wenn Sie diese Richtlinie deaktivieren, können Benutzer die Schadsoftwareüberprüfung einer Archivdatei bei der Installation mithilfe eines lokalen Manifests nicht außer Kraft setzen. Wenn Sie diese Richtlinie nicht konfigurieren, werden die Windows-Paket-Manager Administratoreinstellungen eingehalten. - Standardquelle für den App-Installer aktivieren + Enable Windows Package Manager Default Source Diese Richtlinie steuert die Standardquelle, die im Windows-Paket-Manager enthalten ist. Wenn Sie diese Einstellung nicht konfigurieren, ist die Standardquelle für den Windows-Paket-Manager verfügbar und kann entfernt werden. @@ -59,7 +59,7 @@ Wenn Sie diese Einstellung nicht konfigurieren, ist die Standardquelle für den Wenn Sie diese Einstellung aktivieren, ist die Standardquelle für den Windows-Paket-Manager verfügbar und kann nicht entfernt werden. Wenn Sie diese Einstellung deaktivieren, ist die Standardquelle für den Windows-Paket-Manager nicht verfügbar. - Microsoft Store-Quelle für den App-Installer aktivieren + Enable Windows Package Manager Microsoft Store Source Diese Richtlinie steuert die Microsoft Store-Quelle, die im Windows-Paket-Manager enthalten ist. Wenn Sie diese Einstellung nicht konfigurieren, ist die Microsoft Store-Quelle für den Windows-Paket-Manager verfügbar und kann entfernt werden. @@ -67,13 +67,13 @@ Wenn Sie diese Einstellung nicht konfigurieren, ist die Microsoft Store-Quelle f Wenn Sie diese Einstellung aktivieren, ist die Microsoft Store-Quelle für den Windows-Paket-Manager verfügbar und kann nicht entfernt werden. Wenn Sie diese Einstellung deaktivieren, ist die Microsoft Store-Quelle für den Windows-Paket-Manager nicht verfügbar. - Intervall für automatische Aktualisierung der App-Installer-Quelle in Minuten festlegen + Intervall für das automatische Aktualisieren der Windows-Paket-Manager-Quelle in Minuten festlegen Diese Richtlinie steuert das Intervall für die automatische Aktualisierung paketbasierter Quellen. Die Standardquelle für Windows-Paket-Manager ist so konfiguriert, dass ein Index der Pakete auf dem lokalen Computer zwischengespeichert wird. Der Index wird heruntergeladen, wenn ein Benutzer einen Befehl aufruft und das Intervall abgelaufen ist. Wenn Sie diese Einstellung deaktivieren oder nicht konfigurieren, wird das Standardintervall oder der in den Windows-Paket-Manager Einstellungen angegebene Wert verwendet. Wenn Sie diese Einstellung aktivieren, wird die angegebene Anzahl von Minuten vom Windows-Paket-Manager verwendet. - Zusätzliche Quellen für den App-Installer aktivieren + Enable Windows Package Manager Additional Sources Diese Richtlinie steuert zusätzliche Quellen, die vom IT-Administrator des Unternehmens bereitgestellt werden. Wenn Sie diese Richtlinie nicht konfigurieren, werden keine zusätzlichen Quellen für den Windows-Paket-Manager konfiguriert. @@ -81,7 +81,7 @@ Wenn Sie diese Richtlinie nicht konfigurieren, werden keine zusätzlichen Quelle Wenn Sie diese Richtlinie aktivieren, werden die zusätzlichen Quellen dem Windows-Paket-Manager hinzugefügt und können nicht entfernt werden. Die Repräsentation für jede zusätzliche Quelle kann aus den installierten Quellen mit „winget source export“ bezogen werden. Wenn Sie diese Richtlinie deaktivieren, können keine zusätzlichen Quellen für den Windows-Paket-Manager konfiguriert werden. - Zulässige Quellen für den App-Installer aktivieren + Enable Windows Package Manager Allowed Sources Diese Richtlinie steuert zusätzliche Quellen, die vom IT-Administrator des Unternehmens zugelassen werden. Wenn Sie diese Richtlinie nicht konfigurieren, können Benutzer zusätzliche Quellen neben den in der Richtlinie konfigurierten hinzufügen oder entfernen. @@ -122,6 +122,20 @@ Wenn Sie diese Einstellung deaktivieren oder nicht konfigurieren, können Benutz Wenn Sie diese Einstellung deaktivieren oder nicht konfigurieren, wird standardmäßig kein Proxy verwendet. Wenn Sie diese Einstellung aktivieren, wird der angegebene Proxy standardmäßig verwendet. + Enable App Installer Allowed Zones for MSIX Packages + Diese Richtlinie steuert, ob App-Installer die Installation von Paketen aus bestimmten URL-Zonen zulässt. Der Ursprung eines Pakets wird durch seinen URI bestimmt und ob ein Mart-of-the-Web (MotW) vorhanden ist. Wenn mehrere URIs beteiligt sind, werden alle berücksichtigt; z. B. bei Verwendung einer .appinstaller-Datei, die umleitungsbezieht. + +Wenn Sie diese Richtlinie aktivieren, können Benutzer MSIX-Pakete gemäß der Konfiguration für jede Zone installieren. + +Wenn Sie diese Richtlinie deaktivieren oder nicht konfigurieren, können Benutzer MSIX-Pakete aus einer beliebigen Zone installieren, mit Ausnahme von "Nicht vertrauenswürdig". + Zulassen + Blockieren + Enable Microsoft SmartScreen checks for MSIX Packages + Diese Richtlinie steuert, ob App-Installer bei der Installation von MSIX-Paketen Microsoft SmartScreen-Überprüfungen durchführt. + +Wenn Sie diese Richtlinie aktivieren oder nicht konfigurieren, wird der Paket-URI vor der Installation mit Microsoft SmartScreen ausgewertet. Diese Überprüfung wird nur für Pakete durchgeführt, die aus dem Internet stammen. + +Wenn Sie diese Option deaktivieren, wird Microsoft SmartScreen vor der Installation eines Pakets nicht abgefragt. @@ -138,6 +152,13 @@ Wenn Sie diese Einstellung aktivieren, wird der angegebene Proxy standardmäßig + + Lokaler Computer + Intranet + Vertrauenswürdige Sites + Internet + Untrusted Sites + diff --git a/Localization/Policies/es-ES/DesktopAppInstaller.adml b/Localization/Policies/es-ES/DesktopAppInstaller.adml index 2b5a602d91..127a903fe6 100644 --- a/Localization/Policies/es-ES/DesktopAppInstaller.adml +++ b/Localization/Policies/es-ES/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ Instalador de aplicaciones de escritorio - Habilitar el instalador de aplicaciones + Habilitar el Administrador de paquetes de Windows Esta directiva controla si los usuarios pueden usar el administrador de paquetes de Windows. Si habilitas o no estableces esta configuración, los usuarios podrán usar el administrador de paquetes de Windows. Si deshabilitas esta configuración, los usuarios no podrán usar el administrador de paquetes de Windows. - Habilitar la configuración del instalador de aplicaciones + Habilitar la configuración del Administrador de paquetes de Windows Esta directiva controla si los usuarios pueden cambiar su configuración. Si habilita o no establece esta configuración, los usuarios podrán cambiar la configuración del administrador de paquetes de Windows. Si deshabilitas esta configuración, los usuarios no podrán cambiar la configuración del administrador de paquetes de Windows. - Habilitar las funciones experimentales del instalador de aplicaciones + Habilitar Administrador de paquetes de Windows características experimentales Esta directiva controla si los usuarios pueden habilitar características experimentales en el administrador de paquetes de Windows. Si habilitas o no configuras esta opción, los usuarios podrán habilitar las características experimentales para el administrador de paquetes de Windows. Si deshabilitas esta configuración, los usuarios no podrán habilitar las características experimentales para el administrador de paquetes de Windows. - Habilitar los archivos de manifiesto locales del instalador de aplicaciones + Habilitar Administrador de paquetes de Windows archivos de manifiesto local Esta directiva controla si los usuarios pueden instalar paquetes con archivos de manifiesto locales. Si habilitas o no configuras esta opción, los usuarios podrán instalar paquetes con manifiestos locales mediante el administrador de paquetes de Windows. Si deshabilitas esta configuración, los usuarios no podrán instalar paquetes con manifiestos locales mediante el administrador de paquetes de Windows. - Habilitación de la omisión de validación de certificados de origen del Instalador de aplicación para Microsoft Store + Habilitar Administrador de paquetes de Windows Microsoft Store omisión de validación de certificado de origen Esta directiva controla si el Administrador de paquetes de Windows validará las coincidencias del hash del certificado de Microsoft Store con un certificado de Microsoft Store conocido al iniciar una conexión con el origen de Microsoft Store. Si habilita esta directiva, el Administrador de paquetes de Windows omitirá la validación del certificado de Microsoft Store. Si deshabilita esta directiva, el Administrador de paquetes de Windows validará que el certificado de Microsoft Store usado es válido y pertenece a Microsoft Store antes de comunicarse con el origen de Microsoft Store. Si no establece esta directiva, se usará la configuración de administrador del Administrador de paquetes de Windows. - Habilitar la anulación del hash del instalador de la aplicación + Habilitar invalidación de hash de Administrador de paquetes de Windows Esta directiva controla si se puede configurar el administrador de paquetes de Windows para que permita revertir la validación de seguridad SHA256 en la configuración. Si habilita o no configura esta directiva, los usuarios podrán habilitar la capacidad de revertir la validación de seguridad SHA256 en la configuración del administrador de paquetes de Windows. Si deshabilita esta directiva, los usuarios no podrán habilitar la capacidad de revertir la validación de seguridad SHA256 en la configuración del administrador de paquetes de Windows. - Habilitación de la omisión de detección de malware de archivos locales del Instalador de aplicación + Habilitar Administrador de paquetes de Windows invalidación del examen de malware de archivo local Esta directiva controla la capacidad de invalidar los exámenes de vulnerabilidades de malware al instalar un archivo de almacenamiento mediante un manifiesto local mediante los argumentos de la línea de comandos. Si habilita esta directiva, los usuarios pueden invalidar el examen de malware al realizar una instalación de manifiesto local de un archivo de almacenamiento. Si deshabilita esta directiva, los usuarios no podrán invalidar el examen de malware de un archivo de almacenamiento al instalarlo mediante un manifiesto local. Si no establece esta directiva, se cumplirá la configuración de administrador de Administrador de paquetes de Windows. - Habilitar el origen predeterminado del instalador de aplicaciones + Habilitar Administrador de paquetes de Windows origen predeterminado Esta directiva controla la fuente predeterminada incluida con el Administrador de paquetes de Windows. Si no configura esta opción, el origen predeterminado para el Administrador de paquetes de Windows estará disponible y podrá eliminarse. @@ -59,7 +59,7 @@ Si no configura esta opción, el origen predeterminado para el Administrador de Si habilita esta configuración, el origen predeterminado para el Administrador de paquetes de Windows estará disponible y no se podrá eliminar. Si desactiva esta configuración, la fuente por defecto para el Administrador de Paquetes de Windows no estará disponible. - Habilitar el instalador de aplicaciones de origen de Microsoft Store + Habilitar Administrador de paquetes de Windows origen de Microsoft Store Esta directiva controla la fuente de la Tienda Microsoft incluida en el Administrador de paquetes de Windows. Si no configura esta opción, el origen de la Tienda Microsoft para el Administrador de paquetes de Windows estará disponible y se podrá elimina. @@ -67,13 +67,13 @@ Si no configura esta opción, el origen de la Tienda Microsoft para el Administr Si habilita esta configuración, el origen de Microsoft Store para el Administrador de paquetes de Windows estará disponible y no se podrá eliminar. Si desactiva esta configuración, el origen de la Tienda Microsoft para el Administrador de paquetes de Windows no estará disponible. - Establecer el intervalo de actualización automática de la fuente del instalador de aplicaciones en minutos + Establecer el intervalo de actualización automática del origen del Administrador de paquetes de Windows en minutos Esta directiva controla el intervalo de actualización automática para orígenes basados en paquetes. El origen predeterminado para Administrador de paquetes de Windows está configurado de forma que un índice de los paquetes se almacena en caché en el equipo local. El índice se descarga cuando un usuario invoca un comando y el intervalo ha pasado. Si deshabilita o no establece esta configuración, se usará el intervalo predeterminado o el valor especificado en la configuración de Administrador de paquetes de Windows. Si habilita esta configuración, el Administrador de paquetes de Windows usará el número de minutos especificado. - Habilitar orígenes adicionales del instalador de aplicaciones + Habilitar Administrador de paquetes de Windows orígenes adicionales Esta directiva controla los orígenes adicionales proporcionados por el administrador de TI de la empresa. Si no configura esta directiva, los orígenes adicionales no se podrán configurar para el Administrador de paquetes de Windows. @@ -81,7 +81,7 @@ Si no configura esta directiva, los orígenes adicionales no se podrán configur Si habilita esta directiva, los orígenes adicionales se agregarán al Administrador de paquetes de Windows y no se podrán eliminar. La representación de cada origen adicional puede obtenerse de las fuentes instaladas mediante "winget source export". Si desactiva esta directiva, no se podrán configurar orígenes adicionales para el Administrador de paquetes de Windows. - Habilitar los orígenes permitidos del instalador de aplicaciones + Habilitar Administrador de paquetes de Windows orígenes permitidos Esta directiva controla los orígenes adicionales permitidos por el administrador de TI de la empresa Si no configura esta directiva, los usuarios podrán agregar o eliminar fuentes adicionales distintas de las configuradas por la directiva. @@ -122,6 +122,20 @@ Si deshabilita o no establece esta configuración, los usuarios no podrán confi Si deshabilita o no establece esta configuración, no se usará ningún proxy de forma predeterminada. Si habilita esta configuración, el proxy especificado se usará de forma predeterminada. + Habilitar Instalador de aplicación zonas permitidas para paquetes MSIX + Esta directiva controla si Instalador de aplicación permite instalar paquetes procedentes de zonas URL específicas. El origen de un paquete está determinado por su URI y si hay presente un Mart-of-the-Web (MotW). Si hay varios URI implicados, se consideran todos; por ejemplo, cuando se usa un archivo .appinstaller que implica redirección. + +Si habilita esta directiva, los usuarios podrán instalar paquetes MSIX según la configuración de cada zona. + +Si deshabilitas o no configuras esta directiva, los usuarios podrán instalar paquetes MSIX desde cualquier zona excepto si no son de confianza. + Permitir + Bloquear + Habilitar las comprobaciones de Microsoft SmartScreen para paquetes MSIX + Esta directiva controla si Instalador de aplicación realiza comprobaciones de SmartScreen de Microsoft al instalar paquetes MSIX. + +Si habilitas o no configuras esta directiva, el URI del paquete se evaluará con Microsoft SmartScreen antes de la instalación. Esta comprobación solo se realiza para los paquetes procedentes de Internet. + +Si lo deshabilita, no se consultará a Microsoft SmartScreen antes de instalar un paquete. @@ -138,6 +152,13 @@ Si habilita esta configuración, el proxy especificado se usará de forma predet + + Equipo local + Intranet + Sitios de confianza + Internet + Sitio que no es de confianza + diff --git a/Localization/Policies/fr-FR/DesktopAppInstaller.adml b/Localization/Policies/fr-FR/DesktopAppInstaller.adml index 97b503e991..b0f5422fe8 100644 --- a/Localization/Policies/fr-FR/DesktopAppInstaller.adml +++ b/Localization/Policies/fr-FR/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ Programme d’installation des applications de bureau - Activer le programme d’installation de l’application + Activer le Gestionnaire de package Windows Cette stratégie contrôle si le gestionnaire de packages Windows peut être utilisé par les utilisateurs. Si vous activez ou ne configurez pas ce paramètre, les utilisateurs peuvent utiliser le gestionnaire de packages Windows. Si vous désactivez ce paramètre, les utilisateurs ne peuvent pas utiliser le gestionnaire de packages Windows. - Activer les paramètres du Programme d’installation de l’application + Activer les paramètres du Gestionnaire de package Windows Cette stratégie contrôle si les utilisateurs peuvent modifier leurs paramètres. Si vous activez ou ne configurez pas ce paramètre, les utilisateurs peuvent modifier les paramètres du gestionnaire de packages Windows. Si vous désactivez ce paramètre, les utilisateurs ne peuvent pas modifier les paramètres du gestionnaire de packages Windows. - Activer les fonctionnalités expérimentales du Programme d’installation de l’application + Enable Windows Package Manager Experimental Features Cette stratégie contrôle si les utilisateurs peuvent activer les fonctionnalités expérimentales dans le gestionnaire de packages Windows. Si vous activez ou ne configurez pas ce paramètre, les utilisateurs peuvent activer des fonctionnalités expérimentales pour le gestionnaire de package Windows. Si vous désactivez ce paramètre, les utilisateurs ne peuvent pas activer les fonctionnalités expérimentales pour le gestionnaire de package Windows. - Activer les fichiers de manifeste locaux du Programme d'installation de l'application + Enable Windows Package Manager Local Manifest Files Cette stratégie contrôle si les utilisateurs peuvent installer des packages avec des fichiers de manifeste locaux. Si vous activez ou ne configurez pas ce paramètre, les utilisateurs peuvent installer des packages avec des manifestes locaux à l’aide du gestionnaire de packages Windows. Si vous désactivez ce paramètre, les utilisateurs ne peuvent pas installer de packages avec des manifestes locaux à l’aide du gestionnaire de packages Windows. - Activer Programme d'installation d'application Microsoft Store contournement de la validation du certificat source + Enable Windows Package Manager Microsoft Store Source Certificate Validation Bypass Cette stratégie contrôle si le Gestionnaire de package Windows validera si les correspondances de hachage de certificat Microsoft Store correspond à un certificat Microsoft Store connu lors de l’initialisation d’une connexion à la source Microsoft Store. Si vous activez cette stratégie, le Gestionnaire de package Windows contourne la validation du certificat Microsoft Store. Si vous désactivez cette stratégie, le Gestionnaire de package Windows vérifie que le certificat Microsoft Store utilisé est valide et appartient au Microsoft Store avant de communiquer avec la source Microsoft Store. Si vous ne configurez pas cette stratégie, les paramètres d’administrateur Gestionnaire de package Windows sont respectés. - Activer le remplacement de code de hachage du Programme d’installation de l’application + Enable Windows Package Manager Hash Override Cette stratégie détermine si les utilisateurs peuvent configurer le Gestionnaire de package Windows ou non pour activer la fonction de remplacement de la validation de sécurité SHA256 dans les paramètres. Si vous activez ou ne configurez pas cette stratégie, les utilisateurs pourront activer la fonction de remplacement la validation de sécurité SHA256 dans les paramètres du Gestionnaire de package Windows. Si vous désactivez cette stratégie, les utilisateurs ne pourront pas activer la fonction de remplacement la validation de sécurité SHA256 dans les paramètres du Gestionnaire de package Windows. - Activer le remplacement de l’analyse des programmes malveillants des archives locales Windows Programme d'installation d'application + Enable Windows Package Manager Local Archive Malware Scan Override Cette stratégie contrôle la possibilité de remplacer les analyses de vulnérabilités de programmes malveillants lors de l’installation d’un fichier d’archive à l’aide d’un manifeste local à l’aide des arguments de ligne de commande. Si vous activez ce paramètre de stratégie, les utilisateurs peuvent remplacer l’analyse des programmes malveillants lors de l’installation d’un manifeste local d’un fichier d’archive. Si vous désactivez cette stratégie, les utilisateurs ne peuvent pas remplacer l’analyse des programmes malveillants d’un fichier d’archive lors de l’installation à l’aide d’un manifeste local. Si vous ne configurez pas cette stratégie, les paramètres d’administrateur Gestionnaire de package Windows sont conformes. - Activer la source par défaut du Programme d'installation d'application + Enable Windows Package Manager Default Source Cette stratégie contrôle la source par défaut incluse dans le Gestionnaire de package Windows. Si vous ne configurez pas ce paramètre, la source par défaut pour le Gestionnaire de package Windows est disponible et peut être supprimée. @@ -59,7 +59,7 @@ Si vous ne configurez pas ce paramètre, la source par défaut pour le Gestionna Si vous activez ce paramètre, la source par défaut pour le Gestionnaire de package Windows est disponible et ne peut pas être supprimée. Si vous désactivez ce paramètre, la source par défaut pour le Gestionnaire de package Windows n’est pas disponible. - Activer la source Microsoft Store du Programme d’installation d’application + Enable Windows Package Manager Microsoft Store Source Cette stratégie contrôle la source du Microsoft Store incluse dans le Gestionnaire de package Windows. Si vous ne configurez pas ce paramètre, la source du Microsoft Store pour le Gestionnaire de package Windows est disponible et peut être supprimée. @@ -67,13 +67,13 @@ Si vous ne configurez pas ce paramètre, la source du Microsoft Store pour le Ge Si vous activez ce paramètre, la source du Microsoft Store pour le Gestionnaire de package Windows est disponible et ne peut pas être supprimée. Si vous désactivez ce paramètre, la source du Microsoft Store pour le Gestionnaire de package Windows n’est pas disponible. - Définir l’intervalle en minutes de mise à jour automatique de source du programme d’installation de l’application + Définir l’intervalle en minutes de la mise à jour automatique source du Gestionnaire de package Windows Cette stratégie contrôle l’intervalle de mise à jour automatique pour les sources basées sur les packages. La source par défaut de Gestionnaire de package Windows est configurée de sorte qu’un index des packages soit mis en cache sur l’ordinateur local. L’index est téléchargé lorsqu’un utilisateur appelle une commande et que l’intervalle est écoulé. Si vous désactivez ou ne configurez pas ce paramètre, l’intervalle par défaut ou la valeur spécifié dans les paramètres de Gestionnaire de package Windows sont utilisés. Si vous activez ce paramètre, le nombre de minutes spécifié est utilisé par le Gestionnaire de package Windows. - Activer les sources supplémentaires du Programme d’installation de l’application + Enable Windows Package Manager Additional Sources Cette stratégie contrôle les sources supplémentaires offertes par l’administrateur informatique de l’entreprise. Si vous ne configurez pas ce paramètre de stratégie, aucune source supplémentaire n’est configurée pour le Gestionnaire de package Windows. @@ -81,7 +81,7 @@ Si vous ne configurez pas ce paramètre de stratégie, aucune source supplément Si vous activez ce paramètre de stratégie, les sources supplémentaires sont ajoutées au Gestionnaire de package Windows et ne peuvent pas être supprimées. La représentation de chaque source supplémentaire peut être obtenue à partir de sources installées à l’aide de « Winget source export ». Si vous désactivez ce paramètre de stratégie, aucune source supplémentaire ne peut être configurée pour le Gestionnaire de package Windows. - Activer les sources autorisées du Programme d’installation de l’application + Enable Windows Package Manager Allowed Sources Cette stratégie contrôle les sources supplémentaires autorisées par l’administrateur informatique de l’entreprise. Si vous ne configurez pas ce paramètre de stratégie, les utilisateurs pourront ajouter ou supprimer des sources supplémentaires autres que celles configurées par la stratégie Si @@ -122,6 +122,20 @@ Si vous désactivez ou ne configurez pas ce paramètre, les utilisateurs ne peuv Si vous désactivez ou ne configurez pas ce paramètre, aucun proxy n’est utilisé par défaut. Si vous activez ce paramètre, le proxy spécifié est utilisé par défaut. + Enable App Installer Allowed Zones for MSIX Packages + Cette stratégie contrôle si Programme d'installation d'application autorise l’installation de packages provenant de zones URL spécifiques. L’origine d’un package est déterminée par son URI et si un Mart-of-the-Web (MotW) est présent. Si plusieurs URI sont impliqués, tous sont pris en compte ; par exemple, lors de l’utilisation d’un fichier .appinstaller qui implique une redirection. + +Si vous activez cette stratégie, les utilisateurs peuvent installer des packages MSIX en fonction de la configuration de chaque zone. + +Si vous désactivez ou ne configurez pas cette stratégie, les utilisateurs peuvent installer des packages MSIX à partir de n’importe quelle zone, sauf pour les packages non approuvés. + Autoriser + Bloquer + Enable Microsoft SmartScreen checks for MSIX Packages + Cette stratégie contrôle si Programme d'installation d'application effectue des vérifications Microsoft SmartScreen lors de l’installation des packages MSIX. + +Si vous activez ou ne configurez pas cette stratégie, l’URI du package est évalué avec Microsoft SmartScreen avant l’installation. Cette case activée est effectuée uniquement pour les packages provenant d’Internet. + +Si vous désactivez, Microsoft SmartScreen n’est pas consulté avant d’installer un package. @@ -138,6 +152,13 @@ Si vous activez ce paramètre, le proxy spécifié est utilisé par défaut.Proxy par défaut + + Ordinateur local + Intranet + Sites de confiance + Internet + Untrusted Sites + diff --git a/Localization/Policies/it-IT/DesktopAppInstaller.adml b/Localization/Policies/it-IT/DesktopAppInstaller.adml index 95fb331f23..a21e27774c 100644 --- a/Localization/Policies/it-IT/DesktopAppInstaller.adml +++ b/Localization/Policies/it-IT/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ Programma di installazione app desktop - Abilita programma di installazione app + Abilita Gestione pacchetti Windows Questo criterio Controlla se Windows Gestione pacchetti può essere utilizzato dagli utenti. Se si Abilita o non si configura questa impostazione, gli utenti potranno utilizzare Windows Gestione pacchetti. Se si disabilita questa impostazione, gli utenti non potranno utilizzare Windows Gestione pacchetti. - Abilita impostazioni del programma di installazione app + Abilita le impostazioni di Gestione pacchetti Windows Questo criterio Controlla se gli utenti possono modificare le impostazioni. Se si Abilita o non si configura questa impostazione, gli utenti potranno modificare le impostazioni di Windows Gestione pacchetti. Se si disabilita questa impostazione, gli utenti non saranno in grado di modificare le impostazioni per Windows Gestione pacchetti. - Abilita funzionalità sperimentali del programma di installazione app + Abilita le funzionalità sperimentali di Gestione pacchetti Windows Questo criterio Controlla se gli utenti possono abilitare le funzionalità sperimentali in Windows Gestione pacchetti. Se si Abilita o non si configura questa impostazione, gli utenti potranno abilitare le funzionalità sperimentali per Windows Gestione pacchetti. Se si disabilita questa impostazione, gli utenti non saranno in grado di abilitare le funzionalità sperimentali per Windows Gestione pacchetti. - Abilita file manifesto locali del programma di installazione app + Abilita i file manifesto locali di Gestione pacchetti Windows Questo criterio Controlla se gli utenti possono installare pacchetti con file di manifesto locali. Se si Abilita o non si configura questa impostazione, gli utenti potranno installare pacchetti con manifesti locali tramite Windows Gestione pacchetti. Se si disabilita questa impostazione, gli utenti non saranno in grado di installare pacchetti con manifesti locali tramite Windows Gestione pacchetti. - Abilita il bypass del certificato di origine del programma di installazione app Microsoft Store + Abilita il bypass di convalida del certificato di Microsoft Store di Gestione pacchetti Windows Questo criterio consente di stabilire se Gestione pacchetti Windows convaliderà la corrispondenza dell'hash del certificato Microsoft Store con un certificato Microsoft Store noto quando si avvia una connessione all'origine Microsoft Store. Se si abilita questo criterio, Gestione pacchetti Windows ignorerà la convalida del certificato Microsoft Store. Se si disabilita questo criterio, Gestione pacchetti Windows convaliderà il certificato Microsoft Store usato affinché sia valido e appartenga a Microsoft Store prima di comunicare con l'origine Microsoft Store. Se non si configura questo criterio, verranno rispettate le impostazioni dell'amministratore di Gestione pacchetti Windows. - Abilita sostituzione hash del programma di installazione app + Abilita l’override dell’hash di Gestione pacchetti Windows Questa impostazione dei criteri consente di specificare se Windows Gestione pacchetti può essere configurato per abilitare la possibilità di ignorare la convalida di sicurezza SHA256 nelle impostazioni. Se si Abilita o non si configura questa impostazione dei criteri, gli utenti potranno abilitare la funzionalità di poter ignorare la convalida della sicurezza SHA256 nelle impostazioni di Windows Gestione pacchetti. Se si disabilita questa impostazione dei criteri, gli utenti non potranno abilitare la funzionalità di ignorare la convalida della sicurezza SHA256 nelle impostazioni di Windows Gestione pacchetti. - Abilita l'override dell’analisi malware dell'archivio locale + Abilita l'override dell'analisi malware dell'archivio locale di Gestione pacchetti Windows Questo criterio consente di controllare la possibilità di eseguire l'override delle analisi di vulnerabilità malware durante l'installazione di un file di archivio usando un manifesto locale usando gli argomenti della riga di comando. Se si abilita questo criterio, gli utenti potranno eseguire l'override dell'analisi antimalware durante l'installazione di un manifesto locale di un file di archivio. Se si disabilita questo criterio, gli utenti non potranno eseguire l'override dell'analisi malware di un file di archivio durante l'installazione con un manifesto locale. Se non si configura questo criterio, le impostazioni dell'amministratore di Gestione pacchetti Windows saranno conformi. - Abilita origine predefinita del programma di installazione app + Abilita l’origine predefinita di Gestione pacchetti Windows Questo criterio controlla l'origine predefinita inclusa in Gestione pacchetti Windows. Se non si configura questa impostazione, l'origine predefinita per il gestore dei pacchetti di Windows sarà disponibile e potrà essere rimossa. @@ -59,7 +59,7 @@ Se non si configura questa impostazione, l'origine predefinita per il gestore de Se si abilita questa impostazione, l'origine predefinita per Windows Gestione pacchetti sarà disponibile e non potrà essere rimossa. Se si disabilita questa impostazione, l'origine predefinita per Windows Gestione pacchetti non sarà disponibile. - Abilita l'origine Microsoft Store del programma di installazione app + Abilita l’origine di Microsoft Store di Gestione pacchetti Windows Questo criterio controlla l'origine Microsoft Store inclusa in Windows Gestione pacchetti. Se non si configura questa impostazione, l'origine Microsoft Store per il gestore dei pacchetti di Windows sarà disponibile e potrà essere rimossa. @@ -67,13 +67,13 @@ Se non si configura questa impostazione, l'origine Microsoft Store per il gestor Se si abilita questa impostazione, l'origine Microsoft Store per Windows Gestione pacchetti sarà disponibile e non potrà essere rimossa. Se si disabilita questa impostazione, l'origine Microsoft Store per Windows Gestione pacchetti non sarà disponibile. - Imposta l'intervallo di aggiornamento automatico dell'origine del programma di installazione app in minuti + Imposta l’intervallo di aggiornamento automatico di origine Gestione pacchetti Windows in minuti Questo criterio controlla l'intervallo di aggiornamento automatico per le origini basate su pacchetto. L'origine predefinita per Gestione pacchetti Windows è configurata in modo che un indice dei pacchetti venga memorizzato nella cache nel computer locale. L'indice viene scaricato quando un utente richiama un comando e l'intervallo è passato. Se si disabilita o non si configura questa impostazione, verrà utilizzato l'intervallo predefinito o il valore specificato nelle impostazioni Gestione pacchetti Windows. Se si abilita questa impostazione, il numero di minuti specificato verrà utilizzato dal Gestione pacchetti Windows. - Abilita altre origini del programma di installazione app + Abilita le origini aggiuntive di Gestione pacchetti Windows Questo criterio controlla le origini aggiuntive fornite dall'amministratore IT dell'organizzazione. Se non si configura questa impostazione dei criteri, non verrà configurata alcuna origine aggiuntiva per Windows Gestione pacchetti. @@ -81,7 +81,7 @@ Se non si configura questa impostazione dei criteri, non verrà configurata alcu Se si Abilita questo criterio, le origini aggiuntive verranno aggiunte a Windows Gestione pacchetti e non potranno essere rimosse. È possibile ottenere la rappresentazione di ogni origine aggiuntiva dalle origini installate usando 'esportazione di origine winget'. Se si disabilita questo criterio, non sarà possibile configurare altre origini per Windows Gestione pacchetti. - Abilita le origini consentite del programma di installazione app + Abilita le origini consentite di Gestione pacchetti Windows Questo criterio controlla le origini aggiuntive fornite dall'amministratore IT dell'organizzazione. Se non si configura questa impostazione dei criteri, gli utenti potranno aggiungere o rimuovere ulteriori origini oltre quelle configurate dal criterio. @@ -122,6 +122,20 @@ Se si disabilita o non si configura questa impostazione, gli utenti non potranno Se si disabilita o non si configura questa impostazione, per impostazione predefinita non verrà utilizzato alcun proxy. Se si abilita questa impostazione, per impostazione predefinita verrà utilizzato il proxy specificato. + Abilita le zone consentite del programma di installazione app per i pacchetti MSIX + Questo criterio controlla se Programma di installazione app consente l'installazione di pacchetti provenienti da aree URL specifiche. L'origine di un pacchetto è determinata dal relativo URI e dalla presenza di un Mart-of-the-Web (MotW). Se sono coinvolti più URI, vengono considerati tutti; ad esempio, quando si utilizza un file con estensione appinstaller che implica il reindirizzamento. + +Se si abilita questo criterio, gli utenti potranno installare i pacchetti MSIX in base alla configurazione per ogni area. + +Se si disabilita o non si configura questo criterio, gli utenti potranno installare pacchetti MSIX da qualsiasi area, ad eccezione di Non attendibili. + Consenti + Blocca + Abilita i controlli di Microsoft SmartScreen per i pacchetti MSIX + Questo criterio controlla se Programma di installazione app esegue controlli Microsoft SmartScreen durante l'installazione dei pacchetti MSIX. + +Se si abilita o non si configura questo criterio, l'URI del pacchetto verrà valutato con Microsoft SmartScreen prima dell'installazione. Questo controllo viene eseguito solo per i pacchetti provenienti da Internet. + +Se si disabilita, Microsoft SmartScreen non verrà avvisato prima di installare un pacchetto. @@ -138,6 +152,13 @@ Se si abilita questa impostazione, per impostazione predefinita verrà utilizzat + + Computer locale + Intranet + Siti attendibili + Internet + Siti non attendibili + diff --git a/Localization/Policies/ja-JP/DesktopAppInstaller.adml b/Localization/Policies/ja-JP/DesktopAppInstaller.adml index 2c31873a8d..3f66d6826b 100644 --- a/Localization/Policies/ja-JP/DesktopAppInstaller.adml +++ b/Localization/Policies/ja-JP/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ デスクトップ アプリ インストーラー - アプリ インストーラーを有効にする + Windows パッケージ マネージャーを有効にする このポリシーでは、ユーザーが Windows パッケージマネージャーを使用できるかどうかを制御します。 この設定を有効にした場合、または構成しなかった場合、ユーザーは Windows パッケージマネージャーを使用できます。 この設定を無効にした場合、ユーザーは Windows パッケージマネージャーを使用できなくなります。 - アプリのインストーラーの設定を有効にする + Windows パッケージ マネージャーを有効にする このポリシーでは、ユーザーが設定を変更できるかどうかを制御します。 この設定を有効にした場合、または構成しなかった場合、ユーザーは Windows パッケージマネージャーの設定を変更することができます。 この設定を無効にした場合、ユーザーは Windows パッケージマネージャーの設定を変更できなくなります。 - アプリ インストーラーの試験的な機能を有効にする + Windows パッケージ マネージャーの試験的な機能を有効にする このポリシーでは、ユーザーが Windows パッケージマネージャーで試験的な機能を有効にできるかどうかを制御します。 この設定を有効にした場合、または構成しなかった場合、ユーザーは Windows パッケージマネージャーに対して実験的な機能を有効にすることができます。 この設定を無効にした場合、ユーザーは Windows パッケージマネージャーの実験的な機能を有効にできなくなります。 - アプリ インストーラーのローカル マニフェスト ファイルを有効にする + Windows パッケージ マネージャーのローカル マニフェスト ファイルを有効にする このポリシーでは、ローカルマニフェストファイルを含むパッケージをユーザーがインストールできるかどうかを制御します。 この設定を有効にした場合、または構成しなかった場合、ユーザーは Windows パッケージマネージャーを使用してローカルのマニフェストを含むパッケージをインストールできます。 この設定を無効にした場合、ユーザーは Windows パッケージマネージャーを使用してローカルのマニフェストを含むパッケージをインストールできなくなります。 - アプリ インストーラーでの Microsoft Store ソースの固定証明書のバイパスを有効にする + Windows パッケージ マネージャーでの Microsoft Store ソースの証明書検証バイパスを有効にする このポリシーでは、Microsoft Store ソースへの接続を開始するときに、Windows パッケージ マネージャーが既知の Microsoft Store 証明書と一致する Microsoft Store 証明書ハッシュを検証するかどうかを制御します。 このポリシーを有効にした場合、Windows パッケージ マネージャーは Microsoft Store 証明書の検証をバイパスします。 このポリシーを無効にした場合、Windows パッケージ マネージャーは、Microsoft Store ソースと通信する前に、使用されている Microsoft Store 証明書が有効であり、Microsoft Store に属していることを検証します。 このポリシーを構成しなかった場合は、Windows パッケージ マネージャー管理者の設定が適用されます。 - アプリ インストーラーのハッシュ上書きを有効にする + Windows パッケージ マネージャーのハッシュ オーバーライドを有効にする このポリシーでは、設定の SHA256 セキュリティ検証を上書きする機能を有効にできるように Windows パッケージ マネージャーを構成できるかどうかを制御します。 このポリシーを有効にした場合、または構成しなかった場合、ユーザーは Windows パッケージ マネージャーの設定で SHA256 セキュリティ検証を上書きする機能を有効にすることができます。 このポリシーを無効にした場合、ユーザーは Windows パッケージ マネージャーの設定で SHA256 セキュリティ検証を上書きする機能を有効することができなくなります。 - アプリ インストーラー ローカル アーカイブ マルウェア スキャンの上書きを有効にする + Windows パッケージ マネージャーでのローカル アーカイブ マルウェア スキャンのオーバーライドを有効にする このポリシーでは、コマンド ライン引数を使用してローカル マニフェストを使用してアーカイブ ファイルをインストールするときに、マルウェアの脆弱性スキャンをオーバーライドする機能を制御します。 このポリシーを有効にした場合、アーカイブ ファイルのローカル マニフェストのインストールを実行するときに、ユーザーはマルウェア スキャンをオーバーライドできます。 このポリシーを無効にすると、ユーザーはローカル マニフェストを使用してインストールするときにアーカイブ ファイルのマルウェア スキャンをオーバーライドできなくなります。 このポリシーを構成しなかった場合は、Windows パッケージ マネージャー管理者の設定が適用されます。 - アプリ インストーラーの既定のソースを有効にする + Windows パッケージ マネージャーの既定のソースを有効にする このポリシーでは、Windows パッケージ マネージャーに含まれている 既定ソースを制御します。 この設定を構成しなかった場合、Windows パッケージ マネージャーの 既定ソースが利用可能になり、削除できるようになります。 @@ -59,7 +59,7 @@ この設定を有効にした場合、Windows パッケージ マネージャーの 既定ソースが利用できるようになり、削除できなくなります。 この設定を無効にした場合、Windows パッケージマ ネージャーの 既定ソースは利用できなくなります。 - アプリ インストーラー Microsoft Store ソースを有効にする + Windows パッケージ マネージャーの Microsoft Store ソースを有効にする このポリシーでは、Windows パッケージ マネージャーに含まれている Microsoft Store ソースを制御します。 この設定を構成しなかった場合、Windows パッケージ マネージャーの Microsoft Store ソースが利用可能になり、削除できるようになります。 @@ -67,13 +67,13 @@ この設定を有効にした場合、Windows パッケージ マネージャーの Microsoft Store ソースが利用できるようになり、削除できなくなります。 この設定を無効にした場合、Windows パッケージマ ネージャーの Microsoft Store ソースは利用できなくなります。 - アプリ インストーラー ソースの自動更新間隔を分単位で設定します + Windows パッケージ マネージャーのソース自動更新間隔を分単位で設定する このポリシーは、パッケージ ベースのソースの自動更新間隔を制御します。Windows パッケージ マネージャーの既定のソースは、パッケージのインデックスがローカル コンピューターにキャッシュされるように構成されています。インデックスは、ユーザーがコマンドを呼び出し、間隔が過ぎたときにダウンロードされます。 この設定を無効にした場合、または構成しなかった場合は、既定の間隔またはWindows パッケージ マネージャー設定で指定された値が使用されます。 この設定を有効にした場合、指定した分数がWindows パッケージ マネージャーで使用されます。 - アプリ インストーラーの追加ソースを有効にする + Windows パッケージ マネージャーの追加のソースを有効にする このポリシーは、エンタープライズIT管理者によって提供される追加のソースを制御します。 このポリシーを構成しない場合、Windows パッケージ マネージャー用に追加のソースは構成されません。 @@ -81,7 +81,7 @@ このポリシーを有効にすると、追加のソースが Windows パッケージ マネージャーに追加され、削除できなくなります。 追加の各ソースの表現は、「wingetsourceexport」を使用してインストールされたソースから取得できます。 このポリシーを無効にすると、Windows パッケージ マネージャーに追加のソースを構成できなくなります。 - アプリ インストーラーの許可されたソースを有効にする + Windows パッケージ マネージャーの許可されたソースを有効にする このポリシーは、エンタープライズ IT 管理者が許可する追加のソースを制御します。 このポリシーを構成しない場合、ユーザーはポリシーで構成されたソース以外のソースを追加または削除できます。 @@ -122,6 +122,20 @@ この設定を無効にした場合、または構成しなかった場合、既定ではプロキシは使用されません。 この設定を有効にした場合、指定したプロキシが既定で使用されます。 + MSIX パッケージアプリ インストーラー許可されたゾーンを有効にする + このポリシーでは、アプリ インストーラーが特定の URL ゾーンからのパッケージのインストールを許可するかどうかを制御します。パッケージの配信元は、その URI と、Mart-of-the-Web (MotW) が存在するかどうかによって決まります。複数の URI が含まれている場合、すべてが考慮されます。たとえば、リダイレクトを含む .appinstaller ファイルを使用する場合などです。 + +このポリシーを有効にした場合、ユーザーは各ゾーンの構成に従って MSIX パッケージをインストールできます。 + +このポリシーを無効にするか、未構成にした場合、ユーザーは信頼されていないゾーン以外のゾーンから MSIX パッケージをインストールできます。 + 許可 + ブロック + MSIX パッケージの Microsoft SmartScreen チェックを有効にする + このポリシーでは、MSIX パッケージのインストール時にアプリ インストーラーが Microsoft SmartScreen チェックを実行するかどうかを制御します。 + +このポリシーを有効にするか、未構成にした場合、インストール前にパッケージ URI が Microsoft SmartScreen で評価されます。このチェックは、インターネットからのパッケージに対してのみ実行されます。 + +無効にした場合、パッケージをインストールする前に Microsoft SmartScreen に問い合わせてください。 @@ -138,6 +152,13 @@ + + ローカル コンピューター + イントラネット + 信頼済みサイト + インターネット + 信頼できないサイト + diff --git a/Localization/Policies/ko-KR/DesktopAppInstaller.adml b/Localization/Policies/ko-KR/DesktopAppInstaller.adml index 9bbc425ce6..e16399ddba 100644 --- a/Localization/Policies/ko-KR/DesktopAppInstaller.adml +++ b/Localization/Policies/ko-KR/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ 데스크톱 앱 설치 관리자 - 앱 설치 관리자 사용 + Windows 패키지 관리자 사용 이 정책은 사용자가 Windows 패키지 관리자를 사용할 수 있는지 여부를 제어합니다. 이 설정을 사용하거나 구성하지 않으면 사용자가 Windows 패키지 관리자를 사용할 수 있습니다. 이 설정을 사용하지 않으면 사용자가 Windows 패키지 관리자를 사용할 수 없습니다. - 앱 설치 관리자 설정 사용 + Windows 패키지 관리자 설정 사용 이 정책은 사용자가 설정을 변경할 수 있는지 여부를 제어합니다. 이 설정을 사용하도록 설정하거나 구성하지 않으면 사용자가 Windows 패키지 관리자의 설정을 변경할 수 있습니다. 이 설정을 사용하지 않으면 사용자가 Windows 패키지 관리자의 설정을 변경할 수 없습니다. - 앱 설치 관리자 실험적 기능 사용 + Windows 패키지 관리자 실험적 기능 사용 이 정책은 사용자가 Windows 패키지 관리자에서 실험적인 기능을 사용하도록 설정할 수 있는지 여부를 제어합니다. 이 설정을 사용하거나 구성하지 않으면 사용자가 Windows 패키지 관리자를 위해 실험적 기능을 사용할 수 있습니다. 이 설정을 사용하지 않도록 설정하면 사용자가 Windows 패키지 관리자를 위해 실험적 기능을 사용할 수 없습니다. - 앱 설치 관리자 로컬 매니페스트 파일 사용 + Windows 패키지 관리자 로컬 매니페스트 파일 사용 이 정책은 사용자가 로컬 매니페스트 파일을 사용하여 패키지를 설치할 수 있는지 여부를 제어합니다. 이 설정을 사용하거나 구성하지 않으면 사용자는 Windows 패키지 관리자를 사용하여 로컬 매니페스트와 함께 패키지를 설치할 수 있습니다. 이 설정을 사용하지 않으면 사용자는 Windows 패키지 관리자를 사용하여 로컬 매니페스트를 통해 패키지를 설치할 수 없습니다. - 앱 설치 관리자 Microsoft Store 원본 인증서 유효성 검사 바이패스 사용 + Windows 패키지 관리자 Microsoft Store 원본 인증서 유효성 검사 바이패스 사용 이 정책은 Windows 패키지 관리자가 Microsoft 저장소 원본에 대한 연결을 시작할 때 알려진 Microsoft Store 인증서와 일치하는 Microsoft 저장소 인증서 해시의 유효성을 검사할지 여부를 제어합니다. 이 정책을 사용하면 Windows 패키지 관리자는 Microsoft 저장소 인증서 유효성 검사를 무시합니다. 이 정책을 사용하지 않으면 Windows 패키지 관리자는 Microsoft Store 원본과 통신하기 전에 사용된 Microsoft 저장소 인증서가 유효하고 Microsoft 저장소에 속하는지 확인합니다. 이 정책을 구성하지 않으면 Windows 패키지 관리자의 관리자 설정이 적용됩니다. - 앱 설치 관리자 해시 재정의 사용 + Windows 패키지 관리자 해시 재정의 사용 이 정책은 설정에서 SHA256 보안 유효성 검사를 재정의하도록 Windows 패키지 관리자를 구성할 수 있는지 여부를 제어합니다. 이 정책을 실행하거나 구성하지 않으면 Windows 패키지 관리자 설정에서 SHA256 보안 유효성 검사를 재정의하는 기능을 사용할 수 있습니다. 이 정책을 실행 중지하면 Windows 패키지 관리자 설정에서 SHA256 보안 유효성 검사를 재정의하는 기능을 사용자가 사용하도록 설정할 수 없습니다. - 앱 설치 관리자 로컬 보관 맬웨어 검사 재정의 사용 + Windows 패키지 관리자 로컬 보관 맬웨어 검사 재정의 사용 이 정책은 명령줄 인수를 사용하여 로컬 매니페스트를 사용하여 보관 파일을 설치할 때 맬웨어 취약성 검사를 재정의하는 기능을 제어합니다. 이 정책을 사용하면 사용자가 보관 파일의 로컬 매니페스트 설치를 수행할 때 맬웨어 검사를 재정의할 수 있습니다. 이 정책을 사용하지 않으면 로컬 매니페스트를 사용하여 설치할 때 사용자가 보관 파일의 맬웨어 검사를 재정의할 수 없습니다. 이 정책을 구성하지 않으면 Windows 패키지 관리자 관리자 설정이 적용됩니다. - 앱 설치 관리자 기본 원본 사용 + Windows 패키지 관리자 기본 원본 사용 이 정책은 Windows 패키지 관리자에 포함된 기본 원본을 제어합니다. 이 설정을 구성하지 않는 경우 Windows 패키지 관리자의 기본 원본을 사용할 수 있으며 제거할 수 있습니다. @@ -59,7 +59,7 @@ 이 설정을 사용하면 Windows 패키지 관리자의 기본 원본을 사용할 수 있으며 제거할 수 없습니다. 이 설정을 사용하지 않도록 설정하면 Windows 패키지 관리자의 기본 원본을 사용할 수 없습니다. - 앱 설치 관리자 Microsoft 스토어 원본 사용 + Windows 패키지 관리자 Microsoft Store 원본 사용 이 정책은 Windows 패키지 관리자에 포함된 Microsoft 스토어 원본을 제어합니다. 이 설정을 구성하지 않는 경우 Windows 패키지 관리자의 Microsoft 스토어 원본을 사용할 수 있으며 제거할 수 있습니다. @@ -67,13 +67,13 @@ 이 설정을 사용하면 Windows 패키지 관리자용 Microsoft 스토어 원본을 사용할 수 있으며 제거할 수 없습니다. 이 설정을 사용 중지하면 Windows 패키지 관리자용 Microsoft 스토어 원본을 사용할 수 없습니다. - 앱 설치 관리자 원본 자동 업데이트 간격(분) 설정 + Windows 패키지 관리자 원본 자동 업데이트 간격(분) 설정 이 정책은 패키지 기반 원본의 자동 업데이트 간격을 제어합니다. 패키지의 인덱스가 로컬 컴퓨터에 캐시되도록 Windows 패키지 관리자 기본 원본이 구성됩니다. 사용자가 명령을 호출하고 간격이 지나면 인덱스가 다운로드됩니다. 이 설정을 사용하지 않거나 구성하지 않으면 Windows 패키지 관리자 설정에 지정된 기본 간격 또는 값이 사용됩니다. 이 설정을 사용하면 지정한 시간(분)이 Windows 패키지 관리자 사용됩니다. - 앱 설치 관리자 추가 원본 사용 + Windows 패키지 관리자 추가 원본 사용 이 정책은 엔터프라이즈 IT 관리자가 제공하는 추가 원본을 제어합니다. 정책을 구성하지 않는 경우 Windows 패키지 관리자에 대해 추가 원본이 구성되지 않습니다. @@ -81,7 +81,7 @@ 정책을 사용하도록 설정하면 추가 원본이 Windows 패키지 관리자에 추가되고 제거할 수 없습니다. 'winget 원본 내보내기'를 사용하여 설치된 원본에서 각 추가 원본에 대한 표현을 얻을 수 있습니다. 이 정책을 사용하지 않도록 설정하는 경우 Windows 패키지 관리자에 대해 추가 원본을 구성할 수 없습니다. - 앱 설치 관리자 허용된 원본 사용 + Windows 패키지 관리자 허용된 원본 사용 이 정책은 엔터프라이즈 IT 관리자가 허용하는 추가 원본을 제어합니다. 이 정책을 구성하지 않는 경우 사용자는 정책에 의해 구성된 원본 외의 다른 원본을 추가하거나 제거할 수 있습니다. @@ -122,6 +122,20 @@ 이 설정을 사용하지 않거나 구성하지 않으면 기본적으로 프록시가 사용되지 않습니다. 이 설정을 사용하면 지정된 프록시가 기본적으로 사용됩니다. + MSIX 패키지에 대해 앱 설치 관리자 허용된 영역 사용 + 이 정책은 앱 설치 관리자 특정 URL 영역에서 시작되는 패키지를 설치할 수 있는지 여부를 제어합니다. 패키지의 원본은 해당 URI에 따라 결정되며 MotW(Mart-of-the-Web)가 있는지 여부를 결정합니다. 여러 URI가 관련된 경우 모두 고려됩니다. 예를 들어 리디렉션과 관련된 .appinstaller 파일을 사용하는 경우 + +이 정책을 사용하면 사용자가 각 영역의 구성에 따라 MSIX 패키지를 설치할 수 있습니다. + +이 정책을 사용하지 않거나 구성하지 않으면 신뢰할 수 없음을 제외한 모든 영역에서 MSIX 패키지를 설치할 수 있습니다. + 허용 + 차단 + MSIX 패키지에 Microsoft SmartScreen 검사 사용 + 이 정책은 MSIX 패키지를 설치할 때 앱 설치 관리자 Microsoft SmartScreen 검사를 수행할지 여부를 제어합니다. + +이 정책을 사용하거나 구성하지 않으면 설치 전에 Microsoft SmartScreen을 사용하여 패키지 URI가 평가됩니다. 이 검사 인터넷에서 가져온 패키지에 대해서만 수행됩니다. + +사용하지 않도록 설정하면 패키지를 설치하기 전에 Microsoft SmartScreen을 참조하지 않습니다. @@ -138,6 +152,13 @@ + + 로컬 컴퓨터 + 인트라넷 + 신뢰할 수 있는 사이트 + 인터넷 + 신뢰할 수 없는 사이트 + diff --git a/Localization/Policies/pt-BR/DesktopAppInstaller.adml b/Localization/Policies/pt-BR/DesktopAppInstaller.adml index d8ad3bb50b..3dfe138475 100644 --- a/Localization/Policies/pt-BR/DesktopAppInstaller.adml +++ b/Localization/Policies/pt-BR/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ Instalador de Aplicativos de Área de Trabalho - Habilitar o Instalador de Aplicativos + Habilitar o Gerenciador de Pacotes do Windows Esta política controla se o Gerenciador de pacotes do Windows pode ser usado por usuários. Se você habilitar ou não definir essa configuração, os usuários poderão usar o Gerenciador de pacotes do Windows. Se você desabilitar essa configuração, os usuários não poderão usar o Gerenciador de pacotes do Windows. - Habilitar as Configurações do Instalador de Aplicativos + Habilitar as Configurações do Gerenciador de Pacotes do Windows Esta política controla se os usuários podem alterar suas configurações. Se você habilitar ou não definir essa configuração, os usuários poderão alterar as configurações do Gerenciador de pacotes do Windows. Se você desabilitar essa configuração, os usuários não poderão alterar configurações para o Gerenciador de pacotes do Windows. - Habilitar os Recursos Experimentais do Instalador de Aplicativos + Habilitar Recursos Experimentais do Gerenciador de Pacotes do Windows Essa política controla se os usuários podem habilitar recursos experimentais no Gerenciador de pacotes do Windows. Se você habilitar ou não definir essa configuração, os usuários poderão habilitar recursos experimentais para o Gerenciador de pacotes do Windows. Se você desabilitar essa configuração, os usuários não poderão habilitar os recursos experimentais do Gerenciador de pacotes do Windows. - Habilitar os Arquivos de Manifesto Local do Instalador de Aplicativos + Habilitar Arquivos de Manifesto Local do Gerenciador de Pacotes do Windows Essa política controla se os usuários podem instalar pacotes com arquivos de manifesto locais. Se você habilitar ou não definir essa configuração, os usuários poderão instalar pacotes com manifestos locais usando o Gerenciador de pacotes do Windows. Se você desabilitar essa configuração, os usuários não poderão instalar pacotes com manifestos locais usando o Gerenciador de pacotes do Windows. - Habilitar Bypass de Validação de Certificado de Origem da Microsoft Store do Instalador de Aplicativos + Habilitar Bypass Gerenciador de Pacotes do Windows Microsoft Store Certificado de Origem Essa política controla se o Gerenciador de Pacotes do Windows validará se o hash do certificado Microsoft Store corresponde a um certificado Microsoft Store conhecido ao iniciar uma conexão com a Origem da Microsoft Store. Se você habilitar essa política, o Gerenciador de Pacotes do Windows ignorará a validação do certificado da Microsoft Store. Se você desabilitar essa política, o Gerenciador de Pacotes do Windows validará se o certificado Microsoft Store usado é válido e pertence ao Microsoft Store antes de se comunicar com a origem da Microsoft Store. Se você não definir essa política, as configurações de administrador do Gerenciador de Pacotes do Windows serão aderidas. - Habilitar a Substituição do Hash do Instalador de Aplicativos + Habilitar a Substituição de Hash do Gerenciador de Pacotes do Windows Esta política controla se o Gerenciador de Pacotes do Windows pode ou não ser configurado para permitir a capacidade de substituição da validação de segurança SHA256 nas configurações. Se você habilitar ou não configurar esta política, os usuários poderão habilitar a capacidade de substituição da validação de segurança SHA256 nas configurações do Gerenciador de Pacotes do Windows. Se você desabilitar esta política, os usuários não poderão habilitar a capacidade de substituição da validação de segurança SHA256 nas configurações do Gerenciador de Pacotes do Windows. - Habilitar Instalador de Aplicativo Verificação de Malware de Arquivo Morto Local + Habilitar Gerenciador de Pacotes do Windows Verificação de Malware de Arquivo Morto Local Esta política controla a capacidade de substituir verificações de vulnerabilidade de malware ao instalar um arquivo morto usando um manifesto local usando os argumentos de linha de comando. Se você habilitar essa política, os usuários poderão substituir a verificação de malware ao executar uma instalação de manifesto local de um arquivo morto. Se você desabilitar essa política, os usuários não poderão substituir a verificação de malware de um arquivo morto durante a instalação usando um manifesto local. Se você não configurar essa política, as configurações Gerenciador de Pacotes do Windows administrador serão aderidas. - Habilitar a Fonte Padrão do Instalador de Aplicativos + Habilitar a Fonte Padrão do Gerenciador de Pacotes do Windows Esta política controla a fonte padrão incluída no Gerenciador de Pacotes do Windows. Se você não definir essa configuração, a fonte padrão do Gerenciador de Pacotes do Windows estará disponível e poderá ser removida. @@ -59,7 +59,7 @@ Se você não definir essa configuração, a fonte padrão do Gerenciador de Pac Se você habilitar essa configuração, a fonte padrão para o Gerenciador de Pacotes do Windows estará disponível e não poderá ser removida. Se você desabilitar esta configuração, a fonte padrão para o Gerenciador de Pacotes do Windows não estará disponível. - Habilitar a Fonte da Microsoft Store do Instalador de Aplicativos + Habilitar a Fonte da Microsoft Store do Gerenciador de Pacotes do Windows Esta política controla a fonte da Microsoft Store incluída com o Gerenciador de Pacotes do Windows. Se você não definir essa configuração, a fonte da Microsoft Store para o Gerenciador do Pacote Windows estará disponível e poderá ser removida. @@ -67,13 +67,13 @@ Se você não definir essa configuração, a fonte da Microsoft Store para o Ger Se você habilitar essa configuração, a fonte da Microsoft Store para o Gerenciador de Pacotes do Windows estará disponível e não poderá ser removida. Se você desabilitar esta configuração, a fonte da Microsoft Store para o Gerenciador de Pacotes do Windows não estará disponível. - Definir o Intervalo de Atualização Automática da Fonte do Instalador de Aplicativo em Minutos + Definir o Intervalo de Atualização Automática da Fonte do Gerenciador de Pacotes do Windows em Minutos Esta política controla o intervalo de atualização automática para origens baseadas em pacote. A fonte padrão para Gerenciador de Pacotes do Windows é configurada de modo que um índice dos pacotes seja armazenado em cache no computador local. O índice é baixado quando um usuário invoca um comando e o intervalo é passado. Se você desabilitar ou não definir essa configuração, o intervalo padrão ou o valor especificado na Gerenciador de Pacotes do Windows configurações serão usadas. Se você habilitar essa configuração, o número de minutos especificado será usado pelo Gerenciador de Pacotes do Windows. - Habilitar as Fontes Adicionais do Instalador de Aplicativos + Habilitar Fontes Adicionais do Gerenciador de Pacotes do Windows Esta política controla as fontes adicionais fornecidas pelo administrador de TI da empresa. Se você não configurar esta política, nenhuma fonte adicional será configurada para o Gerenciador de Pacotes do Windows. @@ -81,7 +81,7 @@ Se você não configurar esta política, nenhuma fonte adicional será configura Se você habilitar essa política, as fontes adicionais serão adicionadas ao Gerenciador de Pacotes do Windows e não poderão ser removidas. A representação de cada fonte adicional poderá ser obtida a partir das fontes instaladas usando a 'exportação de fonte de winget'. Se você desabilitar esta política, nenhuma fonte adicional poderá ser configurada para o Gerenciador de Pacotes do Windows. - Habilitar as Fontes Permitidas do Instalador de Aplicativos + Habilitar Fontes Permitidas do Gerenciador de Pacotes do Windows Esta política controla as fontes adicionais permitidas pelo administrador de TI da empresa. Se você não configurar esta política, os usuários poderão adicionar ou remover fontes adicionais além daquelas configuradas pela política. @@ -122,6 +122,20 @@ Se você desabilitar ou não definir essa configuração, os usuários não pode Se você desabilitar ou não definir essa configuração, nenhum proxy será usado por padrão. Se você habilitar essa configuração, o proxy especificado será usado por padrão. + Habilitar Zonas Permitidas do Instalador de Aplicativo para Pacotes MSIX + Esta política controla se Instalador de Aplicativo permite a instalação de pacotes originados de Zonas de URL específicas. A origem de um pacote é determinada por seu URI e se um Mart-of-the-Web (MotW) está presente. Se vários URIs forem envolvidos, todos eles serão considerados; por exemplo, ao usar um arquivo .appinstaller que envolve redirecionamento. + +Se você habilitar essa política, os usuários poderão instalar pacotes MSIX de acordo com a configuração de cada zona. + +Se você desabilitar ou não configurar esta política, os usuários poderão instalar pacotes MSIX de qualquer zona, exceto por Não Confiável. + Permitir + Bloquear + Habilitar verificações do Microsoft SmartScreen para Pacotes MSIX + Esta política controla se Instalador de Aplicativo verificações do Microsoft SmartScreen ao instalar pacotes MSIX. + +Se você habilitar ou não configurar essa política, o URI do pacote será avaliado com o Microsoft SmartScreen antes da instalação. Este marcar é feito somente para pacotes provenientes da Internet. + +Se você desabilitar, o Microsoft SmartScreen não será consultado antes de instalar um pacote. @@ -138,6 +152,13 @@ Se você habilitar essa configuração, o proxy especificado será usado por pad + + Computador Local + Intranet + Sites Confiáveis + Internet + Sites Não Confiáveis + diff --git a/Localization/Policies/ru-RU/DesktopAppInstaller.adml b/Localization/Policies/ru-RU/DesktopAppInstaller.adml index b7e8caca52..fee746baff 100644 --- a/Localization/Policies/ru-RU/DesktopAppInstaller.adml +++ b/Localization/Policies/ru-RU/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ Установщик классических приложений - Включить Установщик приложений + Включить Диспетчер пакетов Windows Эта политика определяет, могут ли пользователи использовать Диспетчер пакетов Windows. Если включить или не настроить этот параметр, пользователи смогут использовать Диспетчер пакетов Windows. Если отключить этот параметр, пользователи не смогут использовать Диспетчер пакетов Windows. - Включить параметры Установщика приложений + Включить параметры Диспетчера пакетов Windows Эта политика определяет, могут ли пользователи изменять свои параметры. Если включить или не настроить этот параметр, пользователи смогут изменять параметры Диспетчера пакетов Windows. Если отключить этот параметр, пользователи не смогут изменять параметры Диспетчера пакетов Windows. - Включить экспериментальные функции Установщика приложений + Включить экспериментальные функции Диспетчера пакетов Windows Этот параметр политики определяет, могут ли пользователи включать экспериментальные функции в диспетчер пакетов Windows. Если включить или не настроить этот параметр, пользователи смогут включать экспериментальные функции для диспетчер пакетов Windows. Если этот параметр отключен, пользователи не смогут включать экспериментальные функции для диспетчер пакетов Windows. - Включить локальные файлы манифестов Установщика приложений + Включить файлы локальных манифестов Диспетчера пакетов Windows Эта политика определяет, могут ли пользователи устанавливать пакеты с локальными файлами манифестов. Если включить или не настроить этот параметр, пользователи смогут устанавливать пакеты с локальными манифестами с помощью Диспетчера пакетов Windows. Если отключить этот параметр, пользователи не смогут устанавливать пакеты с локальными манифестами с помощью Диспетчера пакетов Windows. - Включение обхода проверки исходного сертификата Microsoft Store для установщика приложений + Включить обход проверки сертификата источника Microsoft Store в Диспетчере пакетов Windows Эта политика определяет, будет ли Диспетчер пакетов Windows проверять соответствие хэша сертификата Microsoft Store известному сертификату Microsoft Store при инициации подключения к источнику Microsoft Store. При включении этой политики диспетчер пакетов Windows будет обходить проверку сертификата Microsoft Store. При отключении этой политики диспетчер пакетов Windows будет проверять принадлежность используемого сертификата Microsoft Store и его действительность, прежде чем связываться с источником Microsoft Store.. Если эта политика не настроена, будут соблюдаться параметры администратора диспетчера пакетов Windows. - Включить переопределение хэша Установщика приложений + Включить переопределение хэша Диспетчера пакетов Windows Этот параметр политики определяет, можно ли настроить Диспетчер пакетов Windows, чтобы включить возможность переопределения параметров проверки безопасности SHA256 в настройках. Если данный параметр политики включен или не настроен, пользователи получат возможность переопределять проверку безопасности SHA256 в параметрах Диспетчера пакетов Windows. Если данный параметр политики отключен, пользователи не смогут переопределять проверку безопасности SHA256 в параметрах Диспетчера пакетов Windows. - Включение блокировки сканирования вредоносных программ в локальном архиве установщика приложений + Включить переопределение сканирования вредоносных программ в локальном архиве Диспетчера пакетов Windows Эта политика управляет возможностью переопределения сканирования уязвимостей вредоносных программ при установке файла архива с использованием локального манифеста с использованием аргументов командной строки. При включении этой политики пользователи смогут переопределять сканирование вредоносных программ при выполнении локальной установки манифеста архивного файла. При отключении этой политики пользователи не смогут переопределять сканирование архивного файла на наличие вредоносных программ при установке с использованием локального манифеста. Если эта политика не настроена, будут соблюдаться параметры администратора диспетчера пакетов Windows. - Включить источник по умолчанию Установщика приложений + Включить источник по умолчанию для Диспетчера пакетов Windows Эта политика управляет источником по умолчанию, входящим в состав Диспетчера пакетов Windows. Если не задать этот параметр, источник по умолчанию для Диспетчера пакетов Windows будет доступен, и его можно будет удалить. @@ -59,7 +59,7 @@ Если включить этот параметр, источник по умолчанию для Диспетчера пакетов Windows будет доступен, и его нельзя будет удалить. Если отключить этот параметр, источник по умолчанию для Диспетчера пакетов Windows будет недоступен. - Включить источник Microsoft Store Установщика приложений + Включить источник Microsoft Store в Диспетчере пакетов Windows Эта политика управляет источником Microsoft Store, входящим в состав Диспетчера пакетов Windows. Если не задать этот параметр, источник Microsoft Store для Диспетчера пакетов Windows будет доступен, и его можно будет удалить. @@ -67,13 +67,13 @@ Если включить этот параметр, источник Microsoft Store для Диспетчера пакетов Windows будет доступен, и его нельзя будет удалить. Если отключить этот параметр, источник Microsoft Store для Диспетчера пакетов Windows будет недоступен. - Задать интервал автоматического обновления источника Установщика приложений в минутах + Задать интервал автоматического обновления источника Диспетчера пакетов Windows в минутах Эта политика управляет интервалом автоматического обновления для источников на основе пакетов. Источник по умолчанию для Диспетчера пакетов Windows настроен таким образом, что индекс пакетов кэшируется на локальном компьютере. Индекс скачивается при вызове команды пользователем и завершении интервала. Если этот параметр отключен или не настроен, будет использоваться интервал по умолчанию или значение, указанное в параметрах Диспетчера пакетов Windows. Если этот параметр включен, указанное число минут будет использоваться Диспетчером пакетов Windows. - Включить дополнительные источники Установщика приложений + Включить дополнительные источники Диспетчера пакетов Windows Эта политика управляет дополнительными источниками, предоставленными ИТ-администратором предприятия. Если не настроить эту политику, дополнительные источники для Диспетчера пакетов Windows не будут настроены. @@ -81,7 +81,7 @@ Если включить эту политику, дополнительные источники будут добавлены в Диспетчер пакетов Windows, и их нельзя будет удалить. Представление для каждого дополнительного источника можно получить из установленных источников с помощью команды "winget source export". Если отключить эту политику, задать дополнительные источники для Диспетчера пакетов Windows будет невозможно. - Включить разрешенные источники Установщика приложений + Включить разрешенные источники Диспетчера пакетов Windows Эта политика управляет дополнительными источниками, разрешенными ИТ-администратором предприятия. Если не настроить эту политику, пользователи смогут добавлять и удалять дополнительные источники помимо заданных в политике. @@ -122,6 +122,20 @@ Если этот параметр отключен или не настроен, по умолчанию прокси-сервер не будет использоваться. Если этот параметр включен, указанный прокси-сервер будет использоваться по умолчанию. + Включить разрешенные зоны Установщика приложений для пакетов MSIX + Эта политика определяет, Установщик приложений ли установка пакетов, полученных из определенных зон URL-адресов. Источник пакета определяется его URI и наличием киоска в Интернете (MotW). Если включено несколько URI, все они считаются; например, при использовании appinstaller-файла, который включает перенаправление. + +Если эта политика включена, пользователи смогут устанавливать пакеты MSIX в соответствии с конфигурацией для каждой зоны. + +Если эта политика отключена или не настроена, пользователи смогут устанавливать пакеты MSIX из любой зоны, кроме ненадежных. + Разрешить + Блокировать + Включить проверки Microsoft SmartScreen для пакетов MSIX + Эта политика определяет, Установщик приложений ли фильтр SmartScreen (Майкрософт) при установке пакетов MSIX. + +Если эта политика включена или не настроена, URI пакета будет проверяться с помощью фильтра SmartScreen (Майкрософт) перед установкой. Эта проверка только для пакетов, поступающих из Интернета. + +Если отключить этот параметр, microsoft SmartScreen не будет проверяться перед установкой пакета. @@ -138,6 +152,13 @@ + + Локальный компьютер + Интрасеть + Надежные сайты + Интернет + Ненадежные сайты + diff --git a/Localization/Policies/zh-CN/DesktopAppInstaller.adml b/Localization/Policies/zh-CN/DesktopAppInstaller.adml index a09e6e4df2..e85544cb98 100644 --- a/Localization/Policies/zh-CN/DesktopAppInstaller.adml +++ b/Localization/Policies/zh-CN/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ 桌面应用安装程序 - 启用应用安装程序 + 启用 Windows 程序包管理器 此策略控制用户是否可以使用 Windows 程序包管理器。 如果启用或未配置此设置,则用户可以使用 Windows 程序包管理器。 如果禁用此设置,则用户将无法使用 Windows 程序包管理器。 - 启用应用安装程序设置 + 启用 Windows 程序包管理器设置 此策略控制用户是否可以更改其设置。 如果启用或未配置此设置,则用户可以更改 Windows 程序包管理器的设置。 如果禁用此设置,则用户将无法更改 Windows 程序包管理器的设置。 - 启用应用安装程序实验性功能 + 启用 Windows 程序包管理器实验性功能 此策略控制用户是否可以在 Windows 程序包管理器中启用实验性功能。 如果启用或未配置此设置,则用户将能够为 Windows 包管理器启用实验性功能。 如果禁用此设置,则用户将无法启用 Windows 包管理器的实验性功能。 - 启用应用安装程序本地清单文件 + 启用 Windows 程序包管理器本地清单文件 此策略控制用户是否可以使用本地清单文件安装程序包。 如果启用或未配置此设置,则用户可以使用 Windows 程序包管理器在本地清单中安装包。 如果禁用此设置,则用户将无法使用 Windows 程序包管理器在本地清单中安装包。 - 启用应用安装程序 Microsoft Store 源证书验证绕过 + 启用Windows 程序包管理器Microsoft Store源证书验证绕过 此策略控制 Windows 程序包管理器在发起与 Microsoft Store 源的连接时是否验证 Microsoft Store 证书哈希与已知的 Microsoft Store 证书的匹配情况。 如果启用此策略,Windows 程序包管理器将绕过 Microsoft Store 证书验证。 如果禁用此策略,则 Windows 程序包管理器在与 Microsoft Store 源通信之前,将验证所使用的 Microsoft Store 证书是否有效且属于 Microsoft Store。 如果未配置此策略,则将遵循 Windows 程序包管理器的管理员设置。 - 启用应用安装程序哈希替代 + 启用 Windows 程序包管理器哈希替代 此策略控制是否可以配置 Windows 程序包管理器,以便在设置中启用覆盖 SHA256 安全验证的能力。 如果启用或未配置此策略,则用户将能够在 Windows 程序包管理器设置中启用覆盖 SHA256 安全验证的能力。 如果禁用此策略,则用户将无法在 Windows 程序包管理器设置中启用覆盖 SHA256 安全验证的能力。 - 启用应用安装程序本地存档恶意软件扫描替代 + 启用Windows 程序包管理器本地存档恶意软件扫描替代 此策略控制在使用命令行参数通过本地清单安装存档文件时替代恶意软件漏洞扫描的能力。 如果启用此策略,则用户可以在对存档文件执行本地清单安装时替代恶意软件扫描。 如果禁用此策略,则在使用本地清单进行安装时,用户将无法替代对存档文件的恶意软件扫描。 如果未配置此策略,则将遵循 Windows 程序包管理器的管理员设置。 - 启用应用安装程序默认源 + 启用 Windows 程序包管理器默认源 此策略控制 Windows 程序包管理器中包含的默认源。 如果未配置此设置,Windows 程序包管理器的默认源将可用并可删除。 @@ -59,7 +59,7 @@ 如果启用此设置,Windows 程序包管理器的默认源将可用,无法删除。 如果禁用此设置,Windows 程序包管理器的默认源将不可用。 - 启用应用安装程序 Microsoft Store 源 + 启用 Windows 程序包管理器 Microsoft Store 源 此策略控制 Windows 程序包管理器中包含的 Microsoft Store 源。 如果未配置此设置,Windows 程序包管理器的 Microsoft Store 源将可用并可删除。 @@ -67,13 +67,13 @@ 如果启用此设置,Windows 程序包管理器的 Microsoft Store 源将可用,无法删除。 如果禁用此设置,Windows 程序包管理器的 Microsoft Store 源将不可用。 - 设置应用安装程序源自动更新间隔(分钟) + 设置 Windows 程序包管理器源自动更新间隔(分钟) 此策略控制基于程序包的源的自动更新间隔。配置Windows 程序包管理器的默认源,以便在本地计算机上缓存包索引。当用户调用命令并且间隔已过时,将下载索引。 如果禁用或未配置此设置,将使用Windows 程序包管理器设置中指定的默认间隔或值。 如果启用此设置,则Windows 程序包管理器将使用指定的分钟数。 - 启用应用安装程序其他源 + 启用 Windows 程序包管理器其他源 此策略控制企业 IT 管理员提供的其他源。 如果未配置此策略,则将不会为 Windows 程序包管理器配置其他源。 @@ -81,7 +81,7 @@ 如果启用此策略,则将向 Windows 程序包管理器添加其他源并且这些源不可删除。可使用“winget source export”从已安装的源获取每个其他源的表示形式。 如果禁用此策略,则不能为 Windows 程序包管理器配置其他源。 - 启用应用安装程序允许的源 + 启用 Windows 程序包管理器允许的源 此策略控制企业 IT 管理员允许的其他源。 如果未配置此策略,用户将能够添加或删除策略配置的源之外的其他源。 @@ -122,6 +122,20 @@ 如果禁用或未配置此设置,则默认情况下不会使用任何代理。 如果启用此设置,则默认情况下将使用指定的代理。 + 为 MSIX 包启用应用安装程序允许的区域 + 此策略控制应用安装程序是否允许安装源自特定 URL 区域的包。包的来源由其 URI 以及是否存在 Mart-of-the-Web (MotW) 来确定。如果涉及多个 URI,则会考虑所有这些 URI;例如,使用涉及重定向的 .appinstaller 文件时。 + +如果启用此策略,则用户将能够根据每个区域的配置安装 MSIX 包。 + +如果禁用或未配置此策略,则用户将能够从除不受信任之外的任何区域安装 MSIX 包。 + 允许 + 阻止 + 为 MSIX 包启用 Microsoft SmartScreen 检查 + 此策略控制应用安装程序在安装 MSIX 包时是否执行Microsoft SmartScreen 检查。 + +如果启用或未配置此策略,则在安装之前,将使用 Microsoft SmartScreen 评估包 URI。此检查仅适用于来自 Internet 的程序包。 + +如果禁用,则在安装包之前,不会咨询Microsoft SmartScreen。 @@ -138,6 +152,13 @@ + + 本地计算机 + Intranet + 受信任的站点 + Internet + 不受信任的站点 + diff --git a/Localization/Policies/zh-TW/DesktopAppInstaller.adml b/Localization/Policies/zh-TW/DesktopAppInstaller.adml index a9d5823cc6..86496f6ff9 100644 --- a/Localization/Policies/zh-TW/DesktopAppInstaller.adml +++ b/Localization/Policies/zh-TW/DesktopAppInstaller.adml @@ -7,51 +7,51 @@ 傳統型應用程式安裝程式 - 啟用應用程式安裝程式 + 啟用 Windows 封裝管理員 此原則可控制使用者是否可以使用 Windows 套件管理員。 如果您啟用或未設定這個設定,使用者將可以使用 Windows 套件管理員。 如果停用此設定,使用者將無法使用 Windows 套件管理員。 - 啟用應用程式安裝程式設定 + 啟用 Windows 封裝管理員設定 此原則可控制使用者是否可以變更其設定。 如果您啟用或未設定這個設定,使用者將可以變更 Windows 套件管理員的設定。 如果停用此設定,使用者將無法變更 Windows 套件管理員的設定。 - 啟用應用程式安裝程式實驗性功能 + 啟用 Windows 封裝管理員實驗性功能 此原則可控制使用者是否能在 Windows 套件管理員中啟用實驗性功能。 如果啟用或未設定此設定,使用者將能夠啟用 Windows 套件管理員的實驗性功能。 如果停用此設定,使用者將無法啟用 Windows 套件管理員的實驗性功能。 - 啟用應用程式安裝程式本機資訊清單檔案 + 啟用 Windows 封裝管理員本機資訊清單檔案 此原則可控制使用者是否能安裝具有本機資訊清單檔案的套件。 如果您啟用或未設定這個設定,使用者將可以使用 Windows 套件管理員來安裝具有本機資訊清單的套件。 若停用此設定,使用者將無法使用 Windows 套件管理員來安裝具有本機資訊清單的套件。 - 啟用應用程式安裝程式 Microsoft Store 來源已憑證驗證旁路 + 啟用 Windows 封裝管理員 Microsoft Store來源憑證驗證略過 此原則可控制 Windows 封裝管理員在起始 Microsoft Store 來源的連線時,是否要驗證與已知 Microsoft Store 憑證相符的 Microsoft Store 憑證雜湊。 如果您啟用這個原則,Windows 封裝管理員將會略過 Microsoft Store 憑證驗證。 如果停用此原則,則 Windows 封裝管理員會在與 Microsoft Store 來源通訊之前,驗證使用的 Microsoft Store 憑證有效且屬於 Microsoft Store。 如果您未設定這個原則,則會遵循 Windows 封裝管理員系統管理員設定。 - 啟用應用程式安裝程式雜湊覆寫 + 啟用 Windows 封裝管理員雜湊覆寫 此原則會控制 Windows 封裝管理員是否可以設定以便啟用在設定中覆寫 SHA256 安全性驗證的能力。 如果您啟用或未設定此原則,使用者就可以在 Windows 封裝管理員設定中啟用覆寫 SHA256 安全性驗證的能力。 如果您停用此原則,使用者就無法在 Windows 封裝管理員設定中啟用覆寫 SHA256 安全性驗證的能力。 - 啟用應用程式安裝程式本機封存惡意程式碼掃描覆寫 + 啟用 Windows 封裝管理員 本機封存惡意代碼掃描覆寫 此原則控制在使用本機資訊清單使用命令列引數安裝封存檔案時,是否可以覆寫惡意程式碼弱點掃描。 如果您啟用這個原則,使用者可以在執行封存檔案的本機資訊清單安裝時覆寫惡意程式碼掃描。 如果您停用這個原則,使用者將無法在使用本機資訊清單安裝時覆寫封存檔案的惡意程式碼掃描。 如果您未設定這個原則,則會遵循Windows 封裝管理員系統管理員設定。 - 啟用應用程式安裝程式預設來源 + 設定 Windows 封裝管理員預設來源 此原則控制 Windows 封裝管理員隨附的預設來源。 如果您未設定此設定,Windows 封裝管理員的預設來源將可供使用,而且可以移除。 @@ -59,7 +59,7 @@ 如果您啟用此設定,Windows 封裝管理員的預設來源將可供使用,且無法移除。 如果您停用此設定,Windows 封裝管理員的預設來源將無法使用。 - 啟用應用程式安裝程式 Microsoft Store 來源 + 啟用 Windows 封裝管理員 Microsoft Store 來源 此原則控制 Windows 封裝管理員隨附的 Microsoft Store 來源。 如果您未設定此設定,Windows 封裝管理員的 Microsoft Store 來源將可供使用,而且可以移除。 @@ -67,13 +67,13 @@ 如果您啟用此設定,Windows 封裝管理員的 Microsoft Store 來源將可供使用,且無法移除。 如果您停用此設定,Windows 封裝管理員的 Microsoft Store 來源將無法使用。 - 設定應用程式安裝程式來源自動更新間隔 (分鐘) + 設定 Windows 封裝管理員來源自動更新間隔 (分鐘) 此原則控制封裝型來源的自動更新間隔時間。Windows 封裝管理員的預設來源設定為本機電腦上快取的套件索引。當使用者調用命令且間隔已過時,下載索引。 如果您停用或不設定此設定,將會使用 Windows 封裝管理員設定中指定的預設間隔或值。 如果您啟用此設定,Windows 封裝管理員將會使用指定的分鐘數。 - 啟用應用程式安裝程式其他來源 + 啟用 Windows 封裝管理員其他來源 此原則控制企業 IT 系統管理員提供的其他來源。 如果您未設定此原則,將不會為 Windows 封裝管理員設定其他來源。 @@ -81,7 +81,7 @@ 如果您啟用此原則,其他來源將會新增到 Windows 封裝管理員,而且無法移除。每個其他來源的標記法都可以使用 'winget 來源匯出' 從已安裝的來源取得。 如果您停用此原則,則 Windows 封裝管理員無法為其他來源進行設定。 - 啟用應用程式安裝程式允許的來源 + 設定 Windows 封裝管理員允許來源 此原則控制企業 IT 系統管理員允許的其他來源。 如果您未設定此原則,使用者將可以新增或移除其他非此原則設定的來源。 @@ -122,6 +122,20 @@ 如果停用或未設定此設定,則預設不會使用任何 Proxy。 如果您啟用這個設定,預設會使用指定的 Proxy。 + 為 MSIX 套件啟用應用程式安裝程式允許的區域 + 此原則控制應用程式安裝程式是否允許安裝來自特定 URL 區域的套件。套件的來源取決於其 URI,以及是否存在 Mart-of the Web (MotW)。如果涉及多個 URI,則會考慮所有 URI;例如,使用涉及重新導向的 .appinstaller 檔案時。 + +如果您啟用這個原則,使用者將可以根據每個區域的設定來安裝 MSIX 套件。 + +如果您停用或未設定這個原則,除了不受信任之外,使用者將可以從任何區域安裝 MSIX 套件。 + 允許 + 阻止 + 啟用 MSIX 套件的 Microsoft SmartScreen 檢查 + 此原則可控制應用程式安裝程式在安裝 MSIX 套件時是否執行Microsoft SmartScreen 檢查。 + +如果啟用或未設定此原則,則會在安裝前使用 Microsoft SmartScreen 評估套件 URI。這項檢查只會針對來自因特網的套件執行。 + +如果停用,Microsoft安裝套件前將不會詢問 SmartScreen。 @@ -138,6 +152,13 @@ + + 本機電腦 + 內部網路 + 信任的網站 + 網際網路 + 未受信任的網站 + diff --git a/Localization/Resources/de-DE/winget.resw b/Localization/Resources/de-DE/winget.resw index 395484dd5a..4d857e5673 100644 --- a/Localization/Resources/de-DE/winget.resw +++ b/Localization/Resources/de-DE/winget.resw @@ -3130,4 +3130,13 @@ Geben Sie eine Option für --source an, um den Vorgang fortzusetzen. Fehler beim Abrufen Microsoft Store Paketlizenz. Das Microsoft Entra-ID-Konto verfügt nicht über die erforderlichen Berechtigungen. + + Der Parameter kann nicht über die Integritätsgrenze hinweg übergeben werden. + + + Das Zero-Byte-Installationsprogramm wurde heruntergeladen. stellen Sie sicher, dass die Netzwerkverbindung ordnungsgemäß funktioniert. + + + Das Zero-Byte-Installationsprogramm wurde heruntergeladen. stellen Sie sicher, dass die Netzwerkverbindung ordnungsgemäß funktioniert. + \ No newline at end of file diff --git a/Localization/Resources/es-ES/winget.resw b/Localization/Resources/es-ES/winget.resw index 605962b98e..056a8b1ecf 100644 --- a/Localization/Resources/es-ES/winget.resw +++ b/Localization/Resources/es-ES/winget.resw @@ -3130,4 +3130,13 @@ Especifique uno de ellos con la opción --source para continuar. No se pudo recuperar Microsoft Store licencia del paquete. La cuenta de id. de Microsoft Entra no tiene el privilegio necesario. + + El parámetro no se puede pasar a través del límite de integridad. + + + Instalador de cero bytes descargado; asegúrese de que la conexión de red funciona correctamente. + + + Instalador de cero bytes descargado; asegúrese de que la conexión de red funciona correctamente. + \ No newline at end of file diff --git a/Localization/Resources/fr-FR/winget.resw b/Localization/Resources/fr-FR/winget.resw index 71f7fed825..e6ee627e21 100644 --- a/Localization/Resources/fr-FR/winget.resw +++ b/Localization/Resources/fr-FR/winget.resw @@ -3130,4 +3130,13 @@ Spécifiez l’un d’entre eux à l’aide de l’option --source pour continue Échec de la récupération de Microsoft Store licence de package. Le compte d’ID Microsoft Entra ne dispose pas des privilèges requis. + + Le paramètre ne peut pas être transmis au-delà de la limite d’intégrité. + + + Programme d’installation zéro octet téléchargé ; vérifiez que votre connexion réseau fonctionne correctement. + + + Programme d’installation zéro octet téléchargé ; vérifiez que votre connexion réseau fonctionne correctement. + \ No newline at end of file diff --git a/Localization/Resources/it-IT/winget.resw b/Localization/Resources/it-IT/winget.resw index 908e00236a..b9c5ea6b4f 100644 --- a/Localization/Resources/it-IT/winget.resw +++ b/Localization/Resources/it-IT/winget.resw @@ -3130,4 +3130,13 @@ Specificarne uno utilizzando l'opzione --source per continuare. Non è stato possibile recuperare Microsoft Store licenza del pacchetto. L'account id Microsoft Entra non dispone dei privilegi necessari. + + Il parametro non può essere passato oltre il limite di integrità. + + + Programma di installazione a zero byte scaricato; verificare che la connessione di rete funzioni correttamente. + + + Programma di installazione a zero byte scaricato; verificare che la connessione di rete funzioni correttamente. + \ No newline at end of file diff --git a/Localization/Resources/ja-JP/winget.resw b/Localization/Resources/ja-JP/winget.resw index e8364c5acf..c95dffa066 100644 --- a/Localization/Resources/ja-JP/winget.resw +++ b/Localization/Resources/ja-JP/winget.resw @@ -3130,4 +3130,13 @@ Microsoft Store パッケージ ライセンスを取得できませんでした。Microsoft Entra ID アカウントに必要な特権がありません。 + + 整合性境界を越えてパラメーターを渡すことはできません。 + + + ゼロ バイト インストーラーをダウンロードしました;ネットワーク接続が正しく動作していることを確認してください。 + + + ゼロ バイト インストーラーをダウンロードしました;ネットワーク接続が正しく動作していることを確認してください。 + \ No newline at end of file diff --git a/Localization/Resources/ko-KR/winget.resw b/Localization/Resources/ko-KR/winget.resw index f8d1bedeaa..6d5042d792 100644 --- a/Localization/Resources/ko-KR/winget.resw +++ b/Localization/Resources/ko-KR/winget.resw @@ -3130,4 +3130,13 @@ Microsoft Store 패키지 라이선스를 검색하지 못했습니다. Microsoft Entra ID 계정에 필요한 권한이 없습니다. + + 무결성 경계를 넘어 매개 변수를 전달할 수 없습니다. + + + 0 바이트 설치 관리자 다운로드됨; 네트워크 연결이 제대로 작동하는지 확인하십시오. + + + 0 바이트 설치 관리자 다운로드됨; 네트워크 연결이 제대로 작동하는지 확인하십시오. + \ No newline at end of file diff --git a/Localization/Resources/pt-BR/winget.resw b/Localization/Resources/pt-BR/winget.resw index 31011b9a02..4b1aaa91fa 100644 --- a/Localization/Resources/pt-BR/winget.resw +++ b/Localization/Resources/pt-BR/winget.resw @@ -3130,4 +3130,13 @@ Especifique um deles usando a opção --source para continuar. Falha ao recuperar a Microsoft Store do pacote. A Microsoft Entra de ID não tem o privilégio necessário. + + O parâmetro não pode ser passado através do limite de integridade. + + + Instalador de zero bytes baixado; verifique se a conexão de rede está funcionando corretamente. + + + Instalador de zero bytes baixado; verifique se a conexão de rede está funcionando corretamente. + \ No newline at end of file diff --git a/Localization/Resources/ru-RU/winget.resw b/Localization/Resources/ru-RU/winget.resw index 1099ce92df..c3e2bf2a22 100644 --- a/Localization/Resources/ru-RU/winget.resw +++ b/Localization/Resources/ru-RU/winget.resw @@ -3130,4 +3130,13 @@ Не удалось получить Microsoft Store пакета. Учетная Microsoft Entra идентификатора учетной записи не имеет необходимых привилегий. + + Параметр нельзя передать через границу целостности. + + + Скачан установщик нулевого байта. Убедитесь, что ваше сетевое подключение работает правильно. + + + Скачан установщик нулевого байта. Убедитесь, что ваше сетевое подключение работает правильно. + \ No newline at end of file diff --git a/Localization/Resources/zh-CN/winget.resw b/Localization/Resources/zh-CN/winget.resw index ab055b7d0a..a217673231 100644 --- a/Localization/Resources/zh-CN/winget.resw +++ b/Localization/Resources/zh-CN/winget.resw @@ -3130,4 +3130,13 @@ 无法检索Microsoft Store包许可证。Microsoft Entra ID 帐户没有所需的权限。 + + 无法跨完整性边界传递参数。 + + + 已下载零字节安装程序;请确保网络连接正常工作。 + + + 已下载零字节安装程序;请确保网络连接正常工作。 + \ No newline at end of file diff --git a/Localization/Resources/zh-TW/winget.resw b/Localization/Resources/zh-TW/winget.resw index 024479ce56..fa1001888d 100644 --- a/Localization/Resources/zh-TW/winget.resw +++ b/Localization/Resources/zh-TW/winget.resw @@ -3130,4 +3130,13 @@ 無法擷取Microsoft Store套件授權。Microsoft Entra識別子帳戶沒有所需的許可權。 + + 參數無法通過完整性邊界。 + + + 已下載零位元組安裝程式;請確認您的網路連線正常運作。 + + + 已下載零位元組安裝程式;請確認您的網路連線正常運作。 + \ No newline at end of file