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
|
// --- BEGIN COPYRIGHT BLOCK ---
// This program 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; version 2 of the License.
//
// This program 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 this program; if not, write to the Free Software Foundation, Inc.,
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
//
// (C) 2013 Red Hat, Inc.
// All rights reserved.
// --- END COPYRIGHT BLOCK ---
package org.dogtagpki.server.tps.dbs;
import java.util.Calendar;
import java.util.Date;
import java.util.Map;
import org.dogtagpki.tps.main.Util;
import com.netscape.certsrv.base.EBaseException;
import com.netscape.certsrv.dbs.IDBSubsystem;
import com.netscape.cmscore.dbs.LDAPDatabase;
import com.netscape.cmsutil.ldap.LDAPUtil;
/**
* This class implements in-memory activity database. In the future this
* will be replaced with LDAP database.
*
* @author Endi S. Dewata
*/
public class ActivityDatabase extends LDAPDatabase<ActivityRecord> {
public final static String OP_DO_TOKEN = "do_token";
public final static String OP_ADD = "add"; // add a token
public final static String OP_DELETE = "delete"; // delete a token
//public final static String OP_MODIFY_AUDIT_SIGNING = "modify_audit_signing";
public final static String OP_ENROLLMENT = "enrollment";
public final static String OP_RECOVERY = "recovery";
public final static String OP_RENEWAL = "renewal";
public final static String OP_PIN_RESET = "pin_reset";
public final static String OP_FORMAT = "format";
public ActivityDatabase(IDBSubsystem dbSubsystem, String baseDN) throws EBaseException {
super("Activity", dbSubsystem, baseDN, ActivityRecord.class);
}
public ActivityRecord log(
String ip, String tokenID, String operation, String result,
String message, String userID, String tokenType) throws Exception {
Calendar c = Calendar.getInstance();
String timeString = Util.getTimeStampString(true);
long threadID = Thread.currentThread().getId();
String threadIDS = String.format("%x", threadID);
String id = timeString + "." + threadIDS;
ActivityRecord activityRecord = new ActivityRecord();
activityRecord.setId(id);
activityRecord.setIP(ip);
activityRecord.setTokenID(tokenID);
activityRecord.setOperation(operation);
activityRecord.setResult(result);
activityRecord.setMessage(message);
activityRecord.setUserID(userID);
activityRecord.setType(tokenType);
activityRecord.setDate(c.getTime());
super.addRecord(id, activityRecord);
return activityRecord;
}
@Override
public void addRecord(String id, ActivityRecord activityRecord) throws Exception {
activityRecord.setDate(new Date());
super.addRecord(id, activityRecord);
}
@Override
public String createDN(String id) {
return "cn=" + id + "," + baseDN;
}
@Override
public String createFilter(String keyword, Map<String, String> attributes) {
StringBuilder sb = new StringBuilder();
if (keyword != null) {
keyword = LDAPUtil.escapeFilter(keyword);
sb.append("(|(tokenID=*" + keyword + "*)(userID=*" + keyword + "*))");
}
createFilter(sb, attributes);
if (sb.length() == 0) {
sb.append("(id=*)");
}
return sb.toString();
}
}
|