Menu

[r2035]: / trunk / Src / UEncryptor.pas  Maximize  Restore  History

Download this file

147 lines (125 with data), 3.9 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
{
* UEncryptor.pas
*
* Static class that encrypts and decrypts binary data. Acts as a facade to the
* actual encryption engine.
*
* All code that requires encryption should use this class rather than making
* calls the the actual the encryption engine.
*
* $Rev$
* $Date$
*
* ***** BEGIN LICENSE BLOCK *****
*
* Version: MPL 1.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
*
* The Original Code is UEncryptor.pas
*
* The Initial Developer of the Original Code is Peter Johnson
* (http://www.delphidabbler.com/).
*
* Portions created by the Initial Developer are Copyright (C) 2010 Peter
* Johnson. All Rights Reserved.
*
* Contributor(s)
* NONE
*
* ***** END LICENSE BLOCK *****
}
unit UEncryptor;
interface
uses
// Delphi
SysUtils,
// Project
UBaseObjects;
type
{
TEncryptor:
Static class that encrypts and decrypts binary data. Acts as a facade to the
actual encryption engine.
}
TEncryptor = class(TNoConstructObject)
strict private
const cEncryptKey = 46723; // Key used for encryption / decryption
class function BytesToRawString(const Bytes: TBytes): RawByteString;
{Copies the bytes from a byte array into a raw byte string.
@param Bytes [in] Bytes to be copied.
@return Raw byte string containing bytes.
}
class function RawStringToBytes(const Str: RawByteString): TBytes;
{Copies the bytes from a raw byte string into a byte array.
@param Str [in] Raw byte string to be copied.
@return Byte array containing bytes from string.
}
public
class function Encrypt(const Bytes: TBytes): TBytes;
{Encrypts data from a byte array.
@param Bytes [in] Array of bytes to be encrypted.
@return Byte array containing encrypted data.
}
class function Decrypt(const Bytes: TBytes): TBytes;
{Decrypts data from a byte array.
@param Bytes [in] Array of encrypted bytes to be decrypted.
@return Byte array containing decrypted data.
}
end;
implementation
uses
// 3rd party
UEncrypt;
{ TEncryptor }
class function TEncryptor.BytesToRawString(const Bytes: TBytes): RawByteString;
{Copies the bytes from a byte array into a raw byte string.
@param Bytes [in] Bytes to be copied.
@return Raw byte string containing bytes.
}
begin
SetLength(Result, Length(Bytes));
if Length(Bytes) > 0 then
Move(Bytes[0], Result[1], Length(Bytes));
end;
class function TEncryptor.Decrypt(const Bytes: TBytes): TBytes;
{Decrypts data from a byte array.
@param Bytes [in] Array of encrypted bytes to be decrypted.
@return Byte array containing decrypted data.
}
begin
Result := RawStringToBytes(
UEncrypt.Decrypt(
BytesToRawString(Bytes), cEncryptKey
)
);
end;
class function TEncryptor.Encrypt(const Bytes: TBytes): TBytes;
{Encrypts data from a byte array.
@param Bytes [in] Array of bytes to be encrypted.
@return Byte array containing encrypted data.
}
begin
Result := RawStringToBytes(
UEncrypt.Encrypt(
BytesToRawString(Bytes), cEncryptKey
)
);
end;
class function TEncryptor.RawStringToBytes(const Str: RawByteString): TBytes;
{Copies the bytes from a raw byte string into a byte array.
@param Str [in] Raw byte string to be copied.
@return Byte array containing bytes from string.
}
begin
SetLength(Result, Length(Str));
if Length(Str) > 0 then
Move(Str[1], Result[0], Length(Str));
end;
end.
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.