52 lines
1.9 KiB
C#
52 lines
1.9 KiB
C#
|
//------------------------------------------------------------------------------
|
||
|
// <copyright file="CryptographicKey.cs" company="Microsoft">
|
||
|
// Copyright (c) Microsoft Corporation. All rights reserved.
|
||
|
// </copyright>
|
||
|
//------------------------------------------------------------------------------
|
||
|
|
||
|
namespace System.Web.Security.Cryptography {
|
||
|
using System;
|
||
|
using System.Web.Util;
|
||
|
|
||
|
// Represents a key that can be used for a cryptographic operation.
|
||
|
|
||
|
internal sealed class CryptographicKey {
|
||
|
|
||
|
private readonly byte[] _keyMaterial;
|
||
|
|
||
|
public CryptographicKey(byte[] keyMaterial) {
|
||
|
_keyMaterial = keyMaterial;
|
||
|
}
|
||
|
|
||
|
// Returns the length of the key (in bits).
|
||
|
public int KeyLength {
|
||
|
get {
|
||
|
return checked(_keyMaterial.Length * 8);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Extracts the specified number of bits at the specified offset
|
||
|
// and returns a new CryptographicKey. This is not appropriate
|
||
|
// for subkey derivation, but it can be used if this cryptographic
|
||
|
// key is actually two keys (like encryption + validation)
|
||
|
// concatenated together. Inputs are specified as bit lengths.
|
||
|
public CryptographicKey ExtractBits(int offset, int count) {
|
||
|
Debug.Assert(offset % 8 == 0, "Offset must be divisible by 8.");
|
||
|
Debug.Assert(count % 8 == 0, "Count must be divisible by 8.");
|
||
|
|
||
|
int offsetBytes = offset / 8;
|
||
|
int countBytes = count / 8;
|
||
|
|
||
|
byte[] newKey = new byte[countBytes];
|
||
|
Buffer.BlockCopy(_keyMaterial, offsetBytes, newKey, 0, countBytes);
|
||
|
return new CryptographicKey(newKey);
|
||
|
}
|
||
|
|
||
|
// Returns the raw key material as a byte array.
|
||
|
public byte[] GetKeyMaterial() {
|
||
|
return _keyMaterial;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|