diff options
author | Sean Hall <r.sean.hall@gmail.com> | 2020-03-30 19:46:56 +1000 |
---|---|---|
committer | Sean Hall <r.sean.hall@gmail.com> | 2020-03-30 21:57:49 +1000 |
commit | 0afd76e4c5d46f237591d860e7d445e267522187 (patch) | |
tree | 9f3b648da7733464c83ba6e253a65a18d17f5583 /src/be | |
parent | d74e3dd4bcc573d0c4b1fb5c36c8bf0115cc21a1 (diff) | |
download | wix-0afd76e4c5d46f237591d860e7d445e267522187.tar.gz wix-0afd76e4c5d46f237591d860e7d445e267522187.tar.bz2 wix-0afd76e4c5d46f237591d860e7d445e267522187.zip |
Add DetectSHA2Support "search".
Diffstat (limited to 'src/be')
-rw-r--r-- | src/be/UtilBundleExtension.cpp | 87 | ||||
-rw-r--r-- | src/be/UtilBundleExtension.h | 16 | ||||
-rw-r--r-- | src/be/detectsha2support.cpp | 58 | ||||
-rw-r--r-- | src/be/detectsha2support.h | 8 | ||||
-rw-r--r-- | src/be/packages.config | 1 | ||||
-rw-r--r-- | src/be/precomp.h | 23 | ||||
-rw-r--r-- | src/be/utilbe.cpp | 28 | ||||
-rw-r--r-- | src/be/utilbe.vcxproj | 20 | ||||
-rw-r--r-- | src/be/utilsearch.cpp | 137 | ||||
-rw-r--r-- | src/be/utilsearch.h | 52 |
10 files changed, 410 insertions, 20 deletions
diff --git a/src/be/UtilBundleExtension.cpp b/src/be/UtilBundleExtension.cpp new file mode 100644 index 00000000..2ac842a5 --- /dev/null +++ b/src/be/UtilBundleExtension.cpp | |||
@@ -0,0 +1,87 @@ | |||
1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
2 | |||
3 | #include "precomp.h" | ||
4 | #include "BextBaseBundleExtension.h" | ||
5 | |||
6 | class CWixUtilBundleExtension : public CBextBaseBundleExtension | ||
7 | { | ||
8 | public: // IBundleExtension | ||
9 | virtual STDMETHODIMP Search( | ||
10 | __in LPCWSTR wzId, | ||
11 | __in LPCWSTR wzVariable | ||
12 | ) | ||
13 | { | ||
14 | HRESULT hr = S_OK; | ||
15 | |||
16 | hr = UtilSearchExecute(&m_searches, wzId, wzVariable, m_pEngine); | ||
17 | |||
18 | return hr; | ||
19 | } | ||
20 | |||
21 | public: //CBextBaseBundleExtension | ||
22 | virtual STDMETHODIMP Initialize( | ||
23 | __in const BUNDLE_EXTENSION_CREATE_ARGS* pCreateArgs | ||
24 | ) | ||
25 | { | ||
26 | HRESULT hr = S_OK; | ||
27 | IXMLDOMDocument* pixdManifest = NULL; | ||
28 | IXMLDOMNode* pixnBundleExtension = NULL; | ||
29 | |||
30 | hr = CBextBaseBundleExtension::Initialize(pCreateArgs); | ||
31 | ExitOnFailure(hr, "CBextBaseBundleExtension initialization failed."); | ||
32 | |||
33 | hr = XmlLoadDocumentFromFile(m_sczBundleExtensionDataPath, &pixdManifest); | ||
34 | ExitOnFailure(hr, "Failed to load bundle extension manifest from path: %ls", m_sczBundleExtensionDataPath); | ||
35 | |||
36 | hr = BextGetBundleExtensionDataNode(pixdManifest, UTIL_BUNDLE_EXTENSION_ID, &pixnBundleExtension); | ||
37 | ExitOnFailure(hr, "Failed to get BundleExtension '%ls'", UTIL_BUNDLE_EXTENSION_ID); | ||
38 | |||
39 | hr = UtilSearchParseFromXml(&m_searches, pixnBundleExtension); | ||
40 | ExitOnFailure(hr, "Failed to parse searches from bundle extension manifest."); | ||
41 | |||
42 | LExit: | ||
43 | ReleaseObject(pixnBundleExtension); | ||
44 | ReleaseObject(pixdManifest); | ||
45 | |||
46 | return hr; | ||
47 | } | ||
48 | |||
49 | public: | ||
50 | CWixUtilBundleExtension( | ||
51 | __in IBundleExtensionEngine* pEngine | ||
52 | ) : CBextBaseBundleExtension(pEngine) | ||
53 | { | ||
54 | m_searches = { }; | ||
55 | } | ||
56 | |||
57 | ~CWixUtilBundleExtension() | ||
58 | { | ||
59 | UtilSearchUninitialize(&m_searches); | ||
60 | } | ||
61 | |||
62 | private: | ||
63 | UTIL_SEARCHES m_searches; | ||
64 | }; | ||
65 | |||
66 | HRESULT UtilBundleExtensionCreate( | ||
67 | __in IBundleExtensionEngine* pEngine, | ||
68 | __in const BUNDLE_EXTENSION_CREATE_ARGS* pArgs, | ||
69 | __out IBundleExtension** ppBundleExtension | ||
70 | ) | ||
71 | { | ||
72 | HRESULT hr = S_OK; | ||
73 | CWixUtilBundleExtension* pExtension = NULL; | ||
74 | |||
75 | pExtension = new CWixUtilBundleExtension(pEngine); | ||
76 | ExitOnNull(pExtension, hr, E_OUTOFMEMORY, "Failed to create new CWixUtilBundleExtension."); | ||
77 | |||
78 | hr = pExtension->Initialize(pArgs); | ||
79 | ExitOnFailure(hr, "CWixUtilBundleExtension initialization failed"); | ||
80 | |||
81 | *ppBundleExtension = pExtension; | ||
82 | pExtension = NULL; | ||
83 | |||
84 | LExit: | ||
85 | ReleaseObject(pExtension); | ||
86 | return hr; | ||
87 | } | ||
diff --git a/src/be/UtilBundleExtension.h b/src/be/UtilBundleExtension.h new file mode 100644 index 00000000..16c5b346 --- /dev/null +++ b/src/be/UtilBundleExtension.h | |||
@@ -0,0 +1,16 @@ | |||
1 | #pragma once | ||
2 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
3 | |||
4 | |||
5 | // constants | ||
6 | |||
7 | #define UTIL_BUNDLE_EXTENSION_ID L"WixUtilBundleExtension" | ||
8 | |||
9 | |||
10 | // function declarations | ||
11 | |||
12 | HRESULT UtilBundleExtensionCreate( | ||
13 | __in IBundleExtensionEngine* pEngine, | ||
14 | __in const BUNDLE_EXTENSION_CREATE_ARGS* pArgs, | ||
15 | __out IBundleExtension** ppBundleExtension | ||
16 | ); | ||
diff --git a/src/be/detectsha2support.cpp b/src/be/detectsha2support.cpp new file mode 100644 index 00000000..f1f3637e --- /dev/null +++ b/src/be/detectsha2support.cpp | |||
@@ -0,0 +1,58 @@ | |||
1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
2 | |||
3 | #include "precomp.h" | ||
4 | |||
5 | // https://gist.github.com/navossoc/7572c7d82243e9f818989e2765e7793a | ||
6 | HRESULT DetectSHA2Support( | ||
7 | __out BOOL* pfSupported | ||
8 | ) | ||
9 | { | ||
10 | HRESULT hr = S_OK; | ||
11 | HMODULE hModule = NULL; | ||
12 | FARPROC pfn = NULL; | ||
13 | DWORD er = ERROR_SUCCESS; | ||
14 | |||
15 | hr = LoadSystemLibrary(L"wintrust.dll", &hModule); | ||
16 | ExitOnFailure(hr, "Failed to load wintrust.dll"); | ||
17 | |||
18 | pfn = ::GetProcAddress(hModule, "CryptCATAdminAcquireContext2"); | ||
19 | if (pfn) | ||
20 | { | ||
21 | *pfSupported = TRUE; | ||
22 | ExitFunction1(hr = S_OK); | ||
23 | } | ||
24 | |||
25 | er = ::GetLastError(); | ||
26 | if (er == ERROR_PROC_NOT_FOUND) | ||
27 | { | ||
28 | *pfSupported = FALSE; | ||
29 | ExitFunction1(hr = S_OK); | ||
30 | } | ||
31 | |||
32 | hr = HRESULT_FROM_WIN32(er); | ||
33 | ExitOnFailure(hr, "Failed to probe for CryptCATAdminAcquireContext2 in wintrust.dll"); | ||
34 | |||
35 | LExit: | ||
36 | ::FreeLibrary(hModule); | ||
37 | |||
38 | return hr; | ||
39 | } | ||
40 | |||
41 | HRESULT UtilPerformDetectSHA2Support( | ||
42 | __in LPCWSTR wzVariable, | ||
43 | __in UTIL_SEARCH* /*pSearch*/, | ||
44 | __in IBundleExtensionEngine* pEngine | ||
45 | ) | ||
46 | { | ||
47 | HRESULT hr = S_OK; | ||
48 | BOOL fSupported = FALSE; | ||
49 | |||
50 | hr = DetectSHA2Support(&fSupported); | ||
51 | ExitOnFailure(hr, "DetectSHA2Support failed."); | ||
52 | |||
53 | hr = pEngine->SetVariableNumeric(wzVariable, fSupported ? 1 : 0); | ||
54 | ExitOnFailure(hr, "Failed to set variable '%ls'", wzVariable); | ||
55 | |||
56 | LExit: | ||
57 | return hr; | ||
58 | } | ||
diff --git a/src/be/detectsha2support.h b/src/be/detectsha2support.h new file mode 100644 index 00000000..7f1f6031 --- /dev/null +++ b/src/be/detectsha2support.h | |||
@@ -0,0 +1,8 @@ | |||
1 | #pragma once | ||
2 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
3 | |||
4 | HRESULT UtilPerformDetectSHA2Support( | ||
5 | __in LPCWSTR wzVariable, | ||
6 | __in UTIL_SEARCH* pSearch, | ||
7 | __in IBundleExtensionEngine* pEngine | ||
8 | ); \ No newline at end of file | ||
diff --git a/src/be/packages.config b/src/be/packages.config index f05546c5..ca23641f 100644 --- a/src/be/packages.config +++ b/src/be/packages.config | |||
@@ -1,5 +1,6 @@ | |||
1 | <?xml version="1.0" encoding="utf-8"?> | 1 | <?xml version="1.0" encoding="utf-8"?> |
2 | <packages> | 2 | <packages> |
3 | <package id="WixToolset.BextUtil" version="4.0.16" targetFramework="native" /> | ||
3 | <package id="WixToolset.BootstrapperCore.Native" version="4.0.13" targetFramework="native" /> | 4 | <package id="WixToolset.BootstrapperCore.Native" version="4.0.13" targetFramework="native" /> |
4 | <package id="WixToolset.DUtil" version="4.0.18" targetFramework="native" /> | 5 | <package id="WixToolset.DUtil" version="4.0.18" targetFramework="native" /> |
5 | </packages> \ No newline at end of file | 6 | </packages> \ No newline at end of file |
diff --git a/src/be/precomp.h b/src/be/precomp.h index 9dc3c468..a4ab7abf 100644 --- a/src/be/precomp.h +++ b/src/be/precomp.h | |||
@@ -17,9 +17,20 @@ | |||
17 | 17 | ||
18 | #define MAXUINT USHRT_MAX | 18 | #define MAXUINT USHRT_MAX |
19 | 19 | ||
20 | #include "dutil.h" | 20 | #include <dutil.h> |
21 | #include "memutil.h" | 21 | #include <memutil.h> |
22 | 22 | #include <strutil.h> | |
23 | #include "BootstrapperEngine.h" | 23 | #include <pathutil.h> |
24 | #include "BundleExtensionEngine.h" | 24 | #include <xmlutil.h> |
25 | #include "BundleExtension.h" | 25 | |
26 | #include <BundleExtensionEngine.h> | ||
27 | #include <BundleExtension.h> | ||
28 | |||
29 | #include <IBundleExtensionEngine.h> | ||
30 | #include <IBundleExtension.h> | ||
31 | #include <bextutil.h> | ||
32 | #include <BextBundleExtensionEngine.h> | ||
33 | |||
34 | #include "utilsearch.h" | ||
35 | #include "detectsha2support.h" | ||
36 | #include "UtilBundleExtension.h" | ||
diff --git a/src/be/utilbe.cpp b/src/be/utilbe.cpp index 370669dd..d9816dc7 100644 --- a/src/be/utilbe.cpp +++ b/src/be/utilbe.cpp | |||
@@ -1,19 +1,41 @@ | |||
1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | 1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. |
2 | 2 | ||
3 | #include "precomp.h" | 3 | #include "precomp.h" |
4 | #include "BextBaseBundleExtensionProc.h" | ||
5 | |||
6 | static IBundleExtension* vpBundleExtension = NULL; | ||
4 | 7 | ||
5 | // function definitions | 8 | // function definitions |
6 | 9 | ||
7 | extern "C" HRESULT WINAPI BundleExtensionCreate( | 10 | extern "C" HRESULT WINAPI BundleExtensionCreate( |
8 | __in const BUNDLE_EXTENSION_CREATE_ARGS* /*pArgs*/, | 11 | __in const BUNDLE_EXTENSION_CREATE_ARGS* pArgs, |
9 | __inout BUNDLE_EXTENSION_CREATE_RESULTS* /*pResults*/ | 12 | __inout BUNDLE_EXTENSION_CREATE_RESULTS* pResults |
10 | ) | 13 | ) |
11 | { | 14 | { |
12 | HRESULT hr = S_OK; | 15 | HRESULT hr = S_OK; |
16 | IBundleExtensionEngine* pEngine = NULL; | ||
17 | |||
18 | hr = XmlInitialize(); | ||
19 | ExitOnFailure(hr, "Failed to initialize XML."); | ||
20 | |||
21 | hr = BextInitializeFromCreateArgs(pArgs, &pEngine); | ||
22 | ExitOnFailure(hr, "Failed to initialize bext"); | ||
23 | |||
24 | hr = UtilBundleExtensionCreate(pEngine, pArgs, &vpBundleExtension); | ||
25 | BextExitOnFailure(hr, "Failed to create WixUtilBundleExtension"); | ||
26 | |||
27 | pResults->pfnBundleExtensionProc = BextBaseBundleExtensionProc; | ||
28 | pResults->pvBundleExtensionProcContext = vpBundleExtension; | ||
29 | |||
30 | LExit: | ||
31 | ReleaseObject(pEngine); | ||
13 | 32 | ||
14 | return hr; | 33 | return hr; |
15 | } | 34 | } |
16 | 35 | ||
17 | extern "C" void WINAPI BundleExtensionDestroy() | 36 | extern "C" void WINAPI BundleExtensionDestroy() |
18 | { | 37 | { |
38 | BextUninitialize(); | ||
39 | ReleaseNullObject(vpBundleExtension); | ||
40 | XmlUninitialize(); | ||
19 | } \ No newline at end of file | 41 | } \ No newline at end of file |
diff --git a/src/be/utilbe.vcxproj b/src/be/utilbe.vcxproj index 963eac7f..e64d113e 100644 --- a/src/be/utilbe.vcxproj +++ b/src/be/utilbe.vcxproj | |||
@@ -1,10 +1,9 @@ | |||
1 | <?xml version="1.0" encoding="utf-8"?> | 1 | <?xml version="1.0" encoding="utf-8"?> |
2 | <!-- Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. --> | 2 | <!-- Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. --> |
3 | |||
4 | <Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> | 3 | <Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> |
4 | <Import Project="..\..\packages\WixToolset.BextUtil.4.0.16\build\WixToolset.BextUtil.props" Condition="Exists('..\..\packages\WixToolset.BextUtil.4.0.16\build\WixToolset.BextUtil.props')" /> | ||
5 | <Import Project="..\..\packages\WixToolset.BootstrapperCore.Native.4.0.13\build\WixToolset.BootstrapperCore.Native.props" Condition="Exists('..\..\packages\WixToolset.BootstrapperCore.Native.4.0.13\build\WixToolset.BootstrapperCore.Native.props')" /> | 5 | <Import Project="..\..\packages\WixToolset.BootstrapperCore.Native.4.0.13\build\WixToolset.BootstrapperCore.Native.props" Condition="Exists('..\..\packages\WixToolset.BootstrapperCore.Native.4.0.13\build\WixToolset.BootstrapperCore.Native.props')" /> |
6 | <Import Project="..\..\packages\WixToolset.DUtil.4.0.18\build\WixToolset.DUtil.props" Condition="Exists('..\..\packages\WixToolset.DUtil.4.0.18\build\WixToolset.DUtil.props')" /> | 6 | <Import Project="..\..\packages\WixToolset.DUtil.4.0.18\build\WixToolset.DUtil.props" Condition="Exists('..\..\packages\WixToolset.DUtil.4.0.18\build\WixToolset.DUtil.props')" /> |
7 | |||
8 | <ItemGroup Label="ProjectConfigurations"> | 7 | <ItemGroup Label="ProjectConfigurations"> |
9 | <ProjectConfiguration Include="Debug|Win32"> | 8 | <ProjectConfiguration Include="Debug|Win32"> |
10 | <Configuration>Debug</Configuration> | 9 | <Configuration>Debug</Configuration> |
@@ -15,7 +14,6 @@ | |||
15 | <Platform>Win32</Platform> | 14 | <Platform>Win32</Platform> |
16 | </ProjectConfiguration> | 15 | </ProjectConfiguration> |
17 | </ItemGroup> | 16 | </ItemGroup> |
18 | |||
19 | <PropertyGroup Label="Globals"> | 17 | <PropertyGroup Label="Globals"> |
20 | <ProjectGuid>{630C1EE7-2517-4A8C-83E3-DA1150308B58}</ProjectGuid> | 18 | <ProjectGuid>{630C1EE7-2517-4A8C-83E3-DA1150308B58}</ProjectGuid> |
21 | <ConfigurationType>DynamicLibrary</ConfigurationType> | 19 | <ConfigurationType>DynamicLibrary</ConfigurationType> |
@@ -25,37 +23,37 @@ | |||
25 | <ProjectModuleDefinitionFile>utilbe.def</ProjectModuleDefinitionFile> | 23 | <ProjectModuleDefinitionFile>utilbe.def</ProjectModuleDefinitionFile> |
26 | <Description>WiX Toolset Util BundleExtension</Description> | 24 | <Description>WiX Toolset Util BundleExtension</Description> |
27 | </PropertyGroup> | 25 | </PropertyGroup> |
28 | |||
29 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> | 26 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> |
30 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> | 27 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> |
31 | |||
32 | <PropertyGroup> | 28 | <PropertyGroup> |
33 | <ProjectAdditionalLinkLibraries>msi.lib</ProjectAdditionalLinkLibraries> | 29 | <ProjectAdditionalLinkLibraries>msi.lib</ProjectAdditionalLinkLibraries> |
34 | </PropertyGroup> | 30 | </PropertyGroup> |
35 | |||
36 | <ItemGroup> | 31 | <ItemGroup> |
32 | <ClCompile Include="detectsha2support.cpp" /> | ||
37 | <ClCompile Include="precomp.cpp"> | 33 | <ClCompile Include="precomp.cpp"> |
38 | <PrecompiledHeader>Create</PrecompiledHeader> | 34 | <PrecompiledHeader>Create</PrecompiledHeader> |
39 | </ClCompile> | 35 | </ClCompile> |
40 | <ClCompile Include="utilbe.cpp" /> | 36 | <ClCompile Include="utilbe.cpp" /> |
37 | <ClCompile Include="UtilBundleExtension.cpp" /> | ||
38 | <ClCompile Include="utilsearch.cpp" /> | ||
41 | </ItemGroup> | 39 | </ItemGroup> |
42 | |||
43 | <ItemGroup> | 40 | <ItemGroup> |
41 | <ClInclude Include="detectsha2support.h" /> | ||
44 | <ClInclude Include="precomp.h" /> | 42 | <ClInclude Include="precomp.h" /> |
43 | <ClInclude Include="UtilBundleExtension.h" /> | ||
44 | <ClInclude Include="utilsearch.h" /> | ||
45 | </ItemGroup> | 45 | </ItemGroup> |
46 | |||
47 | <ItemGroup> | 46 | <ItemGroup> |
48 | <None Include="packages.config" /> | 47 | <None Include="packages.config" /> |
49 | <None Include="utilbe.def" /> | 48 | <None Include="utilbe.def" /> |
50 | </ItemGroup> | 49 | </ItemGroup> |
51 | |||
52 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> | 50 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> |
53 | |||
54 | <Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild"> | 51 | <Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild"> |
55 | <PropertyGroup> | 52 | <PropertyGroup> |
56 | <ErrorText>This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}.</ErrorText> | 53 | <ErrorText>This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}.</ErrorText> |
57 | </PropertyGroup> | 54 | </PropertyGroup> |
55 | <Error Condition="!Exists('..\..\packages\WixToolset.BextUtil.4.0.16\build\WixToolset.BextUtil.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\WixToolset.BextUtil.4.0.16\build\WixToolset.BextUtil.props'))" /> | ||
58 | <Error Condition="!Exists('..\..\packages\WixToolset.BootstrapperCore.Native.4.0.13\build\WixToolset.BootstrapperCore.Native.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\WixToolset.BootstrapperCore.Native.4.0.13\build\WixToolset.BootstrapperCore.Native.props'))" /> | 56 | <Error Condition="!Exists('..\..\packages\WixToolset.BootstrapperCore.Native.4.0.13\build\WixToolset.BootstrapperCore.Native.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\WixToolset.BootstrapperCore.Native.4.0.13\build\WixToolset.BootstrapperCore.Native.props'))" /> |
59 | <Error Condition="!Exists('..\..\packages\WixToolset.DUtil.4.0.18\build\WixToolset.DUtil.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\WixToolset.DUtil.4.0.18\build\WixToolset.DUtil.props'))" /> | 57 | <Error Condition="!Exists('..\..\packages\WixToolset.DUtil.4.0.18\build\WixToolset.DUtil.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\WixToolset.DUtil.4.0.18\build\WixToolset.DUtil.props'))" /> |
60 | </Target> | 58 | </Target> |
61 | </Project> | 59 | </Project> \ No newline at end of file |
diff --git a/src/be/utilsearch.cpp b/src/be/utilsearch.cpp new file mode 100644 index 00000000..4e9d86a1 --- /dev/null +++ b/src/be/utilsearch.cpp | |||
@@ -0,0 +1,137 @@ | |||
1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
2 | |||
3 | #include "precomp.h" | ||
4 | |||
5 | |||
6 | STDMETHODIMP UtilSearchParseFromXml( | ||
7 | __in UTIL_SEARCHES* pSearches, | ||
8 | __in IXMLDOMNode* pixnBundleExtension | ||
9 | ) | ||
10 | { | ||
11 | HRESULT hr = S_OK; | ||
12 | IXMLDOMNodeList* pixnNodes = NULL; | ||
13 | IXMLDOMNode* pixnNode = NULL; | ||
14 | DWORD cNodes = 0; | ||
15 | BSTR bstrNodeName = NULL; | ||
16 | |||
17 | // Select Util search nodes. | ||
18 | hr = XmlSelectNodes(pixnBundleExtension, L"WixDetectSHA2Support", &pixnNodes); | ||
19 | ExitOnFailure(hr, "Failed to select Util search nodes."); | ||
20 | |||
21 | // Get Util search node count. | ||
22 | hr = pixnNodes->get_length((long*)&cNodes); | ||
23 | ExitOnFailure(hr, "Failed to get Util search node count."); | ||
24 | |||
25 | if (!cNodes) | ||
26 | { | ||
27 | ExitFunction(); | ||
28 | } | ||
29 | |||
30 | // Allocate memory for searches. | ||
31 | pSearches->rgSearches = (UTIL_SEARCH*)MemAlloc(sizeof(UTIL_SEARCH) * cNodes, TRUE); | ||
32 | ExitOnNull(pSearches->rgSearches, hr, E_OUTOFMEMORY, "Failed to allocate memory for search structs."); | ||
33 | |||
34 | pSearches->cSearches = cNodes; | ||
35 | |||
36 | // Parse search elements. | ||
37 | for (DWORD i = 0; i < cNodes; ++i) | ||
38 | { | ||
39 | UTIL_SEARCH* pSearch = &pSearches->rgSearches[i]; | ||
40 | |||
41 | hr = XmlNextElement(pixnNodes, &pixnNode, &bstrNodeName); | ||
42 | ExitOnFailure(hr, "Failed to get next node."); | ||
43 | |||
44 | // @Id | ||
45 | hr = XmlGetAttributeEx(pixnNode, L"Id", &pSearch->sczId); | ||
46 | ExitOnFailure(hr, "Failed to get @Id."); | ||
47 | |||
48 | // Read type specific attributes. | ||
49 | if (CSTR_EQUAL == ::CompareStringW(LOCALE_INVARIANT, 0, bstrNodeName, -1, L"WixDetectSHA2Support", -1)) | ||
50 | { | ||
51 | pSearch->Type = UTIL_SEARCH_TYPE_DETECT_SHA2_SUPPORT; | ||
52 | } | ||
53 | else | ||
54 | { | ||
55 | hr = E_UNEXPECTED; | ||
56 | ExitOnFailure(hr, "Unexpected element name: %ls", bstrNodeName); | ||
57 | } | ||
58 | |||
59 | // prepare next iteration | ||
60 | ReleaseNullObject(pixnNode); | ||
61 | ReleaseNullBSTR(bstrNodeName); | ||
62 | } | ||
63 | |||
64 | LExit: | ||
65 | ReleaseBSTR(bstrNodeName); | ||
66 | ReleaseObject(pixnNode); | ||
67 | ReleaseObject(pixnNodes); | ||
68 | |||
69 | return hr; | ||
70 | } | ||
71 | |||
72 | void UtilSearchUninitialize( | ||
73 | __in UTIL_SEARCHES* pSearches | ||
74 | ) | ||
75 | { | ||
76 | if (pSearches->rgSearches) | ||
77 | { | ||
78 | for (DWORD i = 0; i < pSearches->cSearches; ++i) | ||
79 | { | ||
80 | UTIL_SEARCH* pSearch = &pSearches->rgSearches[i]; | ||
81 | |||
82 | ReleaseStr(pSearch->sczId); | ||
83 | } | ||
84 | MemFree(pSearches->rgSearches); | ||
85 | } | ||
86 | } | ||
87 | |||
88 | STDMETHODIMP UtilSearchExecute( | ||
89 | __in UTIL_SEARCHES* pSearches, | ||
90 | __in LPCWSTR wzSearchId, | ||
91 | __in LPCWSTR wzVariable, | ||
92 | __in IBundleExtensionEngine* pEngine | ||
93 | ) | ||
94 | { | ||
95 | HRESULT hr = S_OK; | ||
96 | UTIL_SEARCH* pSearch = NULL; | ||
97 | |||
98 | hr = UtilSearchFindById(pSearches, wzSearchId, &pSearch); | ||
99 | ExitOnFailure(hr, "Search id '%ls' is unknown to the util extension."); | ||
100 | |||
101 | switch (pSearch->Type) | ||
102 | { | ||
103 | case UTIL_SEARCH_TYPE_DETECT_SHA2_SUPPORT: | ||
104 | hr = UtilPerformDetectSHA2Support(wzVariable, pSearch, pEngine); | ||
105 | break; | ||
106 | default: | ||
107 | hr = E_UNEXPECTED; | ||
108 | } | ||
109 | |||
110 | LExit: | ||
111 | return hr; | ||
112 | } | ||
113 | |||
114 | STDMETHODIMP UtilSearchFindById( | ||
115 | __in UTIL_SEARCHES* pSearches, | ||
116 | __in LPCWSTR wzId, | ||
117 | __out UTIL_SEARCH** ppSearch | ||
118 | ) | ||
119 | { | ||
120 | HRESULT hr = S_OK; | ||
121 | |||
122 | for (DWORD i = 0; i < pSearches->cSearches; ++i) | ||
123 | { | ||
124 | UTIL_SEARCH* pSearch = &pSearches->rgSearches[i]; | ||
125 | |||
126 | if (CSTR_EQUAL == ::CompareStringW(LOCALE_INVARIANT, 0, pSearch->sczId, -1, wzId, -1)) | ||
127 | { | ||
128 | *ppSearch = pSearch; | ||
129 | ExitFunction1(hr = S_OK); | ||
130 | } | ||
131 | } | ||
132 | |||
133 | hr = E_NOTFOUND; | ||
134 | |||
135 | LExit: | ||
136 | return hr; | ||
137 | } | ||
diff --git a/src/be/utilsearch.h b/src/be/utilsearch.h new file mode 100644 index 00000000..1e0ca96d --- /dev/null +++ b/src/be/utilsearch.h | |||
@@ -0,0 +1,52 @@ | |||
1 | #pragma once | ||
2 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
3 | |||
4 | |||
5 | // constants | ||
6 | |||
7 | enum UTIL_SEARCH_TYPE | ||
8 | { | ||
9 | UTIL_SEARCH_TYPE_NONE, | ||
10 | UTIL_SEARCH_TYPE_DETECT_SHA2_SUPPORT, | ||
11 | }; | ||
12 | |||
13 | |||
14 | // structs | ||
15 | |||
16 | typedef struct _UTIL_SEARCH | ||
17 | { | ||
18 | LPWSTR sczId; | ||
19 | |||
20 | UTIL_SEARCH_TYPE Type; | ||
21 | } UTIL_SEARCH; | ||
22 | |||
23 | typedef struct _UTIL_SEARCHES | ||
24 | { | ||
25 | UTIL_SEARCH* rgSearches; | ||
26 | DWORD cSearches; | ||
27 | } UTIL_SEARCHES; | ||
28 | |||
29 | |||
30 | // function declarations | ||
31 | |||
32 | STDMETHODIMP UtilSearchParseFromXml( | ||
33 | __in UTIL_SEARCHES* pSearches, | ||
34 | __in IXMLDOMNode* pixnBundleExtension | ||
35 | ); | ||
36 | |||
37 | void UtilSearchUninitialize( | ||
38 | __in UTIL_SEARCHES* pSearches | ||
39 | ); | ||
40 | |||
41 | STDMETHODIMP UtilSearchExecute( | ||
42 | __in UTIL_SEARCHES* pSearches, | ||
43 | __in LPCWSTR wzSearchId, | ||
44 | __in LPCWSTR wzVariable, | ||
45 | __in IBundleExtensionEngine* pEngine | ||
46 | ); | ||
47 | |||
48 | STDMETHODIMP UtilSearchFindById( | ||
49 | __in UTIL_SEARCHES* pSearches, | ||
50 | __in LPCWSTR wzId, | ||
51 | __out UTIL_SEARCH** ppSearch | ||
52 | ); | ||