7 """Parse Arvados timestamp to unix time."""
11 return calendar.timegm(ciso8601.parse_datetime_unaware(t).timetuple())
12 except (TypeError, ValueError):
15 def use_counter(orig_func):
16 @functools.wraps(orig_func)
17 def use_counter_wrapper(self, *args, **kwargs):
20 return orig_func(self, *args, **kwargs)
23 return use_counter_wrapper
25 def check_update(orig_func):
26 @functools.wraps(orig_func)
27 def check_update_wrapper(self, *args, **kwargs):
29 return orig_func(self, *args, **kwargs)
30 return check_update_wrapper
32 class FreshBase(object):
33 """Base class for maintaining object lifecycle.
37 * Indicate if an object is up to date (stale() == false) or needs to be
38 updated sets stale() == True). Use invalidate() to mark the object as
39 stale. An object is also automatically stale if it has not been updated
40 in `_poll_time` seconds.
42 * Record access time (atime) timestamp
44 * Manage internal use count used by the inode cache ("inc_use" and
45 "dec_use"). An object which is in use cannot be cleared by the inode
48 * Manage the kernel reference count ("inc_ref" and "dec_ref"). An object
49 which is referenced by the kernel cannot have its inode entry deleted.
51 * Record cache footprint, cache priority
53 * Record Arvados uuid at the time the object is placed in the cache
55 * Clear the object contents (invalidates the object)
61 self._last_update = time.time()
62 self._atime = time.time()
68 self.cache_uuid = None
69 self.allow_attr_cache = True
70 self.allow_dirent_cache = True
73 """Indicate that object contents should be refreshed from source."""
76 def kernel_invalidate(self):
77 """Indicate that an invalidation for this object should be sent to the kernel."""
80 # Test if the entries dict is stale.
85 return (self._last_update + self._poll_time) < self._atime
90 self._last_update = time.time()
102 return self.use_count > 0
112 return self.ref_count
114 def dec_ref(self, n):
116 return self.ref_count
118 def has_ref(self, only_children):
119 """Determine if there are any kernel references to this
120 object or its children.
122 If only_children is True, ignore refcount of self and only consider
128 return self.ref_count > 0