|
|
4a28de |
diff -up ./esc/src/app/esc.js.fix11 ./esc/src/app/esc.js
|
|
|
4a28de |
--- ./esc/src/app/esc.js.fix11 2022-06-15 19:12:43.974710780 -0400
|
|
|
4a28de |
+++ ./esc/src/app/esc.js 2022-06-15 19:12:54.657664269 -0400
|
|
|
4a28de |
@@ -581,7 +581,6 @@ class ESC {
|
|
|
4a28de |
this._configFile = new GLib.KeyFile();
|
|
|
4a28de |
|
|
|
4a28de |
this._configPath = GLib.get_user_config_dir() + "/esc";
|
|
|
4a28de |
-
|
|
|
4a28de |
let configDir = Gio.File.new_for_path(this._configPath);
|
|
|
4a28de |
|
|
|
4a28de |
try {
|
|
|
4a28de |
@@ -606,6 +605,9 @@ class ESC {
|
|
|
4a28de |
this._configFile.save_to_file(this._configFileName);
|
|
|
4a28de |
}
|
|
|
4a28de |
}
|
|
|
4a28de |
+ _initConfigTokenManuIDs() {
|
|
|
4a28de |
+ this._setConfigValue("esc.token.manu_id.0","Volkswagen AG");
|
|
|
4a28de |
+ }
|
|
|
4a28de |
|
|
|
4a28de |
_buildUI() {
|
|
|
4a28de |
// Create the application window
|
|
|
4a28de |
@@ -637,6 +639,7 @@ class ESC {
|
|
|
4a28de |
|
|
|
4a28de |
|
|
|
4a28de |
this._initConfig();
|
|
|
4a28de |
+ this._initConfigTokenManuIDs();
|
|
|
4a28de |
this._initProperties();
|
|
|
4a28de |
|
|
|
4a28de |
this._statusMessages = null;
|
|
|
4a28de |
diff -up ./esc/src/lib/coolkey/CoolKeyHandler.cpp.fix11 ./esc/src/lib/coolkey/CoolKeyHandler.cpp
|
|
|
4a28de |
--- ./esc/src/lib/coolkey/CoolKeyHandler.cpp.fix11 2022-06-15 19:10:26.278310248 -0400
|
|
|
4a28de |
+++ ./esc/src/lib/coolkey/CoolKeyHandler.cpp 2022-06-15 19:10:46.824220800 -0400
|
|
|
4a28de |
@@ -63,6 +63,7 @@ static const char *piv_manu_id_1= "piv_
|
|
|
4a28de |
static PRLogModuleInfo *coolKeyLogHN = PR_NewLogModule("coolKeyHandler");
|
|
|
4a28de |
|
|
|
4a28de |
void NotifyEndResult(CoolKeyHandler* context, int operation, int result, int description);
|
|
|
4a28de |
+bool isTokenTypeOtherKnownType(CK_TOKEN_INFO *tokenInfo);
|
|
|
4a28de |
|
|
|
4a28de |
struct AutoCKYBuffer : public CKYBuffer
|
|
|
4a28de |
{
|
|
|
4a28de |
@@ -2246,6 +2247,7 @@ CKHGetCoolKeyInfo(PK11SlotInfo *aSlot,Co
|
|
|
4a28de |
int isACOOLKey = 0;
|
|
|
4a28de |
int isACAC = 0;
|
|
|
4a28de |
int isAPIV = 0;
|
|
|
4a28de |
+ bool isOtherKey = false;
|
|
|
4a28de |
|
|
|
4a28de |
int hasApplet = 0;
|
|
|
4a28de |
int isPersonalized = 0;
|
|
|
4a28de |
@@ -2306,6 +2308,12 @@ CKHGetCoolKeyInfo(PK11SlotInfo *aSlot,Co
|
|
|
4a28de |
isAPIV = 1;
|
|
|
4a28de |
} else {
|
|
|
4a28de |
isACOOLKey = 1;
|
|
|
4a28de |
+ isOtherKey = isTokenTypeOtherKnownType(&tokenInfo);
|
|
|
4a28de |
+ if(isOtherKey == true && hasApplet == 0 && isPersonalized == 0) {
|
|
|
4a28de |
+ isACOOLKey = 0;
|
|
|
4a28de |
+ } else {
|
|
|
4a28de |
+ isOtherKey = false;
|
|
|
4a28de |
+ }
|
|
|
4a28de |
}
|
|
|
4a28de |
|
|
|
4a28de |
// OK, we have everything we need, now build the COOLKEYInfo structure.
|
|
|
4a28de |
@@ -2336,7 +2344,7 @@ CKHGetCoolKeyInfo(PK11SlotInfo *aSlot,Co
|
|
|
4a28de |
tokenInfo.firmwareVersion.major = 1;
|
|
|
4a28de |
}
|
|
|
4a28de |
|
|
|
4a28de |
- if(isPersonalized == 1 || isACAC == 1 || isAPIV == 1) {
|
|
|
4a28de |
+ if(isPersonalized == 1 || isACAC == 1 || isAPIV == 1 || isOtherKey == true) {
|
|
|
4a28de |
tokenInfo.flags |= CKF_TOKEN_INITIALIZED;
|
|
|
4a28de |
}
|
|
|
4a28de |
|
|
|
4a28de |
@@ -2407,3 +2415,33 @@ failed:
|
|
|
4a28de |
|
|
|
4a28de |
return NULL;
|
|
|
4a28de |
}
|
|
|
4a28de |
+
|
|
|
4a28de |
+bool isTokenTypeOtherKnownType(CK_TOKEN_INFO *tokenInfo)
|
|
|
4a28de |
+{
|
|
|
4a28de |
+ char tBuff[56];
|
|
|
4a28de |
+ bool res = false;
|
|
|
4a28de |
+
|
|
|
4a28de |
+ if(tokenInfo == NULL) {
|
|
|
4a28de |
+ return res;
|
|
|
4a28de |
+ }
|
|
|
4a28de |
+ string curManuCfg;
|
|
|
4a28de |
+ string num;
|
|
|
4a28de |
+ for(int i = 0;;i++) {
|
|
|
4a28de |
+ num = to_string(i);
|
|
|
4a28de |
+ curManuCfg = "esc.token.manu_id." + num;
|
|
|
4a28de |
+ const char *curManu = CoolKeyGetConfig(curManuCfg.c_str());
|
|
|
4a28de |
+
|
|
|
4a28de |
+ if(curManu == NULL) {
|
|
|
4a28de |
+ break;
|
|
|
4a28de |
+ }
|
|
|
4a28de |
+
|
|
|
4a28de |
+ int match = memcmp(tokenInfo->manufacturerID, curManu, strlen(curManu));
|
|
|
4a28de |
+ CoolKeyFreeConfig(curManu);
|
|
|
4a28de |
+ if(match == 0) {
|
|
|
4a28de |
+ res = true;
|
|
|
4a28de |
+ break;
|
|
|
4a28de |
+ }
|
|
|
4a28de |
+ }
|
|
|
4a28de |
+ PR_LOG( coolKeyLogHN, PR_LOG_DEBUG, ("%s CoolKeyHandler::isTokenTypeOtherKnownType: result: %d .\n",GetTStamp(tBuff,56), res));
|
|
|
4a28de |
+ return res;
|
|
|
4a28de |
+}
|