GCC Code Coverage Report


Directory: cvmfs/
File: cvmfs/mountpoint.h
Date: 2026-03-15 02:35:27
Exec Total Coverage
Lines: 54 125 43.2%
Branches: 1 2 50.0%

Line Branch Exec Source
1 /**
2 * This file is part of the CernVM File System.
3 *
4 * Steers the booting of CernVM-FS repositories.
5 */
6
7 #ifndef CVMFS_MOUNTPOINT_H_
8 #define CVMFS_MOUNTPOINT_H_
9
10 #include <pthread.h>
11 #include <sys/statvfs.h>
12 #include <unistd.h>
13
14 #include <ctime>
15 #include <set>
16 #include <string>
17 #include <vector>
18
19 #include "cache.h"
20 #include "crypto/hash.h"
21 #include "duplex_testing.h"
22 #include "file_watcher.h"
23 #include "loader.h"
24 #include "magic_xattr.h"
25 #include "util/algorithm.h"
26 #include "util/pointer.h"
27
28 class AuthzAttachment;
29 class AuthzFetcher;
30 class AuthzSessionManager;
31 class BackoffThrottle;
32 class CacheManager;
33 namespace catalog {
34 class ClientCatalogManager;
35 class InodeAnnotation;
36 } // namespace catalog
37 struct ChunkTables;
38 namespace cvmfs {
39 class Fetcher;
40 class Uuid;
41 } // namespace cvmfs
42 namespace download {
43 class DownloadManager;
44 }
45 namespace glue {
46 class InodeTracker;
47 class DentryTracker;
48 class PageCacheTracker;
49 } // namespace glue
50 namespace lru {
51 class InodeCache;
52 class Md5PathCache;
53 class PathCache;
54 } // namespace lru
55 class NfsMaps;
56 class OptionsManager;
57 namespace perf {
58 class Counter;
59 class Statistics;
60 class TelemetryAggregator;
61 } // namespace perf
62 namespace signature {
63 class SignatureManager;
64 }
65 class SimpleChunkTables;
66 class Tracer;
67
68
69 /**
70 * Construction of FileSystem and MountPoint can go wrong. In this case, we'd
71 * like to know why. This is a base class for both FileSystem and MountPoint.
72 */
73 class BootFactory {
74 public:
75 4780 BootFactory() : boot_status_(loader::kFailUnknown) { }
76 142 bool IsValid() { return boot_status_ == loader::kFailOk; }
77 4080 loader::Failures boot_status() { return boot_status_; }
78 117 std::string boot_error() { return boot_error_; }
79
80 /**
81 * Used in the fuse module to artificially set boot errors that are specific
82 * to the fuse boot procedure.
83 */
84 void set_boot_status(loader::Failures code) { boot_status_ = code; }
85
86 protected:
87 loader::Failures boot_status_;
88 std::string boot_error_;
89 };
90
91
92 /**
93 * The FileSystem object initializes cvmfs' global state. It sets up sqlite and
94 * the cache directory and it can contain multiple mount points. It currently
95 * does so only for libcvmfs; the cvmfs fuse module has exactly one FileSystem
96 * object and one MountPoint object.
97 */
98 class FileSystem : SingleCopy, public BootFactory {
99 FRIEND_TEST(T_MountPoint, MkCacheParm);
100 FRIEND_TEST(T_MountPoint, CacheSettings);
101 FRIEND_TEST(T_MountPoint, CheckInstanceName);
102 FRIEND_TEST(T_MountPoint, CheckPosixCacheSettings);
103 FRIEND_TEST(T_Cvmfs, Basics);
104
105 public:
106 enum Type {
107 kFsFuse = 0,
108 kFsLibrary
109 };
110
111 struct FileSystemInfo {
112 1970 FileSystemInfo()
113 3940 : type(kFsFuse)
114 1970 , options_mgr(NULL)
115 1970 , wait_workspace(false)
116 1970 , foreground(false) { }
117 /**
118 * Name can is used to identify this particular instance of cvmfs in the
119 * cache (directory). Normally it is the fully qualified repository name.
120 * For libcvmfs and in other special mount conditions, it can be something
121 * else. Only file systems with different names can share a cache because
122 * the name is part of a lock file.
123 */
124 std::string name;
125
126 /**
127 * Used to fork & execve into different flavors of the binary, e.g. the
128 * quota manager.
129 */
130 std::string exe_path;
131
132 /**
133 * Fuse mount point or libcvmfs.
134 */
135 Type type;
136
137 /**
138 * All further configuration has to be present in the options manager.
139 */
140 OptionsManager *options_mgr;
141
142 /**
143 * Decides if FileSystem construction should block if the workspace is
144 * currently taken. This is used to coordinate fuse mounts where the next
145 * mount happens while the previous fuse module is not yet fully cleaned
146 * up.
147 */
148 bool wait_workspace;
149 /**
150 * The fuse module should not daemonize. That means the quota manager
151 * should not daemonize, too, but print debug messages to stdout.
152 */
153 bool foreground;
154 };
155
156 /**
157 * Keeps information about I/O errors, e.g. writing local files, permanent
158 * network errors, etc. It counts the number of errors and the timestamp
159 * of the latest errors for consumption by monitoring tools such as Nagios
160 */
161 class IoErrorInfo {
162 public:
163 IoErrorInfo();
164
165 void Reset();
166 void AddIoError();
167 void SetCounter(perf::Counter *c);
168 int64_t count();
169 time_t timestamp_last();
170
171 private:
172 perf::Counter *counter_;
173 time_t timestamp_last_;
174 };
175
176 /**
177 * No NFS maps.
178 */
179 static const unsigned kNfsNone = 0x00;
180 /**
181 * Normal NFS maps by leveldb
182 */
183 static const unsigned kNfsMaps = 0x01;
184 /**
185 * NFS maps maintained by sqlite so that they can reside on an NFS mount
186 */
187 static const unsigned kNfsMapsHa = 0x02;
188
189 static FileSystem *Create(const FileSystemInfo &fs_info);
190 ~FileSystem();
191
192 // Used to setup logging before the file system object is created
193 static void SetupLoggingStandalone(const OptionsManager &options_mgr,
194 const std::string &prefix);
195
196 2121 bool IsNfsSource() { return nfs_mode_ & kNfsMaps; }
197 47 bool IsHaNfsSource() { return nfs_mode_ & kNfsMapsHa; }
198 void ResetErrorCounters();
199 void TearDown2ReadOnly();
200 void RemapCatalogFd(int from, int to);
201
202 // Used in cvmfs' RestoreState to prevent change of cache manager type
203 // during reload
204 void ReplaceCacheManager(CacheManager *new_cache_mgr);
205
206 4732 CacheManager *cache_mgr() { return cache_mgr_; }
207 282 std::string cache_mgr_instance() { return cache_mgr_instance_; }
208 std::string exe_path() { return exe_path_; }
209 94 bool found_previous_crash() { return found_previous_crash_; }
210 Log2Histogram *hist_fs_lookup() { return hist_fs_lookup_; }
211 Log2Histogram *hist_fs_forget() { return hist_fs_forget_; }
212 Log2Histogram *hist_fs_forget_multi() { return hist_fs_forget_multi_; }
213 Log2Histogram *hist_fs_getattr() { return hist_fs_getattr_; }
214 Log2Histogram *hist_fs_readlink() { return hist_fs_readlink_; }
215 Log2Histogram *hist_fs_opendir() { return hist_fs_opendir_; }
216 Log2Histogram *hist_fs_releasedir() { return hist_fs_releasedir_; }
217 Log2Histogram *hist_fs_readdir() { return hist_fs_readdir_; }
218 Log2Histogram *hist_fs_open() { return hist_fs_open_; }
219 Log2Histogram *hist_fs_read() { return hist_fs_read_; }
220 Log2Histogram *hist_fs_release() { return hist_fs_release_; }
221
222 perf::Counter *n_fs_dir_open() { return n_fs_dir_open_; }
223 perf::Counter *n_fs_forget() { return n_fs_forget_; }
224 perf::Counter *n_fs_inode_replace() { return n_fs_inode_replace_; }
225 perf::Counter *n_fs_lookup() { return n_fs_lookup_; }
226 perf::Counter *n_fs_lookup_negative() { return n_fs_lookup_negative_; }
227 perf::Counter *n_fs_open() { return n_fs_open_; }
228 perf::Counter *n_fs_read() { return n_fs_read_; }
229 perf::Counter *n_fs_readlink() { return n_fs_readlink_; }
230 936 perf::Counter *n_fs_stat() { return n_fs_stat_; }
231 perf::Counter *n_fs_stat_stale() { return n_fs_stat_stale_; }
232 perf::Counter *n_fs_statfs() { return n_fs_statfs_; }
233 perf::Counter *n_fs_statfs_cached() { return n_fs_statfs_cached_; }
234 IoErrorInfo *io_error_info() { return &io_error_info_; }
235 1633 std::string name() { return name_; }
236 NfsMaps *nfs_maps() { return nfs_maps_; }
237 perf::Counter *no_open_dirs() { return no_open_dirs_; }
238 perf::Counter *no_open_files() { return no_open_files_; }
239 perf::Counter *n_eio_total() { return n_eio_total_; }
240 perf::Counter *n_eio_01() { return n_eio_01_; }
241 perf::Counter *n_eio_02() { return n_eio_02_; }
242 perf::Counter *n_eio_03() { return n_eio_03_; }
243 perf::Counter *n_eio_04() { return n_eio_04_; }
244 perf::Counter *n_eio_05() { return n_eio_05_; }
245 perf::Counter *n_eio_06() { return n_eio_06_; }
246 perf::Counter *n_eio_07() { return n_eio_07_; }
247 perf::Counter *n_eio_08() { return n_eio_08_; }
248 perf::Counter *n_emfile() { return n_emfile_; }
249 4362 OptionsManager *options_mgr() { return options_mgr_; }
250 1680 perf::Statistics *statistics() { return statistics_; }
251 3989 Type type() { return type_; }
252 1727 cvmfs::Uuid *uuid_cache() { return uuid_cache_; }
253 3132 std::string workspace() { return workspace_; }
254
255 protected:
256 void SetHasCustomVfs(bool setting) { has_custom_sqlitevfs_ = setting; }
257
258 private:
259 /**
260 * Only one instance may be alive at any given time
261 */
262 static bool g_alive;
263 static const char *kDefaultCacheBase; // /var/lib/cvmfs
264 static const unsigned kDefaultQuotaLimit = 1024 * 1024 * 1024; // 1GB
265 static const unsigned kDefaultNfiles = 8192; // if CVMFS_NFILES is unset
266 static const char *kDefaultCacheMgrInstance; // "default"
267
268 struct PosixCacheSettings {
269 2684 PosixCacheSettings()
270 2684 : is_shared(false)
271 2684 , is_alien(false)
272 2684 , is_managed(false)
273 2684 , avoid_rename(false)
274 2684 , cache_base_defined(false)
275 2684 , cache_dir_defined(false)
276 2684 , quota_limit(0)
277 2684 , do_refcount(true)
278 2684 , cleanup_unused_first(false) { }
279 bool is_shared;
280 bool is_alien;
281 bool is_managed;
282 bool avoid_rename;
283 bool cache_base_defined;
284 bool cache_dir_defined;
285 /**
286 * Soft limit in bytes for the cache. The quota manager removes half the
287 * cache when the limit is exceeded.
288 */
289 int64_t quota_limit;
290 bool do_refcount;
291 bool cleanup_unused_first;
292 std::string cache_path;
293 /**
294 * Different from cache_path only if CVMFS_WORKSPACE or
295 * CVMFS_CACHE_WORKSPACE is set.
296 */
297 std::string workspace;
298 };
299
300 static void LogSqliteError(void *user_data __attribute__((unused)),
301 int sqlite_extended_error,
302 const char *message);
303
304 explicit FileSystem(const FileSystemInfo &fs_info);
305
306 void SetupLogging();
307 void CreateStatistics();
308 void SetupSqlite();
309 bool DetermineNfsMode();
310 bool SetupWorkspace();
311 bool SetupCwd();
312 bool LockWorkspace();
313 bool SetupCrashGuard();
314 bool SetupNfsMaps();
315 void SetupUuid();
316
317 std::string MkCacheParm(const std::string &generic_parameter,
318 const std::string &instance);
319 bool CheckInstanceName(const std::string &instance);
320 bool TriageCacheMgr();
321 CacheManager *SetupCacheMgr(const std::string &instance);
322 CacheManager *SetupPosixCacheMgr(const std::string &instance);
323 CacheManager *SetupRamCacheMgr(const std::string &instance);
324 CacheManager *SetupTieredCacheMgr(const std::string &instance);
325 CacheManager *SetupExternalCacheMgr(const std::string &instance);
326 PosixCacheSettings DeterminePosixCacheSettings(const std::string &instance);
327 bool CheckPosixCacheSettings(const PosixCacheSettings &settings);
328 bool SetupPosixQuotaMgr(const PosixCacheSettings &settings,
329 CacheManager *cache_mgr);
330
331 // See FileSystemInfo for the following fields
332 std::string name_;
333 std::string exe_path_;
334 Type type_;
335 /**
336 * Not owned by the FileSystem object
337 */
338 OptionsManager *options_mgr_;
339 bool wait_workspace_;
340 bool foreground_;
341
342 perf::Counter *n_fs_open_;
343 perf::Counter *n_fs_dir_open_;
344 perf::Counter *n_fs_lookup_;
345 perf::Counter *n_fs_lookup_negative_;
346 perf::Counter *n_fs_stat_;
347 perf::Counter *n_fs_stat_stale_;
348 perf::Counter *n_fs_statfs_;
349 perf::Counter *n_fs_statfs_cached_;
350 perf::Counter *n_fs_read_;
351 perf::Counter *n_fs_readlink_;
352 perf::Counter *n_fs_forget_;
353 perf::Counter *n_fs_inode_replace_;
354 perf::Counter *no_open_files_;
355 perf::Counter *no_open_dirs_;
356 perf::Counter *n_eio_total_;
357 perf::Counter *n_eio_01_;
358 perf::Counter *n_eio_02_;
359 perf::Counter *n_eio_03_;
360 perf::Counter *n_eio_04_;
361 perf::Counter *n_eio_05_;
362 perf::Counter *n_eio_06_;
363 perf::Counter *n_eio_07_;
364 perf::Counter *n_eio_08_;
365 perf::Counter *n_emfile_;
366 IoErrorInfo io_error_info_;
367 perf::Statistics *statistics_;
368
369 Log2Histogram *hist_fs_lookup_;
370 Log2Histogram *hist_fs_forget_;
371 Log2Histogram *hist_fs_forget_multi_;
372 Log2Histogram *hist_fs_getattr_;
373 Log2Histogram *hist_fs_readlink_;
374 Log2Histogram *hist_fs_opendir_;
375 Log2Histogram *hist_fs_releasedir_;
376 Log2Histogram *hist_fs_readdir_;
377 Log2Histogram *hist_fs_open_;
378 Log2Histogram *hist_fs_read_;
379 Log2Histogram *hist_fs_release_;
380
381 /**
382 * A writeable local directory. Only small amounts of data (few bytes) will
383 * be stored here. Needed because the cache can be read-only. The workspace
384 * and the cache directory can be identical. A workspace can be shared among
385 * FileSystem instances if their name is different.
386 */
387 std::string workspace_;
388 /**
389 * During setup, the fuse module changes its working directory to workspace.
390 * Afterwards, workspace_ is ".". Store the original one in
391 * workspace_fullpath_
392 */
393 std::string workspace_fullpath_;
394 int fd_workspace_lock_;
395 std::string path_workspace_lock_;
396
397 /**
398 * An empty file that is removed on proper shutdown.
399 */
400 std::string path_crash_guard_;
401
402 /**
403 * A crash guard was found, thus we assume the file system was not shutdown
404 * properly last time.
405 */
406 bool found_previous_crash_;
407
408 /**
409 * Only needed for fuse to detect and prevent double mounting at the same
410 * location.
411 */
412 std::string mountpoint_;
413 /**
414 * The user-provided name of the parimay cache manager or 'default' if none
415 * is specified.
416 */
417 std::string cache_mgr_instance_;
418 /**
419 * Keep track of all the cache instances to detect circular definitions with
420 * the tiered cache.
421 */
422 std::set<std::string> constructed_instances_;
423 std::string nfs_maps_dir_;
424 /**
425 * Combination of kNfs... flags
426 */
427 unsigned nfs_mode_;
428 CacheManager *cache_mgr_;
429 /**
430 * Persistent for the cache directory + name combination. It is used in the
431 * Geo-API to allow for per-client responses when no proxy is used.
432 */
433 cvmfs::Uuid *uuid_cache_;
434
435 /**
436 * TODO(jblomer): Move to MountPoint. Tricky because of the sqlite maps
437 * and the sqlite configuration done for the file catalogs.
438 */
439 NfsMaps *nfs_maps_;
440 /**
441 * Used internally to remember if the Sqlite memory manager need to be shut
442 * down.
443 */
444 bool has_custom_sqlitevfs_;
445 };
446
447 /**
448 * The StatfsCache class is a class purely designed as "struct" (= holding
449 * object for all its parameters).
450 * All its logic, including the locking mechanism, is implemented in the
451 * function cvmfs_statfs in cvmfs.cc
452 */
453 class StatfsCache : SingleCopy {
454 public:
455 951 explicit StatfsCache(uint64_t cacheValid)
456 951 : expiry_deadline_(0), cache_timeout_(cacheValid) {
457 951 memset(&info_, 0, sizeof(info_));
458 951 lock_ = reinterpret_cast<pthread_mutex_t *>(
459 951 smalloc(sizeof(pthread_mutex_t)));
460 951 const int retval = pthread_mutex_init(lock_, NULL);
461
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 951 times.
951 assert(retval == 0);
462 951 }
463 951 ~StatfsCache() {
464 951 pthread_mutex_destroy(lock_);
465 951 free(lock_);
466 951 }
467 uint64_t *expiry_deadline() { return &expiry_deadline_; }
468 const uint64_t cache_timeout() { return cache_timeout_; }
469 struct statvfs *info() { return &info_; }
470 pthread_mutex_t *lock() { return lock_; }
471
472 private:
473 pthread_mutex_t *lock_;
474 // Timestamp/deadline when the currently cached statvfs info_ becomes invalid
475 uint64_t expiry_deadline_;
476 // Time in seconds how long statvfs info_ should be cached
477 uint64_t cache_timeout_;
478 struct statvfs info_;
479 };
480
481 /**
482 * A MountPoint provides a clip around all the different *Manager objects that
483 * in combination represent a mounted cvmfs repository. Its main purpose is
484 * the controlled construction and deconstruction of the involved ensemble of
485 * classes based on the information passed from an options manager.
486 *
487 * A MountPoint is constructed on top of a successfully constructed FileSystem.
488 *
489 * We use pointers to manager classes to make the order of construction and
490 * destruction explicit and also to keep the include list for this header small.
491 */
492 class MountPoint : SingleCopy, public BootFactory {
493 public:
494 /**
495 * If catalog reload fails, try again in 3 minutes
496 */
497 static const unsigned kShortTermTTL = 180;
498 static const time_t kIndefiniteDeadline = time_t(-1);
499
500 static MountPoint *Create(const std::string &fqrn,
501 FileSystem *file_system,
502 OptionsManager *options_mgr = NULL);
503 ~MountPoint();
504
505 unsigned GetMaxTtlMn();
506 unsigned GetEffectiveTtlSec();
507 void SetMaxTtlMn(unsigned value_minutes);
508 void SetMaxTtlSec(unsigned value_secs);
509 void ReEvaluateAuthz();
510
511 AuthzSessionManager *authz_session_mgr() { return authz_session_mgr_; }
512 BackoffThrottle *backoff_throttle() { return backoff_throttle_; }
513 1790 catalog::ClientCatalogManager *catalog_mgr() { return catalog_mgr_; }
514 ChunkTables *chunk_tables() { return chunk_tables_; }
515 211 download::DownloadManager *download_mgr() { return download_mgr_; }
516 188 download::DownloadManager *external_download_mgr() {
517 188 return external_download_mgr_;
518 }
519 file_watcher::FileWatcher *resolv_conf_watcher() {
520 return resolv_conf_watcher_;
521 }
522 1358 cvmfs::Fetcher *fetcher() { return fetcher_; }
523 bool fixed_catalog() { return fixed_catalog_; }
524 1434 std::string fqrn() const { return fqrn_; }
525 // TODO(jblomer): use only a singler fetcher object
526 cvmfs::Fetcher *external_fetcher() { return external_fetcher_; }
527 AuthzFetcher *authz_fetcher() { return authz_fetcher_; };
528 1358 FileSystem *file_system() { return file_system_; }
529 MagicXattrManager *magic_xattr_mgr() { return magic_xattr_mgr_; }
530 38 bool has_membership_req() { return has_membership_req_; }
531 bool enforce_acls() { return enforce_acls_; }
532 bool cache_symlinks() { return cache_symlinks_; }
533 bool fuse_expire_entry() { return fuse_expire_entry_; }
534 catalog::InodeAnnotation *inode_annotation() { return inode_annotation_; }
535 glue::InodeTracker *inode_tracker() { return inode_tracker_; }
536 lru::InodeCache *inode_cache() { return inode_cache_; }
537 double kcache_timeout_sec() { return kcache_timeout_sec_; }
538 1794 lru::Md5PathCache *md5path_cache() { return md5path_cache_; }
539 std::string membership_req() { return membership_req_; }
540 glue::DentryTracker *dentry_tracker() { return dentry_tracker_; }
541 glue::PageCacheTracker *page_cache_tracker() { return page_cache_tracker_; }
542 lru::PathCache *path_cache() { return path_cache_; }
543 std::string repository_tag() { return repository_tag_; }
544 SimpleChunkTables *simple_chunk_tables() { return simple_chunk_tables_; }
545 4074 perf::Statistics *statistics() { return statistics_; }
546 perf::TelemetryAggregator *telemetry_aggr() { return telemetry_aggr_; }
547 1358 signature::SignatureManager *signature_mgr() { return signature_mgr_; }
548 uid_t talk_socket_uid() { return talk_socket_uid_; }
549 gid_t talk_socket_gid() { return talk_socket_gid_; }
550 std::string talk_socket_path() { return talk_socket_path_; }
551 Tracer *tracer() { return tracer_; }
552 cvmfs::Uuid *uuid() { return uuid_; }
553 StatfsCache *statfs_cache() { return statfs_cache_; }
554
555 bool ReloadBlacklists();
556 void DisableCacheSymlinks();
557 void EnableFuseExpireEntry();
558
559 MountPoint(const std::string &fqrn,
560 FileSystem *file_system,
561 OptionsManager *options_mgr);
562
563 private:
564 /**
565 * The maximum TTL can be used to cap a root catalogs registered ttl. By
566 * default this is disabled (= 0).
567 */
568 static const unsigned kDefaultMaxTtlSec = 0;
569 /**
570 * Let fuse cache dentries for 1 minute.
571 */
572 static const unsigned kDefaultKCacheTtlSec = 60;
573 /**
574 * Number of Md5Path entries in the libcvmfs cache.
575 */
576 static const unsigned kLibPathCacheSize = 32000;
577 /**
578 * Cache seven times more md5 paths than inodes in the fuse module.
579 */
580 static const unsigned kInodeCacheFactor = 7;
581 /**
582 * Default to 16M RAM for meta-data caches; does not include the inode tracker
583 */
584 static const unsigned kDefaultMemcacheSize = 16 * 1024 * 1024;
585 /**
586 * Where to look for external authz helpers.
587 */
588 static const char *kDefaultAuthzSearchPath; // "/usr/libexec/cvmfs/authz"
589 /**
590 * Maximum number of concurrent HTTP connections.
591 */
592 static const unsigned kDefaultNumConnections = 16;
593 /**
594 * Default network timeout
595 */
596 static const unsigned kDefaultTimeoutSec = 5;
597 static const unsigned kDefaultRetries = 1;
598 static const unsigned kDefaultBackoffInitMs = 2000;
599 static const unsigned kDefaultBackoffMaxMs = 10000;
600 /**
601 * Memory buffer sizes for an activated tracer
602 */
603 static const unsigned kTracerBufferSize = 8192;
604 static const unsigned kTracerFlushThreshold = 7000;
605 static const char *kDefaultBlacklist; // "/etc/cvmfs/blacklist"
606 /**
607 * Default values for telemetry aggregator
608 */
609 static const int kDefaultTelemetrySendRateSec = 5 * 60; // 5min
610 static const int kMinimumTelemetrySendRateSec = 5; // 5sec
611
612
613 void CreateStatistics();
614 void CreateAuthz();
615 bool CreateSignatureManager();
616 bool CheckBlacklists();
617 bool CreateDownloadManagers();
618 bool CreateResolvConfWatcher();
619 void CreateFetchers();
620 bool CreateCatalogManager();
621 void CreateTables();
622 bool CreateTracer();
623 bool SetupBehavior();
624 void SetupDnsTuning(download::DownloadManager *manager);
625 void SetupHttpTuning();
626 bool SetupExternalDownloadMgr(bool dogeosort);
627 void SetupInodeAnnotation();
628 bool SetupOwnerMaps();
629 bool DetermineRootHash(shash::Any *root_hash);
630 bool FetchHistory(std::string *history_path);
631 std::string ReplaceHosts(std::string hosts);
632 std::string GetUniqFileSuffix();
633
634 std::string fqrn_;
635 cvmfs::Uuid *uuid_;
636 /**
637 * In contrast to the manager objects, the FileSystem is not owned.
638 */
639 FileSystem *file_system_;
640 /**
641 * The options manager is not owned.
642 */
643 OptionsManager *options_mgr_;
644
645 perf::Statistics *statistics_;
646 perf::TelemetryAggregator *telemetry_aggr_;
647 AuthzFetcher *authz_fetcher_;
648 AuthzSessionManager *authz_session_mgr_;
649 AuthzAttachment *authz_attachment_;
650 BackoffThrottle *backoff_throttle_;
651 signature::SignatureManager *signature_mgr_;
652 download::DownloadManager *download_mgr_;
653 download::DownloadManager *external_download_mgr_;
654 cvmfs::Fetcher *fetcher_;
655 cvmfs::Fetcher *external_fetcher_;
656 catalog::InodeAnnotation *inode_annotation_;
657 catalog::ClientCatalogManager *catalog_mgr_;
658 ChunkTables *chunk_tables_;
659 SimpleChunkTables *simple_chunk_tables_;
660 lru::InodeCache *inode_cache_;
661 lru::PathCache *path_cache_;
662 lru::Md5PathCache *md5path_cache_;
663 Tracer *tracer_;
664 glue::InodeTracker *inode_tracker_;
665 glue::DentryTracker *dentry_tracker_;
666 glue::PageCacheTracker *page_cache_tracker_;
667 MagicXattrManager *magic_xattr_mgr_;
668 StatfsCache *statfs_cache_;
669
670 file_watcher::FileWatcher *resolv_conf_watcher_;
671
672 unsigned max_ttl_sec_;
673 pthread_mutex_t lock_max_ttl_;
674 double kcache_timeout_sec_;
675 bool fixed_catalog_;
676 bool enforce_acls_;
677 bool cache_symlinks_;
678 bool fuse_expire_entry_;
679 std::string repository_tag_;
680 std::vector<std::string> blacklist_paths_;
681
682 // TODO(jblomer): this should go in the catalog manager
683 std::string membership_req_;
684 bool has_membership_req_;
685
686 std::string talk_socket_path_;
687 uid_t talk_socket_uid_;
688 gid_t talk_socket_gid_;
689 }; // class MointPoint
690
691 #endif // CVMFS_MOUNTPOINT_H_
692
693