X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=include%2Fatalk%2Fvolume.h;h=ad8be2b8421ff98a384a907b45145e3a6c0cc298;hb=ab6e6f8ed24667ced438afe4df5997469a2ff53b;hp=e7f87724ad1da4a0aff63644f857ef9d18f6de73;hpb=83c9131bbca30fe8834e681420e12cc5c7db8c5a;p=netatalk.git diff --git a/include/atalk/volume.h b/include/atalk/volume.h index e7f87724..ad8be2b8 100644 --- a/include/atalk/volume.h +++ b/include/atalk/volume.h @@ -98,10 +98,11 @@ struct vol { int v_preexec_close; char *v_uuid; /* For TimeMachine zeroconf record */ int v_qfd; + uint32_t v_ignattr; /* AFP attributes that shall be ignored */ }; /* load_volumes() flags */ -#define LV_ALL (1 << 0) +typedef enum {lv_none = 0, lv_all = 1} lv_flags_t; /* volume flags */ #define AFPVOL_OPEN (1<<0) @@ -112,12 +113,12 @@ struct vol { #define AFPVOL_USTATFS (1<<3) #define AFPVOL_UQUOTA (1<<4) -/* - Flags that alter volume behaviour. - Keep in sync with libatalk/util/volinfo.c -*/ #define AFPVOL_NOV2TOEACONV (1 << 5) /* no adouble:v2 to adouble:ea conversion */ +#define AFPVOL_SPOTLIGHT (1 << 6) /* Index volume for Spotlight searches */ #define AFPVOL_RO (1 << 8) /* read-only volume */ +#define AFPVOL_CHMOD_PRESERVE_ACL (1 << 9) /* try to preserve ACLs */ +#define AFPVOL_CHMOD_IGNORE (1 << 10) /* try to preserve ACLs */ +#define AFPVOL_FORCE_STICKY_XATTR (1 << 11) /* write metadata xattr as root on sticky dirs */ #define AFPVOL_NOSTAT (1 << 16) /* advertise the volume even if we can't stat() it * maybe because it will be mounted later in preexec */ #define AFPVOL_UNIX_PRIV (1 << 17) /* support unix privileges */ @@ -132,6 +133,8 @@ struct vol { #define AFPVOL_ACLS (1 << 24) /* Volume supports ACLS */ #define AFPVOL_SEARCHDB (1 << 25) /* Use fast CNID db search instead of filesystem */ #define AFPVOL_NONETIDS (1 << 26) /* signal the client it shall do privelege mapping */ +#define AFPVOL_FOLLOWSYM (1 << 27) /* follow symlinks on the server, default is not to */ +#define AFPVOL_DELVETO (1 << 28) /* delete veto files and dirs */ /* Extended Attributes vfs indirection */ #define AFPVOL_EA_NONE 0 /* No EAs */ @@ -190,6 +193,8 @@ struct vol { #define vol_nodev(vol) (((vol)->v_flags & AFPVOL_NODEV) ? 1 : 0) #define vol_unix_priv(vol) ((vol)->v_obj->afp_version >= 30 && ((vol)->v_flags & AFPVOL_UNIX_PRIV)) #define vol_inv_dots(vol) (((vol)->v_flags & AFPVOL_INV_DOTS) ? 1 : 0) - +#define vol_syml_opt(vol) (((vol)->v_flags & AFPVOL_FOLLOWSYM) ? 0 : O_NOFOLLOW) +#define vol_chmod_opt(vol) (((vol)->v_flags & AFPVOL_CHMOD_PRESERVE_ACL) ? O_NETATALK_ACL : \ + ((vol)->v_flags & AFPVOL_CHMOD_IGNORE) ? O_IGNORE : 0) #endif