Example #1
0
        private DataEntity(string partitionKey, string rowKey, IChasmBlob blob)
        {
            PartitionKey = partitionKey;
            RowKey       = rowKey;

            Content     = blob?.Content.ToArray(); // TODO: Perf
            Filename    = blob?.Metadata?.Filename;
            ContentType = blob?.Metadata?.ContentType;
        }
Example #2
0
 private DataEntity(string partitionKey, string rowKey, IChasmBlob blob, bool forceOverwrite)
     : this(partitionKey, rowKey, blob)
 {
     if (forceOverwrite)
     {
         // https://azure.microsoft.com/en-us/blog/managing-concurrency-in-microsoft-azure-storage-2/
         // "To explicitly disable the concurrency check, you should set the ETag property of the ... object to “*” before you execute the replace operation"
         ETag = "*";
     }
 }
Example #3
0
        public virtual async ValueTask <TreeNodeMap?> ReadTreeAsync(TreeId treeId, ChasmRequestContext requestContext = default, CancellationToken cancellationToken = default)
        {
            requestContext = ChasmRequestContext.Ensure(requestContext);

            // Read bytes
            IChasmBlob blob = await ReadObjectAsync(treeId.Sha1, requestContext, cancellationToken)
                              .ConfigureAwait(false);

            if (blob == null || blob.Content.IsEmpty)
            {
                return(default);
Example #4
0
        internal static DataEntity Create(Sha1 sha1, IChasmBlob blob, bool forceOverwrite)
        {
            if (blob == null)
            {
                throw new ArgumentNullException(nameof(blob));
            }

            KeyValuePair <string, string> split = GetPartition(sha1);

            var entity = new DataEntity(split.Key, split.Value, blob, forceOverwrite);

            return(entity);
        }
Example #5
0
        internal static TableOperation BuildWriteOperation(Sha1 sha1, IChasmBlob blob)
        {
            if (blob == null)
            {
                throw new ArgumentNullException(nameof(blob));
            }

            DataEntity entity = Create(sha1, blob);

            var op = TableOperation.InsertOrReplace(entity);

            return(op);
        }
Example #6
0
        internal static DataEntity Create(string name, string branch, IChasmBlob blob)
        {
            if (string.IsNullOrWhiteSpace(name))
            {
                throw new ArgumentNullException(nameof(name));
            }
            if (string.IsNullOrWhiteSpace(branch))
            {
                throw new ArgumentNullException(nameof(branch));
            }
            if (blob == null)
            {
                throw new ArgumentNullException(nameof(blob));
            }

            string partitionKey = GetPartitionKey(name);
            string rowKey       = GetRowKey(branch);

            var entity = new DataEntity(partitionKey, rowKey, blob);

            return(entity);
        }
Example #7
0
        private static async Task TestRepository(IChasmRepository repository)
        {
            var g  = Guid.NewGuid();
            var cx = new ChasmRequestContext {
                CorrelationId = Guid.NewGuid().ToString("D")
            };

            byte[] buffer = g.ToByteArray();
            Sha1   sha    = s_hasher.HashData(buffer);

            // Unknown SHA
            Sha1 usha1 = s_hasher.HashData(Guid.NewGuid().ToByteArray());
            Sha1 usha2 = s_hasher.HashData(Guid.NewGuid().ToByteArray());

            // Blob
            var  metadata = new ChasmMetadata("application/json", "file123.txt");
            Sha1 sha2     = await repository.WriteObjectAsync(new ReadOnlyMemory <byte>(buffer), metadata, false, cx, default);

            Assert.Equal(sha, sha2);
            IChasmBlob rdata = await repository.ReadObjectAsync(sha, default);

            Assert.True(rdata != null);
            Assert.Equal(16, rdata.Content.Length);
            Assert.Equal(g, new Guid(rdata.Content.ToArray()));
            Assert.Equal("application/json", rdata.Metadata.ContentType);
            Assert.Equal("file123.txt", rdata.Metadata.Filename);

            IChasmBlob urdata = await repository.ReadObjectAsync(usha1, default);

            Assert.False(urdata != null);

            //
            metadata = new ChasmMetadata("application/text", null);
            sha2     = await repository.WriteObjectAsync(buffer, metadata, true, cx, default);

            Assert.Equal(sha, sha2);

            IChasmBlob cnt2 = await repository.ReadObjectAsync(sha2, default);

            Assert.Equal(buffer, cnt2.Content.ToArray());
            Assert.Equal("application/text", cnt2.Metadata.ContentType);
            Assert.Null(cnt2.Metadata.Filename);

            using (IChasmStream stream2 = await repository.ReadStreamAsync(sha2, cx, default))
                using (var ms = new MemoryStream())
                {
                    stream2.Content.CopyTo(ms);
                    Assert.Equal(buffer, ms.ToArray());
                }

            using (Stream stream2 = new MemoryStream(buffer))
            {
                sha2 = await repository.WriteObjectAsync(stream2, null, true, cx, default);
            }
            Assert.Equal(sha, sha2);

            using (IChasmStream stream2 = await repository.ReadStreamAsync(sha2, cx, default))
                using (var ms = new MemoryStream())
                {
                    stream2.Content.CopyTo(ms);
                    Assert.Equal(buffer, ms.ToArray());
                }

            // Tree
            var tree = new TreeNodeMap(
                new TreeNode("firstItem", NodeKind.Blob, sha),
                new TreeNode("secondItem", NodeKind.Blob, sha)
                );
            TreeId treeId = await repository.WriteTreeAsync(tree, cx, default);

            TreeNodeMap?rtree = await repository.ReadTreeAsync(treeId, cx, default);

            Assert.True(rtree.HasValue);
            Assert.Equal(tree, rtree.Value);

            TreeNodeMap?urtree = await repository.ReadTreeAsync(new TreeId(usha1), cx, default);

            Assert.False(urtree.HasValue);
        }
Example #8
0
 private DataEntity(string partitionKey, string rowKey, IChasmBlob blob, string etag)
     : this(partitionKey, rowKey, blob)
 {
     // https://azure.microsoft.com/en-us/blog/managing-concurrency-in-microsoft-azure-storage-2/
     ETag = etag;
 }
Example #9
0
        internal static TableOperation BuildWriteOperation(string name, string branch, IChasmBlob blob)
        {
            if (string.IsNullOrWhiteSpace(name))
            {
                throw new ArgumentNullException(nameof(name));
            }
            if (string.IsNullOrWhiteSpace(branch))
            {
                throw new ArgumentNullException(nameof(branch));
            }
            if (blob == null)
            {
                throw new ArgumentNullException(nameof(blob));
            }

            DataEntity entity = Create(name, branch, blob);

            var op = TableOperation.InsertOrReplace(entity);

            return(op);
        }