Line data Source code
1 : /*
2 : * VFS module with "not implemented " helper functions for other modules.
3 : *
4 : * Copyright (C) Tim Potter, 1999-2000
5 : * Copyright (C) Alexander Bokovoy, 2002
6 : * Copyright (C) Stefan (metze) Metzmacher, 2003,2018
7 : * Copyright (C) Jeremy Allison 2009
8 : *
9 : * This program is free software; you can redistribute it and/or modify
10 : * it under the terms of the GNU General Public License as published by
11 : * the Free Software Foundation; either version 3 of the License, or
12 : * (at your option) any later version.
13 : *
14 : * This program is distributed in the hope that it will be useful,
15 : * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 : * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 : * GNU General Public License for more details.
18 : *
19 : * You should have received a copy of the GNU General Public License
20 : * along with this program; if not, see <http://www.gnu.org/licenses/>.
21 : */
22 :
23 : #include "includes.h"
24 : #include "lib/util/tevent_unix.h"
25 : #include "lib/util/tevent_ntstatus.h"
26 :
27 : _PUBLIC_
28 0 : int vfs_not_implemented_connect(
29 : vfs_handle_struct *handle,
30 : const char *service,
31 : const char *user)
32 : {
33 0 : errno = ENOSYS;
34 0 : return -1;
35 : }
36 :
37 : _PUBLIC_
38 0 : void vfs_not_implemented_disconnect(vfs_handle_struct *handle)
39 : {
40 0 : ;
41 0 : }
42 :
43 : _PUBLIC_
44 0 : uint64_t vfs_not_implemented_disk_free(vfs_handle_struct *handle,
45 : const struct smb_filename *smb_fname,
46 : uint64_t *bsize,
47 : uint64_t *dfree,
48 : uint64_t *dsize)
49 : {
50 0 : *bsize = 0;
51 0 : *dfree = 0;
52 0 : *dsize = 0;
53 0 : return 0;
54 : }
55 :
56 : _PUBLIC_
57 0 : int vfs_not_implemented_get_quota(vfs_handle_struct *handle,
58 : const struct smb_filename *smb_fname,
59 : enum SMB_QUOTA_TYPE qtype,
60 : unid_t id,
61 : SMB_DISK_QUOTA *dq)
62 : {
63 0 : errno = ENOSYS;
64 0 : return -1;
65 : }
66 :
67 : _PUBLIC_
68 0 : int vfs_not_implemented_set_quota(vfs_handle_struct *handle,
69 : enum SMB_QUOTA_TYPE qtype,
70 : unid_t id, SMB_DISK_QUOTA *dq)
71 : {
72 0 : errno = ENOSYS;
73 0 : return -1;
74 : }
75 :
76 : _PUBLIC_
77 0 : int vfs_not_implemented_get_shadow_copy_data(vfs_handle_struct *handle,
78 : files_struct *fsp,
79 : struct shadow_copy_data *shadow_copy_data,
80 : bool labels)
81 : {
82 0 : errno = ENOSYS;
83 0 : return -1;
84 : }
85 :
86 : _PUBLIC_
87 0 : int vfs_not_implemented_statvfs(struct vfs_handle_struct *handle,
88 : const struct smb_filename *smb_fname,
89 : struct vfs_statvfs_struct *statbuf)
90 : {
91 0 : errno = ENOSYS;
92 0 : return -1;
93 : }
94 :
95 : _PUBLIC_
96 0 : uint32_t vfs_not_implemented_fs_capabilities(struct vfs_handle_struct *handle,
97 : enum timestamp_set_resolution *p_ts_res)
98 : {
99 0 : return 0;
100 : }
101 :
102 : _PUBLIC_
103 0 : NTSTATUS vfs_not_implemented_get_dfs_referrals(struct vfs_handle_struct *handle,
104 : struct dfs_GetDFSReferral *r)
105 : {
106 0 : return NT_STATUS_NOT_IMPLEMENTED;
107 : }
108 :
109 : _PUBLIC_
110 0 : NTSTATUS vfs_not_implemented_create_dfs_pathat(struct vfs_handle_struct *handle,
111 : struct files_struct *dirfsp,
112 : const struct smb_filename *smb_fname,
113 : const struct referral *reflist,
114 : size_t referral_count)
115 : {
116 0 : return NT_STATUS_NOT_IMPLEMENTED;
117 : }
118 :
119 : _PUBLIC_
120 0 : NTSTATUS vfs_not_implemented_read_dfs_pathat(struct vfs_handle_struct *handle,
121 : TALLOC_CTX *mem_ctx,
122 : struct files_struct *dirfsp,
123 : struct smb_filename *smb_fname,
124 : struct referral **ppreflist,
125 : size_t *preferral_count)
126 : {
127 0 : return NT_STATUS_NOT_IMPLEMENTED;
128 : }
129 :
130 : _PUBLIC_
131 0 : NTSTATUS vfs_not_implemented_snap_check_path(struct vfs_handle_struct *handle,
132 : TALLOC_CTX *mem_ctx,
133 : const char *service_path,
134 : char **base_volume)
135 : {
136 0 : return NT_STATUS_NOT_SUPPORTED;
137 : }
138 :
139 : _PUBLIC_
140 0 : NTSTATUS vfs_not_implemented_snap_create(struct vfs_handle_struct *handle,
141 : TALLOC_CTX *mem_ctx,
142 : const char *base_volume,
143 : time_t *tstamp,
144 : bool rw,
145 : char **base_path,
146 : char **snap_path)
147 : {
148 0 : return NT_STATUS_NOT_SUPPORTED;
149 : }
150 :
151 : _PUBLIC_
152 0 : NTSTATUS vfs_not_implemented_snap_delete(struct vfs_handle_struct *handle,
153 : TALLOC_CTX *mem_ctx,
154 : char *base_path,
155 : char *snap_path)
156 : {
157 0 : return NT_STATUS_NOT_SUPPORTED;
158 : }
159 :
160 : _PUBLIC_
161 0 : DIR *vfs_not_implemented_fdopendir(vfs_handle_struct *handle, files_struct *fsp,
162 : const char *mask, uint32_t attr)
163 : {
164 0 : errno = ENOSYS;
165 0 : return NULL;
166 : }
167 :
168 : _PUBLIC_
169 0 : struct dirent *vfs_not_implemented_readdir(vfs_handle_struct *handle,
170 : struct files_struct *dirfsp,
171 : DIR *dirp)
172 : {
173 0 : errno = ENOSYS;
174 0 : return NULL;
175 : }
176 :
177 : _PUBLIC_
178 0 : void vfs_not_implemented_rewind_dir(vfs_handle_struct *handle, DIR *dirp)
179 : {
180 0 : ;
181 0 : }
182 :
183 : _PUBLIC_
184 0 : int vfs_not_implemented_mkdirat(vfs_handle_struct *handle,
185 : struct files_struct *dirfsp,
186 : const struct smb_filename *smb_fname,
187 : mode_t mode)
188 : {
189 0 : errno = ENOSYS;
190 0 : return -1;
191 : }
192 :
193 : _PUBLIC_
194 0 : int vfs_not_implemented_closedir(vfs_handle_struct *handle, DIR *dir)
195 : {
196 0 : errno = ENOSYS;
197 0 : return -1;
198 : }
199 :
200 : _PUBLIC_
201 0 : int vfs_not_implemented_openat(vfs_handle_struct *handle,
202 : const struct files_struct *dirfsp,
203 : const struct smb_filename *smb_fname,
204 : struct files_struct *fsp,
205 : const struct vfs_open_how *how)
206 : {
207 0 : errno = ENOSYS;
208 0 : return -1;
209 : }
210 :
211 : _PUBLIC_
212 0 : NTSTATUS vfs_not_implemented_create_file(struct vfs_handle_struct *handle,
213 : struct smb_request *req,
214 : struct files_struct *dirsp,
215 : struct smb_filename *smb_fname,
216 : uint32_t access_mask,
217 : uint32_t share_access,
218 : uint32_t create_disposition,
219 : uint32_t create_options,
220 : uint32_t file_attributes,
221 : uint32_t oplock_request,
222 : const struct smb2_lease *lease,
223 : uint64_t allocation_size,
224 : uint32_t private_flags,
225 : struct security_descriptor *sd,
226 : struct ea_list *ea_list,
227 : files_struct **result, int *pinfo,
228 : const struct smb2_create_blobs *in_context_blobs,
229 : struct smb2_create_blobs *out_context_blobs)
230 : {
231 0 : return NT_STATUS_NOT_IMPLEMENTED;
232 : }
233 :
234 : _PUBLIC_
235 0 : int vfs_not_implemented_close_fn(vfs_handle_struct *handle, files_struct *fsp)
236 : {
237 0 : errno = ENOSYS;
238 0 : return -1;
239 : }
240 :
241 : _PUBLIC_
242 0 : ssize_t vfs_not_implemented_pread(vfs_handle_struct *handle, files_struct *fsp,
243 : void *data, size_t n, off_t offset)
244 : {
245 0 : errno = ENOSYS;
246 0 : return -1;
247 : }
248 :
249 : _PUBLIC_
250 0 : struct tevent_req *vfs_not_implemented_pread_send(struct vfs_handle_struct *handle,
251 : TALLOC_CTX *mem_ctx,
252 : struct tevent_context *ev,
253 : struct files_struct *fsp,
254 : void *data, size_t n, off_t offset)
255 : {
256 0 : return NULL;
257 : }
258 :
259 : _PUBLIC_
260 0 : ssize_t vfs_not_implemented_pread_recv(struct tevent_req *req,
261 : struct vfs_aio_state *vfs_aio_state)
262 : {
263 0 : vfs_aio_state->error = ENOSYS;
264 0 : return -1;
265 : }
266 :
267 : _PUBLIC_
268 0 : ssize_t vfs_not_implemented_pwrite(vfs_handle_struct *handle, files_struct *fsp,
269 : const void *data, size_t n, off_t offset)
270 : {
271 0 : errno = ENOSYS;
272 0 : return -1;
273 : }
274 :
275 : _PUBLIC_
276 0 : struct tevent_req *vfs_not_implemented_pwrite_send(struct vfs_handle_struct *handle,
277 : TALLOC_CTX *mem_ctx,
278 : struct tevent_context *ev,
279 : struct files_struct *fsp,
280 : const void *data,
281 : size_t n, off_t offset)
282 : {
283 0 : return NULL;
284 : }
285 :
286 : _PUBLIC_
287 0 : ssize_t vfs_not_implemented_pwrite_recv(struct tevent_req *req,
288 : struct vfs_aio_state *vfs_aio_state)
289 : {
290 0 : vfs_aio_state->error = ENOSYS;
291 0 : return -1;
292 : }
293 :
294 : _PUBLIC_
295 0 : off_t vfs_not_implemented_lseek(vfs_handle_struct *handle, files_struct *fsp,
296 : off_t offset, int whence)
297 : {
298 0 : errno = ENOSYS;
299 0 : return (off_t) - 1;
300 : }
301 :
302 : _PUBLIC_
303 0 : ssize_t vfs_not_implemented_sendfile(vfs_handle_struct *handle, int tofd,
304 : files_struct *fromfsp, const DATA_BLOB *hdr,
305 : off_t offset, size_t n)
306 : {
307 0 : errno = ENOSYS;
308 0 : return -1;
309 : }
310 :
311 : _PUBLIC_
312 0 : ssize_t vfs_not_implemented_recvfile(vfs_handle_struct *handle, int fromfd,
313 : files_struct *tofsp, off_t offset, size_t n)
314 : {
315 0 : errno = ENOSYS;
316 0 : return -1;
317 : }
318 :
319 : _PUBLIC_
320 0 : int vfs_not_implemented_renameat(vfs_handle_struct *handle,
321 : files_struct *srcfsp,
322 : const struct smb_filename *smb_fname_src,
323 : files_struct *dstfsp,
324 : const struct smb_filename *smb_fname_dst)
325 : {
326 0 : errno = ENOSYS;
327 0 : return -1;
328 : }
329 :
330 : _PUBLIC_
331 0 : struct tevent_req *vfs_not_implemented_fsync_send(struct vfs_handle_struct *handle,
332 : TALLOC_CTX *mem_ctx,
333 : struct tevent_context *ev,
334 : struct files_struct *fsp)
335 : {
336 0 : return NULL;
337 : }
338 :
339 : _PUBLIC_
340 0 : int vfs_not_implemented_fsync_recv(struct tevent_req *req,
341 : struct vfs_aio_state *vfs_aio_state)
342 : {
343 0 : vfs_aio_state->error = ENOSYS;
344 0 : return -1;
345 : }
346 :
347 : _PUBLIC_
348 0 : int vfs_not_implemented_stat(vfs_handle_struct *handle, struct smb_filename *smb_fname)
349 : {
350 0 : errno = ENOSYS;
351 0 : return -1;
352 : }
353 :
354 : _PUBLIC_
355 0 : int vfs_not_implemented_fstat(vfs_handle_struct *handle, files_struct *fsp,
356 : SMB_STRUCT_STAT *sbuf)
357 : {
358 0 : errno = ENOSYS;
359 0 : return -1;
360 : }
361 :
362 : _PUBLIC_
363 0 : int vfs_not_implemented_lstat(vfs_handle_struct *handle,
364 : struct smb_filename *smb_fname)
365 : {
366 0 : errno = ENOSYS;
367 0 : return -1;
368 : }
369 :
370 : _PUBLIC_
371 0 : int vfs_not_implemented_fstatat(
372 : struct vfs_handle_struct *handle,
373 : const struct files_struct *dirfsp,
374 : const struct smb_filename *smb_fname,
375 : SMB_STRUCT_STAT *sbuf,
376 : int flags)
377 : {
378 0 : errno = ENOSYS;
379 0 : return -1;
380 : }
381 :
382 : _PUBLIC_
383 0 : uint64_t vfs_not_implemented_get_alloc_size(struct vfs_handle_struct *handle,
384 : struct files_struct *fsp,
385 : const SMB_STRUCT_STAT *sbuf)
386 : {
387 0 : errno = ENOSYS;
388 0 : return -1;
389 : }
390 :
391 : _PUBLIC_
392 0 : int vfs_not_implemented_unlinkat(vfs_handle_struct *handle,
393 : struct files_struct *dirfsp,
394 : const struct smb_filename *smb_fname,
395 : int flags)
396 : {
397 0 : errno = ENOSYS;
398 0 : return -1;
399 : }
400 :
401 : _PUBLIC_
402 0 : int vfs_not_implemented_fchmod(vfs_handle_struct *handle, files_struct *fsp,
403 : mode_t mode)
404 : {
405 0 : errno = ENOSYS;
406 0 : return -1;
407 : }
408 :
409 : _PUBLIC_
410 0 : int vfs_not_implemented_fchown(vfs_handle_struct *handle, files_struct *fsp,
411 : uid_t uid, gid_t gid)
412 : {
413 0 : errno = ENOSYS;
414 0 : return -1;
415 : }
416 :
417 : _PUBLIC_
418 0 : int vfs_not_implemented_lchown(vfs_handle_struct *handle,
419 : const struct smb_filename *smb_fname,
420 : uid_t uid,
421 : gid_t gid)
422 : {
423 0 : errno = ENOSYS;
424 0 : return -1;
425 : }
426 :
427 : _PUBLIC_
428 0 : int vfs_not_implemented_chdir(vfs_handle_struct *handle,
429 : const struct smb_filename *smb_fname)
430 : {
431 0 : errno = ENOSYS;
432 0 : return -1;
433 : }
434 :
435 : _PUBLIC_
436 0 : struct smb_filename *vfs_not_implemented_getwd(vfs_handle_struct *handle,
437 : TALLOC_CTX *ctx)
438 : {
439 0 : errno = ENOSYS;
440 0 : return NULL;
441 : }
442 :
443 : _PUBLIC_
444 0 : int vfs_not_implemented_fntimes(vfs_handle_struct *handle,
445 : files_struct *fsp,
446 : struct smb_file_time *ft)
447 : {
448 0 : errno = ENOSYS;
449 0 : return -1;
450 : }
451 :
452 : _PUBLIC_
453 0 : int vfs_not_implemented_ftruncate(vfs_handle_struct *handle, files_struct *fsp,
454 : off_t offset)
455 : {
456 0 : errno = ENOSYS;
457 0 : return -1;
458 : }
459 :
460 : _PUBLIC_
461 0 : int vfs_not_implemented_fallocate(vfs_handle_struct *handle, files_struct *fsp,
462 : uint32_t mode, off_t offset, off_t len)
463 : {
464 0 : errno = ENOSYS;
465 0 : return -1;
466 : }
467 :
468 : _PUBLIC_
469 0 : bool vfs_not_implemented_lock(vfs_handle_struct *handle, files_struct *fsp, int op,
470 : off_t offset, off_t count, int type)
471 : {
472 0 : errno = ENOSYS;
473 0 : return false;
474 : }
475 :
476 : _PUBLIC_
477 0 : int vfs_not_implemented_filesystem_sharemode(struct vfs_handle_struct *handle,
478 : struct files_struct *fsp,
479 : uint32_t share_access,
480 : uint32_t access_mask)
481 : {
482 0 : errno = ENOSYS;
483 0 : return -1;
484 : }
485 :
486 : _PUBLIC_
487 0 : int vfs_not_implemented_fcntl(struct vfs_handle_struct *handle,
488 : struct files_struct *fsp, int cmd,
489 : va_list cmd_arg)
490 : {
491 0 : errno = ENOSYS;
492 0 : return -1;
493 : }
494 :
495 : _PUBLIC_
496 0 : int vfs_not_implemented_linux_setlease(struct vfs_handle_struct *handle,
497 : struct files_struct *fsp, int leasetype)
498 : {
499 0 : errno = ENOSYS;
500 0 : return -1;
501 : }
502 :
503 : _PUBLIC_
504 0 : bool vfs_not_implemented_getlock(vfs_handle_struct *handle, files_struct *fsp,
505 : off_t *poffset, off_t *pcount, int *ptype,
506 : pid_t *ppid)
507 : {
508 0 : errno = ENOSYS;
509 0 : return false;
510 : }
511 :
512 : _PUBLIC_
513 0 : int vfs_not_implemented_symlinkat(vfs_handle_struct *handle,
514 : const struct smb_filename *link_contents,
515 : struct files_struct *dirfsp,
516 : const struct smb_filename *new_smb_fname)
517 : {
518 0 : errno = ENOSYS;
519 0 : return -1;
520 : }
521 :
522 : _PUBLIC_
523 0 : int vfs_not_implemented_vfs_readlinkat(vfs_handle_struct *handle,
524 : const struct files_struct *dirfsp,
525 : const struct smb_filename *smb_fname,
526 : char *buf,
527 : size_t bufsiz)
528 : {
529 0 : errno = ENOSYS;
530 0 : return -1;
531 : }
532 :
533 : _PUBLIC_
534 0 : int vfs_not_implemented_linkat(vfs_handle_struct *handle,
535 : files_struct *srcfsp,
536 : const struct smb_filename *old_smb_fname,
537 : files_struct *dstfsp,
538 : const struct smb_filename *new_smb_fname,
539 : int flags)
540 : {
541 0 : errno = ENOSYS;
542 0 : return -1;
543 : }
544 :
545 : _PUBLIC_
546 0 : int vfs_not_implemented_mknodat(vfs_handle_struct *handle,
547 : files_struct *dirfsp,
548 : const struct smb_filename *smb_fname,
549 : mode_t mode,
550 : SMB_DEV_T dev)
551 : {
552 0 : errno = ENOSYS;
553 0 : return -1;
554 : }
555 :
556 : _PUBLIC_
557 0 : struct smb_filename *vfs_not_implemented_realpath(vfs_handle_struct *handle,
558 : TALLOC_CTX *ctx,
559 : const struct smb_filename *smb_fname)
560 : {
561 0 : errno = ENOSYS;
562 0 : return NULL;
563 : }
564 :
565 : _PUBLIC_
566 0 : int vfs_not_implemented_fchflags(vfs_handle_struct *handle,
567 : struct files_struct *fsp,
568 : uint flags)
569 : {
570 0 : errno = ENOSYS;
571 0 : return -1;
572 : }
573 :
574 : _PUBLIC_
575 0 : struct file_id vfs_not_implemented_file_id_create(vfs_handle_struct *handle,
576 : const SMB_STRUCT_STAT *sbuf)
577 : {
578 0 : struct file_id id;
579 0 : ZERO_STRUCT(id);
580 0 : errno = ENOSYS;
581 0 : return id;
582 : }
583 :
584 : _PUBLIC_
585 0 : uint64_t vfs_not_implemented_fs_file_id(vfs_handle_struct *handle,
586 : const SMB_STRUCT_STAT *sbuf)
587 : {
588 0 : errno = ENOSYS;
589 0 : return 0;
590 : }
591 :
592 : struct vfs_not_implemented_offload_read_state {
593 : bool dummy;
594 : };
595 :
596 : _PUBLIC_
597 0 : struct tevent_req *vfs_not_implemented_offload_read_send(
598 : TALLOC_CTX *mem_ctx,
599 : struct tevent_context *ev,
600 : struct vfs_handle_struct *handle,
601 : struct files_struct *fsp,
602 : uint32_t fsctl,
603 : uint32_t ttl,
604 : off_t offset,
605 : size_t to_copy)
606 : {
607 0 : struct tevent_req *req = NULL;
608 0 : struct vfs_not_implemented_offload_read_state *state = NULL;
609 :
610 0 : req = tevent_req_create(mem_ctx, &state,
611 : struct vfs_not_implemented_offload_read_state);
612 0 : if (req == NULL) {
613 0 : return NULL;
614 : }
615 :
616 0 : tevent_req_nterror(req, NT_STATUS_NOT_IMPLEMENTED);
617 0 : return tevent_req_post(req, ev);
618 : }
619 :
620 : _PUBLIC_
621 0 : NTSTATUS vfs_not_implemented_offload_read_recv(struct tevent_req *req,
622 : struct vfs_handle_struct *handle,
623 : TALLOC_CTX *mem_ctx,
624 : uint32_t *flags,
625 : uint64_t *xferlen,
626 : DATA_BLOB *_token_blob)
627 : {
628 0 : NTSTATUS status;
629 :
630 0 : if (tevent_req_is_nterror(req, &status)) {
631 0 : tevent_req_received(req);
632 0 : return status;
633 : }
634 :
635 0 : tevent_req_received(req);
636 0 : return NT_STATUS_OK;
637 : }
638 :
639 : struct vfs_not_implemented_offload_write_state {
640 : uint64_t unused;
641 : };
642 :
643 : _PUBLIC_
644 0 : struct tevent_req *vfs_not_implemented_offload_write_send(
645 : struct vfs_handle_struct *handle,
646 : TALLOC_CTX *mem_ctx,
647 : struct tevent_context *ev,
648 : uint32_t fsctl,
649 : DATA_BLOB *token,
650 : off_t transfer_offset,
651 : struct files_struct *dest_fsp,
652 : off_t dest_off,
653 : off_t num)
654 : {
655 0 : struct tevent_req *req;
656 0 : struct vfs_not_implemented_offload_write_state *state;
657 :
658 0 : req = tevent_req_create(mem_ctx, &state,
659 : struct vfs_not_implemented_offload_write_state);
660 0 : if (req == NULL) {
661 0 : return NULL;
662 : }
663 :
664 0 : tevent_req_nterror(req, NT_STATUS_NOT_IMPLEMENTED);
665 0 : return tevent_req_post(req, ev);
666 : }
667 :
668 : _PUBLIC_
669 0 : NTSTATUS vfs_not_implemented_offload_write_recv(struct vfs_handle_struct *handle,
670 : struct tevent_req *req,
671 : off_t *copied)
672 : {
673 0 : NTSTATUS status;
674 :
675 0 : if (tevent_req_is_nterror(req, &status)) {
676 0 : tevent_req_received(req);
677 0 : return status;
678 : }
679 :
680 0 : tevent_req_received(req);
681 0 : return NT_STATUS_OK;
682 : }
683 :
684 : _PUBLIC_
685 0 : NTSTATUS vfs_not_implemented_fget_compression(struct vfs_handle_struct *handle,
686 : TALLOC_CTX *mem_ctx,
687 : struct files_struct *fsp,
688 : uint16_t *_compression_fmt)
689 : {
690 0 : return NT_STATUS_INVALID_DEVICE_REQUEST;
691 : }
692 :
693 : _PUBLIC_
694 0 : NTSTATUS vfs_not_implemented_set_compression(struct vfs_handle_struct *handle,
695 : TALLOC_CTX *mem_ctx,
696 : struct files_struct *fsp,
697 : uint16_t compression_fmt)
698 : {
699 0 : return NT_STATUS_INVALID_DEVICE_REQUEST;
700 : }
701 :
702 : _PUBLIC_
703 0 : NTSTATUS vfs_not_implemented_fstreaminfo(struct vfs_handle_struct *handle,
704 : struct files_struct *fsp,
705 : TALLOC_CTX *mem_ctx,
706 : unsigned int *num_streams,
707 : struct stream_struct **streams)
708 : {
709 0 : return NT_STATUS_NOT_IMPLEMENTED;
710 : }
711 :
712 : _PUBLIC_
713 0 : NTSTATUS vfs_not_implemented_get_real_filename_at(
714 : struct vfs_handle_struct *handle,
715 : struct files_struct *dirfsp,
716 : const char *name,
717 : TALLOC_CTX *mem_ctx,
718 : char **found_name)
719 : {
720 0 : return NT_STATUS_NOT_IMPLEMENTED;
721 : }
722 :
723 : _PUBLIC_
724 0 : const char *vfs_not_implemented_connectpath(
725 : struct vfs_handle_struct *handle,
726 : const struct files_struct *dirfsp,
727 : const struct smb_filename *smb_fname)
728 : {
729 0 : errno = ENOSYS;
730 0 : return NULL;
731 : }
732 :
733 : _PUBLIC_
734 0 : NTSTATUS vfs_not_implemented_brl_lock_windows(struct vfs_handle_struct *handle,
735 : struct byte_range_lock *br_lck,
736 : struct lock_struct *plock)
737 : {
738 0 : return NT_STATUS_NOT_IMPLEMENTED;
739 : }
740 :
741 : _PUBLIC_
742 0 : bool vfs_not_implemented_brl_unlock_windows(struct vfs_handle_struct *handle,
743 : struct byte_range_lock *br_lck,
744 : const struct lock_struct *plock)
745 : {
746 0 : errno = ENOSYS;
747 0 : return false;
748 : }
749 :
750 : _PUBLIC_
751 0 : bool vfs_not_implemented_strict_lock_check(struct vfs_handle_struct *handle,
752 : struct files_struct *fsp,
753 : struct lock_struct *plock)
754 : {
755 0 : errno = ENOSYS;
756 0 : return false;
757 : }
758 :
759 : _PUBLIC_
760 0 : NTSTATUS vfs_not_implemented_translate_name(struct vfs_handle_struct *handle,
761 : const char *mapped_name,
762 : enum vfs_translate_direction direction,
763 : TALLOC_CTX *mem_ctx, char **pmapped_name)
764 : {
765 0 : return NT_STATUS_NOT_IMPLEMENTED;
766 : }
767 :
768 : _PUBLIC_
769 0 : NTSTATUS vfs_not_implemented_parent_pathname(struct vfs_handle_struct *handle,
770 : TALLOC_CTX *mem_ctx,
771 : const struct smb_filename *smb_fname_in,
772 : struct smb_filename **parent_dir_out,
773 : struct smb_filename **atname_out)
774 : {
775 0 : return NT_STATUS_NOT_IMPLEMENTED;
776 : }
777 :
778 : _PUBLIC_
779 0 : NTSTATUS vfs_not_implemented_fsctl(struct vfs_handle_struct *handle,
780 : struct files_struct *fsp,
781 : TALLOC_CTX *ctx,
782 : uint32_t function,
783 : uint16_t req_flags, /* Needed for UNICODE ... */
784 : const uint8_t *_in_data,
785 : uint32_t in_len,
786 : uint8_t **_out_data,
787 : uint32_t max_out_len, uint32_t *out_len)
788 : {
789 0 : return NT_STATUS_NOT_IMPLEMENTED;
790 : }
791 :
792 : _PUBLIC_
793 0 : NTSTATUS vfs_not_implemented_freaddir_attr(struct vfs_handle_struct *handle,
794 : struct files_struct *fsp,
795 : TALLOC_CTX *mem_ctx,
796 : struct readdir_attr_data **pattr_data)
797 : {
798 0 : return NT_STATUS_NOT_IMPLEMENTED;
799 : }
800 :
801 : struct vfs_not_implemented_get_dos_attributes_state {
802 : struct vfs_aio_state aio_state;
803 : uint32_t dosmode;
804 : };
805 :
806 : _PUBLIC_
807 0 : struct tevent_req *vfs_not_implemented_get_dos_attributes_send(
808 : TALLOC_CTX *mem_ctx,
809 : struct tevent_context *ev,
810 : struct vfs_handle_struct *handle,
811 : files_struct *dir_fsp,
812 : struct smb_filename *smb_fname)
813 : {
814 0 : struct tevent_req *req = NULL;
815 0 : struct vfs_not_implemented_get_dos_attributes_state *state = NULL;
816 :
817 0 : req = tevent_req_create(mem_ctx, &state,
818 : struct vfs_not_implemented_get_dos_attributes_state);
819 0 : if (req == NULL) {
820 0 : return NULL;
821 : }
822 :
823 0 : tevent_req_nterror(req, NT_STATUS_NOT_IMPLEMENTED);
824 0 : return tevent_req_post(req, ev);
825 : }
826 :
827 : _PUBLIC_
828 0 : NTSTATUS vfs_not_implemented_get_dos_attributes_recv(
829 : struct tevent_req *req,
830 : struct vfs_aio_state *aio_state,
831 : uint32_t *dosmode)
832 : {
833 0 : struct vfs_not_implemented_get_dos_attributes_state *state =
834 0 : tevent_req_data(req,
835 : struct vfs_not_implemented_get_dos_attributes_state);
836 0 : NTSTATUS status;
837 :
838 0 : if (tevent_req_is_nterror(req, &status)) {
839 0 : tevent_req_received(req);
840 0 : return status;
841 : }
842 :
843 0 : *aio_state = state->aio_state;
844 0 : *dosmode = state->dosmode;
845 0 : tevent_req_received(req);
846 0 : return NT_STATUS_OK;
847 : }
848 :
849 : _PUBLIC_
850 0 : NTSTATUS vfs_not_implemented_fget_dos_attributes(struct vfs_handle_struct *handle,
851 : struct files_struct *fsp,
852 : uint32_t *dosmode)
853 : {
854 0 : return NT_STATUS_NOT_IMPLEMENTED;
855 : }
856 :
857 : _PUBLIC_
858 0 : NTSTATUS vfs_not_implemented_fset_dos_attributes(struct vfs_handle_struct *handle,
859 : struct files_struct *fsp,
860 : uint32_t dosmode)
861 : {
862 0 : return NT_STATUS_NOT_IMPLEMENTED;
863 : }
864 :
865 : _PUBLIC_
866 0 : NTSTATUS vfs_not_implemented_fget_nt_acl(vfs_handle_struct *handle, files_struct *fsp,
867 : uint32_t security_info,
868 : TALLOC_CTX *mem_ctx,
869 : struct security_descriptor **ppdesc)
870 : {
871 0 : return NT_STATUS_NOT_IMPLEMENTED;
872 : }
873 :
874 : _PUBLIC_
875 0 : NTSTATUS vfs_not_implemented_fset_nt_acl(vfs_handle_struct *handle, files_struct *fsp,
876 : uint32_t security_info_sent,
877 : const struct security_descriptor *psd)
878 : {
879 0 : return NT_STATUS_NOT_IMPLEMENTED;
880 : }
881 :
882 : _PUBLIC_
883 0 : SMB_ACL_T vfs_not_implemented_sys_acl_get_fd(vfs_handle_struct *handle,
884 : files_struct *fsp,
885 : SMB_ACL_TYPE_T type,
886 : TALLOC_CTX *mem_ctx)
887 : {
888 0 : errno = ENOSYS;
889 0 : return (SMB_ACL_T) NULL;
890 : }
891 :
892 : _PUBLIC_
893 0 : int vfs_not_implemented_sys_acl_blob_get_fd(vfs_handle_struct *handle,
894 : files_struct *fsp, TALLOC_CTX *mem_ctx,
895 : char **blob_description, DATA_BLOB *blob)
896 : {
897 0 : errno = ENOSYS;
898 0 : return -1;
899 : }
900 :
901 : _PUBLIC_
902 0 : int vfs_not_implemented_sys_acl_set_fd(vfs_handle_struct *handle,
903 : struct files_struct *fsp,
904 : SMB_ACL_TYPE_T type,
905 : SMB_ACL_T theacl)
906 : {
907 0 : errno = ENOSYS;
908 0 : return -1;
909 : }
910 :
911 : _PUBLIC_
912 0 : int vfs_not_implemented_sys_acl_delete_def_fd(vfs_handle_struct *handle,
913 : struct files_struct *fsp)
914 : {
915 0 : errno = ENOSYS;
916 0 : return -1;
917 : }
918 :
919 : struct vfs_not_implemented_getxattrat_state {
920 : struct vfs_aio_state aio_state;
921 : ssize_t xattr_size;
922 : uint8_t *xattr_value;
923 : };
924 :
925 : _PUBLIC_
926 0 : struct tevent_req *vfs_not_implemented_getxattrat_send(
927 : TALLOC_CTX *mem_ctx,
928 : struct tevent_context *ev,
929 : struct vfs_handle_struct *handle,
930 : files_struct *dir_fsp,
931 : const struct smb_filename *smb_fname,
932 : const char *xattr_name,
933 : size_t alloc_hint)
934 : {
935 0 : struct tevent_req *req = NULL;
936 0 : struct vfs_not_implemented_getxattrat_state *state = NULL;
937 :
938 0 : req = tevent_req_create(mem_ctx, &state,
939 : struct vfs_not_implemented_getxattrat_state);
940 0 : if (req == NULL) {
941 0 : return NULL;
942 : }
943 :
944 0 : tevent_req_error(req, ENOSYS);
945 0 : return tevent_req_post(req, ev);
946 : }
947 :
948 : _PUBLIC_
949 0 : ssize_t vfs_not_implemented_getxattrat_recv(struct tevent_req *req,
950 : struct vfs_aio_state *aio_state,
951 : TALLOC_CTX *mem_ctx,
952 : uint8_t **xattr_value)
953 : {
954 0 : struct vfs_not_implemented_getxattrat_state *state = tevent_req_data(
955 : req, struct vfs_not_implemented_getxattrat_state);
956 0 : ssize_t xattr_size;
957 :
958 0 : if (tevent_req_is_unix_error(req, &aio_state->error)) {
959 0 : tevent_req_received(req);
960 0 : return -1;
961 : }
962 :
963 0 : *aio_state = state->aio_state;
964 0 : xattr_size = state->xattr_size;
965 0 : if (xattr_value != NULL) {
966 0 : *xattr_value = talloc_move(mem_ctx, &state->xattr_value);
967 : }
968 :
969 0 : tevent_req_received(req);
970 0 : return xattr_size;
971 : }
972 :
973 : _PUBLIC_
974 0 : ssize_t vfs_not_implemented_fgetxattr(vfs_handle_struct *handle,
975 : struct files_struct *fsp, const char *name,
976 : void *value, size_t size)
977 : {
978 0 : errno = ENOSYS;
979 0 : return -1;
980 : }
981 :
982 : _PUBLIC_
983 0 : ssize_t vfs_not_implemented_flistxattr(vfs_handle_struct *handle,
984 : struct files_struct *fsp, char *list,
985 : size_t size)
986 : {
987 0 : errno = ENOSYS;
988 0 : return -1;
989 : }
990 :
991 : _PUBLIC_
992 0 : int vfs_not_implemented_fremovexattr(vfs_handle_struct *handle,
993 : struct files_struct *fsp, const char *name)
994 : {
995 0 : errno = ENOSYS;
996 0 : return -1;
997 : }
998 :
999 : _PUBLIC_
1000 0 : int vfs_not_implemented_fsetxattr(vfs_handle_struct *handle, struct files_struct *fsp,
1001 : const char *name, const void *value, size_t size,
1002 : int flags)
1003 : {
1004 0 : errno = ENOSYS;
1005 0 : return -1;
1006 : }
1007 :
1008 : _PUBLIC_
1009 0 : bool vfs_not_implemented_aio_force(struct vfs_handle_struct *handle,
1010 : struct files_struct *fsp)
1011 : {
1012 0 : errno = ENOSYS;
1013 0 : return false;
1014 : }
1015 :
1016 : _PUBLIC_
1017 0 : NTSTATUS vfs_not_implemented_audit_file(struct vfs_handle_struct *handle,
1018 : struct smb_filename *file,
1019 : struct security_acl *sacl,
1020 : uint32_t access_requested,
1021 : uint32_t access_denied)
1022 : {
1023 0 : return NT_STATUS_NOT_IMPLEMENTED;
1024 : }
1025 :
1026 : _PUBLIC_
1027 0 : NTSTATUS vfs_not_implemented_durable_cookie(struct vfs_handle_struct *handle,
1028 : struct files_struct *fsp,
1029 : TALLOC_CTX *mem_ctx,
1030 : DATA_BLOB *cookie)
1031 : {
1032 0 : return NT_STATUS_NOT_IMPLEMENTED;
1033 : }
1034 :
1035 : _PUBLIC_
1036 0 : NTSTATUS vfs_not_implemented_durable_disconnect(struct vfs_handle_struct *handle,
1037 : struct files_struct *fsp,
1038 : const DATA_BLOB old_cookie,
1039 : TALLOC_CTX *mem_ctx,
1040 : DATA_BLOB *new_cookie)
1041 : {
1042 0 : return NT_STATUS_NOT_IMPLEMENTED;
1043 : }
1044 :
1045 : _PUBLIC_
1046 0 : NTSTATUS vfs_not_implemented_durable_reconnect(struct vfs_handle_struct *handle,
1047 : struct smb_request *smb1req,
1048 : struct smbXsrv_open *op,
1049 : const DATA_BLOB old_cookie,
1050 : TALLOC_CTX *mem_ctx,
1051 : struct files_struct **fsp,
1052 : DATA_BLOB *new_cookie)
1053 : {
1054 0 : return NT_STATUS_NOT_IMPLEMENTED;
1055 : }
1056 :
1057 : /* VFS operations structure */
1058 :
1059 : static struct vfs_fn_pointers vfs_not_implemented_fns = {
1060 : /* Disk operations */
1061 :
1062 : .connect_fn = vfs_not_implemented_connect,
1063 : .disconnect_fn = vfs_not_implemented_disconnect,
1064 : .disk_free_fn = vfs_not_implemented_disk_free,
1065 : .get_quota_fn = vfs_not_implemented_get_quota,
1066 : .set_quota_fn = vfs_not_implemented_set_quota,
1067 : .get_shadow_copy_data_fn = vfs_not_implemented_get_shadow_copy_data,
1068 : .statvfs_fn = vfs_not_implemented_statvfs,
1069 : .fs_capabilities_fn = vfs_not_implemented_fs_capabilities,
1070 : .get_dfs_referrals_fn = vfs_not_implemented_get_dfs_referrals,
1071 : .create_dfs_pathat_fn = vfs_not_implemented_create_dfs_pathat,
1072 : .read_dfs_pathat_fn = vfs_not_implemented_read_dfs_pathat,
1073 : .snap_check_path_fn = vfs_not_implemented_snap_check_path,
1074 : .snap_create_fn = vfs_not_implemented_snap_create,
1075 : .snap_delete_fn = vfs_not_implemented_snap_delete,
1076 :
1077 : /* Directory operations */
1078 :
1079 : .fdopendir_fn = vfs_not_implemented_fdopendir,
1080 : .readdir_fn = vfs_not_implemented_readdir,
1081 : .rewind_dir_fn = vfs_not_implemented_rewind_dir,
1082 : .mkdirat_fn = vfs_not_implemented_mkdirat,
1083 : .closedir_fn = vfs_not_implemented_closedir,
1084 :
1085 : /* File operations */
1086 :
1087 : .openat_fn = vfs_not_implemented_openat,
1088 : .create_file_fn = vfs_not_implemented_create_file,
1089 : .close_fn = vfs_not_implemented_close_fn,
1090 : .pread_fn = vfs_not_implemented_pread,
1091 : .pread_send_fn = vfs_not_implemented_pread_send,
1092 : .pread_recv_fn = vfs_not_implemented_pread_recv,
1093 : .pwrite_fn = vfs_not_implemented_pwrite,
1094 : .pwrite_send_fn = vfs_not_implemented_pwrite_send,
1095 : .pwrite_recv_fn = vfs_not_implemented_pwrite_recv,
1096 : .lseek_fn = vfs_not_implemented_lseek,
1097 : .sendfile_fn = vfs_not_implemented_sendfile,
1098 : .recvfile_fn = vfs_not_implemented_recvfile,
1099 : .renameat_fn = vfs_not_implemented_renameat,
1100 : .fsync_send_fn = vfs_not_implemented_fsync_send,
1101 : .fsync_recv_fn = vfs_not_implemented_fsync_recv,
1102 : .stat_fn = vfs_not_implemented_stat,
1103 : .fstat_fn = vfs_not_implemented_fstat,
1104 : .lstat_fn = vfs_not_implemented_lstat,
1105 : .fstatat_fn = vfs_not_implemented_fstatat,
1106 : .get_alloc_size_fn = vfs_not_implemented_get_alloc_size,
1107 : .unlinkat_fn = vfs_not_implemented_unlinkat,
1108 : .fchmod_fn = vfs_not_implemented_fchmod,
1109 : .fchown_fn = vfs_not_implemented_fchown,
1110 : .lchown_fn = vfs_not_implemented_lchown,
1111 : .chdir_fn = vfs_not_implemented_chdir,
1112 : .getwd_fn = vfs_not_implemented_getwd,
1113 : .fntimes_fn = vfs_not_implemented_fntimes,
1114 : .ftruncate_fn = vfs_not_implemented_ftruncate,
1115 : .fallocate_fn = vfs_not_implemented_fallocate,
1116 : .lock_fn = vfs_not_implemented_lock,
1117 : .filesystem_sharemode_fn = vfs_not_implemented_filesystem_sharemode,
1118 : .fcntl_fn = vfs_not_implemented_fcntl,
1119 : .linux_setlease_fn = vfs_not_implemented_linux_setlease,
1120 : .getlock_fn = vfs_not_implemented_getlock,
1121 : .symlinkat_fn = vfs_not_implemented_symlinkat,
1122 : .readlinkat_fn = vfs_not_implemented_vfs_readlinkat,
1123 : .linkat_fn = vfs_not_implemented_linkat,
1124 : .mknodat_fn = vfs_not_implemented_mknodat,
1125 : .realpath_fn = vfs_not_implemented_realpath,
1126 : .fchflags_fn = vfs_not_implemented_fchflags,
1127 : .file_id_create_fn = vfs_not_implemented_file_id_create,
1128 : .fs_file_id_fn = vfs_not_implemented_fs_file_id,
1129 : .offload_read_send_fn = vfs_not_implemented_offload_read_send,
1130 : .offload_read_recv_fn = vfs_not_implemented_offload_read_recv,
1131 : .offload_write_send_fn = vfs_not_implemented_offload_write_send,
1132 : .offload_write_recv_fn = vfs_not_implemented_offload_write_recv,
1133 : .fget_compression_fn = vfs_not_implemented_fget_compression,
1134 : .set_compression_fn = vfs_not_implemented_set_compression,
1135 :
1136 : .fstreaminfo_fn = vfs_not_implemented_fstreaminfo,
1137 : .get_real_filename_at_fn = vfs_not_implemented_get_real_filename_at,
1138 : .connectpath_fn = vfs_not_implemented_connectpath,
1139 : .brl_lock_windows_fn = vfs_not_implemented_brl_lock_windows,
1140 : .brl_unlock_windows_fn = vfs_not_implemented_brl_unlock_windows,
1141 : .strict_lock_check_fn = vfs_not_implemented_strict_lock_check,
1142 : .translate_name_fn = vfs_not_implemented_translate_name,
1143 : .parent_pathname_fn = vfs_not_implemented_parent_pathname,
1144 : .fsctl_fn = vfs_not_implemented_fsctl,
1145 : .freaddir_attr_fn = vfs_not_implemented_freaddir_attr,
1146 : .audit_file_fn = vfs_not_implemented_audit_file,
1147 :
1148 : /* DOS attributes. */
1149 : .get_dos_attributes_send_fn = vfs_not_implemented_get_dos_attributes_send,
1150 : .get_dos_attributes_recv_fn = vfs_not_implemented_get_dos_attributes_recv,
1151 : .fget_dos_attributes_fn = vfs_not_implemented_fget_dos_attributes,
1152 : .fset_dos_attributes_fn = vfs_not_implemented_fset_dos_attributes,
1153 :
1154 : /* NT ACL operations. */
1155 :
1156 : .fget_nt_acl_fn = vfs_not_implemented_fget_nt_acl,
1157 : .fset_nt_acl_fn = vfs_not_implemented_fset_nt_acl,
1158 :
1159 : /* POSIX ACL operations. */
1160 :
1161 : .sys_acl_get_fd_fn = vfs_not_implemented_sys_acl_get_fd,
1162 : .sys_acl_blob_get_fd_fn = vfs_not_implemented_sys_acl_blob_get_fd,
1163 : .sys_acl_set_fd_fn = vfs_not_implemented_sys_acl_set_fd,
1164 : .sys_acl_delete_def_fd_fn = vfs_not_implemented_sys_acl_delete_def_fd,
1165 :
1166 : /* EA operations. */
1167 : .getxattrat_send_fn = vfs_not_implemented_getxattrat_send,
1168 : .getxattrat_recv_fn = vfs_not_implemented_getxattrat_recv,
1169 : .fgetxattr_fn = vfs_not_implemented_fgetxattr,
1170 : .flistxattr_fn = vfs_not_implemented_flistxattr,
1171 : .fremovexattr_fn = vfs_not_implemented_fremovexattr,
1172 : .fsetxattr_fn = vfs_not_implemented_fsetxattr,
1173 :
1174 : /* aio operations */
1175 : .aio_force_fn = vfs_not_implemented_aio_force,
1176 :
1177 : /* durable handle operations */
1178 : .durable_cookie_fn = vfs_not_implemented_durable_cookie,
1179 : .durable_disconnect_fn = vfs_not_implemented_durable_disconnect,
1180 : .durable_reconnect_fn = vfs_not_implemented_durable_reconnect,
1181 : };
1182 :
1183 : static_decl_vfs;
1184 28912 : NTSTATUS vfs_not_implemented_init(TALLOC_CTX *ctx)
1185 : {
1186 : /*
1187 : * smb_vfs_assert_all_fns() makes sure every
1188 : * call is implemented.
1189 : */
1190 28912 : smb_vfs_assert_all_fns(&vfs_not_implemented_fns, "vfs_not_implemented");
1191 28912 : return smb_register_vfs(SMB_VFS_INTERFACE_VERSION, "vfs_not_implemented",
1192 : &vfs_not_implemented_fns);
1193 : }
|