Richard Boegli's CnC_Generals_Zero_Hour Fork WIP
This is documentation of Richard Boegil's Zero Hour Fork
 
Loading...
Searching...
No Matches
blowpipe.h
Go to the documentation of this file.
1/*
2** Command & Conquer Generals Zero Hour(tm)
3** Copyright 2025 Electronic Arts Inc.
4**
5** This program is free software: you can redistribute it and/or modify
6** it under the terms of the GNU General Public License as published by
7** the Free Software Foundation, either version 3 of the License, or
8** (at your option) any later version.
9**
10** This program is distributed in the hope that it will be useful,
11** but WITHOUT ANY WARRANTY; without even the implied warranty of
12** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13** GNU General Public License for more details.
14**
15** You should have received a copy of the GNU General Public License
16** along with this program. If not, see <http://www.gnu.org/licenses/>.
17*/
18
19/***********************************************************************************************
20 *** C O N F I D E N T I A L --- W E S T W O O D S T U D I O S ***
21 ***********************************************************************************************
22 * *
23 * Project Name : Command & Conquer *
24 * *
25 * $Archive:: /Commando/Library/blowpipe.h $*
26 * *
27 * $Author:: Greg_h $*
28 * *
29 * $Modtime:: 7/22/97 11:37a $*
30 * *
31 * $Revision:: 1 $*
32 * *
33 *---------------------------------------------------------------------------------------------*
34 * Functions: *
35 * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
36
37#ifndef BLOWPIPE_H
38#define BLOWPIPE_H
39
40#include "pipe.h"
41#include "blowfish.h"
42
43/*
44** Performs Blowfish encryption/decryption on the data stream that is piped
45** through this class.
46*/
47class BlowPipe : public Pipe
48{
49 public:
54
55 BlowPipe(CryptControl control) : BF(NULL), Counter(0), Control(control) {}
56 virtual ~BlowPipe(void) {delete BF;BF = NULL;}
57 virtual int Flush(void);
58
59 virtual int Put(void const * source, int slen);
60
61 // Submit key for blowfish engine.
62 void Key(void const * key, int length);
63
64 protected:
65 /*
66 ** The Blowfish engine used for encryption/decryption. If this pointer is
67 ** NULL, then this indicates that the blowfish engine is not active and no
68 ** key has been submitted. All data would pass through this pipe unchanged
69 ** in that case.
70 */
72
73 private:
74 char Buffer[8];
75 int Counter;
76 CryptControl Control;
77
78 BlowPipe(BlowPipe & rvalue);
79 BlowPipe & operator = (BlowPipe const & pipe);
80};
81
82
83#endif
#define NULL
Definition BaseType.h:92
virtual int Put(void const *source, int slen)
Definition blowpipe.cpp:93
@ DECRYPT
Definition blowpipe.h:52
@ ENCRYPT
Definition blowpipe.h:51
void Key(void const *key, int length)
Definition blowpipe.cpp:184
virtual int Flush(void)
Definition blowpipe.cpp:62
BlowfishEngine * BF
Definition blowpipe.h:71
virtual ~BlowPipe(void)
Definition blowpipe.h:56
BlowPipe(CryptControl control)
Definition blowpipe.h:55