diff options
author | vnugent <public@vaughnnugent.com> | 2023-03-06 01:53:33 -0500 |
---|---|---|
committer | vnugent <public@vaughnnugent.com> | 2023-03-06 01:53:33 -0500 |
commit | fd7c37ac02ea56b4f791dd175c1d315b4c682c91 (patch) | |
tree | a0a180630c4c9367726c681bdf0473b24a600a97 /lib/VNLib.Data.Caching/src/IObjectData.cs | |
parent | 7e62ab2caab7c071d0e40df08dc053cc33c6e019 (diff) |
FBM and caching non-breaking updates
Diffstat (limited to 'lib/VNLib.Data.Caching/src/IObjectData.cs')
-rw-r--r-- | lib/VNLib.Data.Caching/src/IObjectData.cs | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/lib/VNLib.Data.Caching/src/IObjectData.cs b/lib/VNLib.Data.Caching/src/IObjectData.cs new file mode 100644 index 0000000..e18de39 --- /dev/null +++ b/lib/VNLib.Data.Caching/src/IObjectData.cs @@ -0,0 +1,46 @@ +/* +* Copyright (c) 2023 Vaughn Nugent +* +* Library: VNLib +* Package: VNLib.Data.Caching +* File: IObjectData.cs +* +* IObjectData.cs is part of VNLib.Data.Caching which is part of the larger +* VNLib collection of libraries and utilities. +* +* VNLib.Data.Caching is free software: you can redistribute it and/or modify +* it under the terms of the GNU Affero General Public License as +* published by the Free Software Foundation, either version 3 of the +* License, or (at your option) any later version. +* +* VNLib.Data.Caching is distributed in the hope that it will be useful, +* but WITHOUT ANY WARRANTY; without even the implied warranty of +* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +* GNU Affero General Public License for more details. +* +* You should have received a copy of the GNU Affero General Public License +* along with this program. If not, see https://www.gnu.org/licenses/. +*/ + +using System; + +namespace VNLib.Data.Caching +{ + /// <summary> + /// Represents object data to send or receive from a cache server + /// </summary> + public interface IObjectData + { + /// <summary> + /// Gets the cachable objects data to store in the remote cache server + /// </summary> + /// <returns>The object data to set</returns> + ReadOnlySpan<byte> GetData(); + + /// <summary> + /// Stores the retrieved object data from the remote server + /// </summary> + /// <param name="data">The object data found on the remote server</param> + void SetData(ReadOnlySpan<byte> data); + } +} |