summaryrefslogtreecommitdiff
path: root/plugins/!NotAdopted/SmartAutoReplier/RulesStorage.h
blob: 25cbec29428895097e73f313257e270193c41479 (plain)
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
/*
 *  Smart Auto Replier (SAR) - auto replier plugin for Miranda IM
 *
 *  Copyright (C) 2004 - 2012 by Volodymyr M. Shcherbyna <volodymyr@shcherbyna.com>
 *
 *      This file is part of SAR.
 *
 *  SAR is free software: you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation, either version 3 of the License, or
 *  (at your option) any later version.
 *
 *  SAR is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with SAR.  If not, see <http://www.gnu.org/licenses/>.
*/

#pragma once

#include "RuleItem.h"
#include <map>

#define STORAGE_NAME	TEXT("sar.rsu")			/// a def. name of a file that is storing settings
typedef std::map<INT, RULE_ITEM> RulesHash;		/// storage representation in memory

/// storage manager..
class CRulesStorage : ISettings
{
public:	/// ctor'rs, dtors..
	CRulesStorage(void);
	~CRulesStorage(void);
public: /// ISettings interface...
	bool Serialize(ISettingsStream *pSettings, DWORD & ObjectSize);
	bool Deserialize(DWORD & ObjectSize);
public:
	void Init(void);	/// initing state of an object
	void DeInit(void);	/// deiniting state of an object
	DWORD AddRuleItem(RULE_ITEM item, bool & bExists); /// n.c.
	bool RemReplyAction(DWORD dwCrc32);				   /// n.c.
	RulesHash & getHashTable(void);					   /// n.c.		
	COMMON_RULE_ITEM & getCommonRule(void);			   /// n.c.
	void setCommonRule(COMMON_RULE_ITEM r);		   /// n.c.
	void Flush(void);											/// flushes all from memory to a file
	void FlushItem(RULE_ITEM & item);							/// flushes an item into file from memory
	bool IsRuleMatch(RULE_METAINFO & info, LPTSTR & strMess, LPTSTR & lpIncomingMsg);	/// n.c.
	void ClearCommonMessages(void);	/// releases memory that is commited for comm. rule
	bool RuleIsRegistered(LPTSTR lpContactName);
private:
	void  RawWriteDataBufByChunk(LPTSTR);			/// writes string to a file
	UINT  RawReadDataBufByChunk(LPTSTR & szData);	/// reads string from file
	UINT GetCommonMessages(void);	/// gets common rules from file to memory
	void SetCommonMessages(void);	/// sets common rules from memory to file	
private:
	COMMON_RULE_ITEM m_comItem;			/// common rule item..
	RulesHash m_hashTable;				/// main storage...
	HANDLE m_hFile;						/// handle to file  that is storing data
	TCHAR m_szSettFileName[MAX_PATH];	/// path to a file...
	CRITICAL_SECTION m_critSect;		/// needed for sync
};