Coverage Report

Created: 2025-11-16 06:57

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/samba/source4/libcli/raw/rawshadow.c
Line
Count
Source
1
/*
2
   Unix SMB/CIFS implementation.
3
4
   shadow copy file operations
5
6
   Copyright (C) Andrew Tridgell 2007
7
8
   This program is free software; you can redistribute it and/or modify
9
   it under the terms of the GNU General Public License as published by
10
   the Free Software Foundation; either version 3 of the License, or
11
   (at your option) any later version.
12
13
   This program is distributed in the hope that it will be useful,
14
   but WITHOUT ANY WARRANTY; without even the implied warranty of
15
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16
   GNU General Public License for more details.
17
18
   You should have received a copy of the GNU General Public License
19
   along with this program.  If not, see <http://www.gnu.org/licenses/>.
20
*/
21
22
#include "includes.h"
23
#include "libcli/raw/libcliraw.h"
24
#include "libcli/raw/raw_proto.h"
25
#include "../libcli/smb/smb_constants.h"
26
27
/*
28
   get shadow volume data
29
*/
30
_PUBLIC_ NTSTATUS smb_raw_shadow_data(struct smbcli_tree *tree,
31
              TALLOC_CTX *mem_ctx, struct smb_shadow_copy *info)
32
0
{
33
0
  union smb_ioctl nt;
34
0
  NTSTATUS status;
35
0
  DATA_BLOB blob;
36
0
  uint32_t dlength;
37
0
  int i;
38
0
  uint32_t ofs;
39
40
0
  nt.ntioctl.level        = RAW_IOCTL_NTIOCTL;
41
0
  nt.ntioctl.in.function  = FSCTL_GET_SHADOW_COPY_DATA;
42
0
  nt.ntioctl.in.file.fnum = info->in.file.fnum;
43
0
  nt.ntioctl.in.fsctl     = true;
44
0
  nt.ntioctl.in.filter    = 0;
45
0
  nt.ntioctl.in.max_data  = info->in.max_data;
46
0
  nt.ntioctl.in.blob      = data_blob(NULL, 0);
47
48
0
  status = smb_raw_ioctl(tree, mem_ctx, &nt);
49
0
  if (!NT_STATUS_IS_OK(status)) {
50
0
    return status;
51
0
  }
52
53
0
  blob = nt.ntioctl.out.blob;
54
55
0
  if (blob.length < 12) {
56
0
    return NT_STATUS_INVALID_NETWORK_RESPONSE;
57
0
  }
58
59
0
  info->out.num_volumes = IVAL(blob.data, 0);
60
0
  info->out.num_names   = IVAL(blob.data, 4);
61
0
  dlength               = IVAL(blob.data, 8);
62
0
  if (dlength > blob.length - 12) {
63
0
    return NT_STATUS_INVALID_NETWORK_RESPONSE;
64
0
  }
65
66
0
  info->out.names = talloc_array(mem_ctx, const char *, info->out.num_names);
67
0
  NT_STATUS_HAVE_NO_MEMORY(info->out.names);
68
69
0
  ofs = 12;
70
0
  for (i=0;i<info->out.num_names;i++) {
71
0
    size_t len;
72
0
    len = smbcli_blob_pull_ucs2(info->out.names,
73
0
              &blob, &info->out.names[i],
74
0
              blob.data+ofs, -1, STR_TERMINATE);
75
0
    if (len == 0) {
76
0
      return NT_STATUS_INVALID_NETWORK_RESPONSE;
77
0
    }
78
0
    ofs += len;
79
0
  }
80
81
0
  return status;
82
0
}