Statistics
| Branch: | Revision:

root / trunk / Pithos.Core / Agents / BlockExtensions.cs @ 922c6aff

History | View | Annotate | Download (4.8 kB)

1
#region
2
/* -----------------------------------------------------------------------
3
 * <copyright file="BlockExtensions.cs" company="GRNet">
4
 * 
5
 * Copyright 2011-2012 GRNET S.A. All rights reserved.
6
 *
7
 * Redistribution and use in source and binary forms, with or
8
 * without modification, are permitted provided that the following
9
 * conditions are met:
10
 *
11
 *   1. Redistributions of source code must retain the above
12
 *      copyright notice, this list of conditions and the following
13
 *      disclaimer.
14
 *
15
 *   2. Redistributions in binary form must reproduce the above
16
 *      copyright notice, this list of conditions and the following
17
 *      disclaimer in the documentation and/or other materials
18
 *      provided with the distribution.
19
 *
20
 *
21
 * THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
22
 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
23
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
24
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
25
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
28
 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
29
 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32
 * POSSIBILITY OF SUCH DAMAGE.
33
 *
34
 * The views and conclusions contained in the software and
35
 * documentation are those of the authors and should not be
36
 * interpreted as representing official policies, either expressed
37
 * or implied, of GRNET S.A.
38
 * </copyright>
39
 * -----------------------------------------------------------------------
40
 */
41
#endregion
42
using System;
43
using System.Collections.Generic;
44
using System.Diagnostics.Contracts;
45
using System.Linq;
46
using System.Security.Cryptography;
47
using System.Text;
48
using System.IO;
49
using System.Text.RegularExpressions;
50
using System.Threading.Tasks;
51
using Pithos.Network;
52

    
53
namespace Pithos.Core.Agents
54
{
55
    static class BlockExtensions
56
    {
57
        
58

    
59
        public static int Read(this FileInfo fileInfo,byte[] buffer,long offset,int count)
60
        {
61
            if (offset <= 0)
62
                throw new ArgumentOutOfRangeException("offset", offset, "The file offset can't be negative");
63
            Contract.EndContractBlock();
64
            //Open the stream only long enough to read a block
65
            using (var stream = fileInfo.OpenRead())
66
            {
67
                stream.Seek(offset, SeekOrigin.Begin);
68
                return  stream.Read(buffer, 0, count);                
69
            }
70
        }
71

    
72
       public static string CalculateHash(this FileSystemInfo info,int blockSize,string algorithm)
73
        {
74
            if (info==null)
75
                throw new ArgumentNullException("info");
76
            if (String.IsNullOrWhiteSpace(info.FullName))
77
                throw new ArgumentException("info");
78
            if (blockSize<=0)
79
                throw new ArgumentOutOfRangeException("blockSize",blockSize,"blockSize must be greater than 0");
80
            if (String.IsNullOrWhiteSpace(algorithm))
81
                throw new ArgumentNullException("algorithm");
82
            Contract.EndContractBlock();
83

    
84
           //The hash for directories is an empty string
85
           if (info is DirectoryInfo)
86
                return String.Empty;
87
           //The hash for non-existent files is an empty string
88
           if (!info.Exists)
89
               return String.Empty;
90

    
91
           return Signature.CalculateTreeHash(info.FullName, blockSize, algorithm).TopHash.ToHashString();
92

    
93
        }
94

    
95
       /// <summary>
96
       ///Calculates a simple hash for an entire file
97
       /// </summary>
98
       /// <param name="info">The file to hash</param>
99
       /// <param name="hasher">The hash algorithm to use</param>
100
       /// <returns>A hash value for the entire file. An empty string if the file does not exist.</returns>
101
       public static string ComputeShortHash(this FileInfo info, HashAlgorithm hasher)
102
       {
103
           Contract.Requires(info != null);
104
           Contract.Requires(hasher!= null);           
105

    
106
           if (!info.Exists)
107
               return String.Empty;
108

    
109
           using (var stream = info.Open(FileMode.Open, FileAccess.Read, FileShare.Read))
110
           {
111
               var hash = hasher.ComputeHash(stream);
112
               var hashString = hash.ToHashString();
113
               return hashString;
114
           }
115
       }
116

    
117
        public static string ComputeShortHash(this FileInfo info)
118
       {
119
           Contract.Requires(info != null);           
120

    
121
           using (var hasher=HashAlgorithm.Create("sha1"))
122
           {               
123
               return ComputeShortHash(info,hasher);
124
           }
125
       }
126

    
127
    }
128
}