DECL_FUNC_PTR(profile_add_relation);\r
DECL_FUNC_PTR(profile_update_relation);\r
DECL_FUNC_PTR(profile_release_string);\r
+DECL_FUNC_PTR(profile_rename_section);\r
\r
// Service functions\r
DECL_FUNC_PTR(OpenSCManagerA);\r
MAKE_FUNC_INFO(profile_add_relation),\r
MAKE_FUNC_INFO(profile_update_relation),\r
MAKE_FUNC_INFO(profile_release_string),\r
+ MAKE_FUNC_INFO(profile_rename_section),\r
END_FUNC_INFO\r
};\r
\r
extern DECL_FUNC_PTR(profile_add_relation);\r
extern DECL_FUNC_PTR(profile_update_relation);\r
extern DECL_FUNC_PTR(profile_release_string);\r
+extern DECL_FUNC_PTR(profile_rename_section);\r
\r
// Service functions\r
extern DECL_FUNC_PTR(OpenSCManagerA);\r
assert(pprofile_add_relation);
assert(pprofile_update_relation);
assert(pprofile_flush);
+ assert(pprofile_rename_section);
#endif
if (!pprofile_init ||
!pprofile_clear_relation ||
!pprofile_add_relation ||
!pprofile_update_relation ||
- !pprofile_flush)
+ !pprofile_flush ||
+ !pprofile_rename_section)
return FALSE;
d->flags = 0;
}
-void
+int
k5_write_config_data(k5_config_data * d) {
char astr[MAX_PATH * 2];
char config_file[MAX_PATH];
const char *filenames[2];
long rv;
khm_size s;
+ int applied = FALSE;
if (d->flags == 0)
- return;
+ return FALSE;
if (!k5_is_profile_loaded())
- return;
+ return FALSE;
/* write the MSLSA import setting */
if (d->flags & K5_CDFLAG_MOD_LSA_IMPORT) {
khc_write_int32(csp_params, L"MsLsaImport", d->lsa_import);
d->flags &= ~K5_CDFLAG_MOD_LSA_IMPORT;
+ applied = TRUE;
}
if (d->flags & K5_CDFLAG_MOD_INC_REALMS) {
khc_write_int32(csp_params, L"UseFullRealmList", d->inc_realms);
d->flags &= ~K5_CDFLAG_MOD_INC_REALMS;
+ applied = TRUE;
}
if (!(d->flags &
K5_CDFLAG_MOD_REALMS))) {
d->flags = 0;
- return;
+ return applied;
}
khm_krb5_get_profile_file(config_file, ARRAYLENGTH(config_file));
rv = pprofile_add_relation(profile, sec_libdefaults,
defrealm);
+ applied = TRUE;
}
d->flags &= ~K5_CDFLAG_MOD_DEF_REALM;
}
KRB5_CONF_YES:
KRB5_CONF_NO);
d->flags &= ~K5_CDFLAG_MOD_DNS_LOOKUP_KDC;
+ applied = TRUE;
}
if (d->flags & K5_CDFLAG_MOD_DNS_LOOKUP_RLM) {
KRB5_CONF_NO);
d->flags &= ~K5_CDFLAG_MOD_DNS_LOOKUP_RLM;
+ applied = TRUE;
}
if (d->flags & K5_CDFLAG_MOD_DNS_FALLBACK) {
KRB5_CONF_NO);
d->flags &= ~K5_CDFLAG_MOD_DNS_FALLBACK;
+ applied = TRUE;
}
if (d->flags & K5_CDFLAG_MOD_NOADDRESSES) {
KRB5_CONF_NO);
d->flags &= ~K5_CDFLAG_MOD_NOADDRESSES;
+ applied = TRUE;
}
/* now we look at the [realms] section */
pprofile_add_relation(profile, sec_admin,
host);
- d->realms[r].kdcs[k].flags &= ~K5_RKFLAG_NEW;
+ d->realms[r].kdcs[k].flags &= ~ (K5_RKFLAG_NEW |
+ K5_RKFLAG_MOD_MASTER |
+ K5_RKFLAG_MOD_ADMIN);
+ applied = TRUE;
}
}
is deleted and not in the profile file
anymore. */
d->realms[r].domain_maps[m].flags |= K5_DMFLAG_NEW;
+ applied = TRUE;
} else if (!(d->realms[r].domain_maps[m].flags &
K5_DMFLAG_DELETED) &&
(d->realms[r].domain_maps[m].flags &
realm);
d->realms[r].domain_maps[m].flags &= ~K5_DMFLAG_NEW;
+ applied = TRUE;
}
}
- d->realms[r].flags &= ~K5_RDFLAG_NEW;
+ d->realms[r].flags &= ~(K5_RDFLAG_NEW |
+ K5_RDFLAG_MODIFED);
} else if ((d->realms[r].flags & K5_RDFLAG_DELETED) &&
!(d->realms[r].flags & K5_RDFLAG_NEW)) {
sec_all[2] = values[v];
pprofile_clear_relation(profile, sec_all);
}
+ sec_all[2] = NULL;
+ pprofile_rename_section(profile, sec_all, NULL);
pprofile_free_list(values);
+ applied = TRUE;
}
rv = pprofile_get_relation_names(profile, sec_domain_realm,
values[v]);
pprofile_clear_relation(profile,
sec_domain_map);
+ applied = TRUE;
}
pprofile_release_string(maprealm);
}
deleted and is not in the profile file. */
d->realms[r].flags |= K5_RDFLAG_NEW;
- } else if (!(d->realms[r].flags & K5_RDFLAG_DELETED)) {
+ } else if (!(d->realms[r].flags & K5_RDFLAG_DELETED) &&
+ (d->realms[r].flags & K5_RDFLAG_MODIFED)) {
khm_size k;
khm_size m;
pprofile_update_relation(profile, sec_master,
host, NULL);
+ applied = TRUE;
+
/* as above, setting 'new' flag to indicate
that the item does not exist in the profile
file. */
pprofile_add_relation(profile, sec_admin,
host);
- d->realms[r].kdcs[k].flags &= ~K5_RKFLAG_NEW;
+ d->realms[r].kdcs[k].flags &= ~(K5_RKFLAG_NEW |
+ K5_RKFLAG_MOD_ADMIN |
+ K5_RKFLAG_MOD_MASTER);
+ applied = TRUE;
continue;
}
host);
}
+ applied = TRUE;
d->realms[r].kdcs[k].flags &= ~K5_RKFLAG_MOD_MASTER;
}
host, NULL);
}
+ applied = TRUE;
d->realms[r].kdcs[k].flags &= ~K5_RKFLAG_MOD_ADMIN;
}
}
pprofile_clear_relation(profile, sec_domain_map);
d->realms[r].domain_maps[m].flags |= K5_DMFLAG_NEW;
+ applied = TRUE;
} else if (!(d->realms[r].domain_maps[m].flags &
K5_DMFLAG_DELETED) &&
pprofile_add_relation(profile, sec_domain_map,
realm);
d->realms[r].domain_maps[m].flags &= ~K5_DMFLAG_NEW;
+ applied = TRUE;
+
}
}
}
d->flags = 0;
+
+ return applied;
}
/* actual dialog stuff */
if (HIWORD(wParam) == WMCFG_APPLY) {
khm_int32 oflags;
+ int applied;
oflags = d->flags;
- k5_write_config_data(d);
+ applied = k5_write_config_data(d);
if (d->flags != oflags) {
khui_cfg_set_flags(d->node_main,
- KHUI_CNFLAG_APPLIED,
+ (applied ? KHUI_CNFLAG_APPLIED : 0),
KHUI_CNFLAG_APPLIED |
KHUI_CNFLAG_MODIFIED);
}
case KHUI_WM_CFG_NOTIFY:
/* the realms dialog receives this notification after the top
- level krb5 configuration panel has received it. Therefore,
- we assume that any changes have already been applied. When
- applying changes, we switch the mod bits off to indicate
- that the changes have been written. We just have to
- repaint the screen at this point. */
+ level krb5 configuration panel has received it. */
if (HIWORD(wParam) == WMCFG_APPLY) {
+ int applied;
+
+ applied = k5_write_config_data(d);
k5_purge_config_data(d, TRUE, TRUE, TRUE);
k5_update_realms_display(GetDlgItem(hwnd, IDC_CFG_REALMS), d);
if (d->c_realm != -1) {
k5_update_kdcs_display(GetDlgItem(hwnd, IDC_CFG_KDC), NULL, 0);
k5_update_dmap_display(GetDlgItem(hwnd, IDC_CFG_DMAP), NULL, 0);
}
+ khui_cfg_set_flags(d->node_realm,
+ (applied ? KHUI_CNFLAG_APPLIED : 0),
+ KHUI_CNFLAG_APPLIED);
+
}
break;
}
/* already expired */\r
goto _cleanup;\r
} else {\r
- FILETIME lifetime;\r
- khm_int32 t;\r
-\r
- /* make the cache expire at some point */\r
- GetSystemTimeAsFileTime(¤t);\r
- khc_read_int32(csp_params, L"PromptCacheLifetime", &t);\r
- if (t == 0)\r
- t = 172800; /* 48 hours */\r
- TimetToFileTimeInterval(t, &lifetime);\r
- expiry = FtAdd(¤t, &lifetime);\r
- iexpiry = FtToInt(&expiry);\r
-\r
- khc_write_int64(csp_prcache, L"ExpiresOn", iexpiry);\r
+ /* if there is no value for ExpiresOn, we assume the prompts\r
+ have already expired. */\r
+ goto _cleanup;\r
}\r
\r
/* we found a prompt cache. We take this to imply that the\r
(khm_int32) num_prompts);\r
\r
GetSystemTimeAsFileTime(¤t);\r
+#ifdef USE_PROMPT_CACHE_LIFETIME\r
khc_read_int32(csp_params, L"PromptCacheLifetime", &t);\r
if (t == 0)\r
t = 172800; /* 48 hours */\r
+#else\r
+ khc_read_int32(csp_params, L"MaxRenewLifetime", &t);\r
+ if (t == 0)\r
+ t = 2592000; /* 30 days */\r
+ t += 604800; /* + 7 days */\r
+#endif\r
TimetToFileTimeInterval(t, &lifetime);\r
expiry = FtAdd(¤t, &lifetime);\r
iexpiry = FtToInt(&expiry);\r
o->data)\r
PFREE(o->data);\r
\r
- if ((o->flags & KHUI_CW_O_STICKY) &&\r
+ if (((o->flags & KHUI_CW_O_STICKY) ||\r
+ (o->flags & KHUI_CW_O_RELIDENT)) &&\r
o->data)\r
kcdb_identity_release((khm_handle) o->data);\r
\r
prevcred = NULL;\r
}\r
\r
- /* Add any sticky identities that we haven't seen yet */\r
+ /* Add any default identities with no credentials and sticky\r
+ identities that we haven't seen yet */\r
if (n_grouping > 0 && \r
tbl->cols[grouping[0]].attr_id == KCDB_ATTR_ID_NAME) {\r
\r
wchar_t ** idarray = NULL;\r
int i;\r
\r
+ /* see if the defualt identity is in the list */\r
+ {\r
+ khm_handle id_def = NULL;\r
+ wchar_t idname[KCDB_IDENT_MAXCCH_NAME];\r
+ khm_size cb;\r
+ khm_int32 flags;\r
+\r
+ if (KHM_FAILED(kcdb_identity_get_default(&id_def))) {\r
+ goto done_with_defident;\r
+ }\r
+\r
+ kcdb_identity_get_flags(id_def, &flags);\r
+ cb = sizeof(idname);\r
+ kcdb_identity_get_name(id_def, idname, &cb);\r
+\r
+ for (o = tbl->outline; o; o = LNEXT(o)) {\r
+ if (!wcscmp(idname, o->header))\r
+ break;\r
+ }\r
+\r
+ if (o == NULL) {\r
+ o = cw_new_outline_node(idname);\r
+ LPUSH(&tbl->outline, o);\r
+ o->flags = KHUI_CW_O_VISIBLE | KHUI_CW_O_RELIDENT;\r
+ o->level = 0;\r
+ o->col = grouping[0];\r
+ o->data = id_def;\r
+ o->attr_id = KCDB_ATTR_ID;\r
+\r
+ if (flags & KCDB_IDENT_FLAG_STICKY)\r
+ o->flags |= KHUI_CW_O_STICKY;\r
+\r
+ o->start = n_rows;\r
+ o->length = 1;\r
+ o->idx_start = -1;\r
+\r
+ if (grouping[0] == tbl->n_cols - 1)\r
+ o->flags |= KHUI_CW_O_NOOUTLINE;\r
+\r
+ cw_set_tbl_row_header(tbl, n_rows, grouping[0], o);\r
+\r
+ n_rows ++;\r
+ } else {\r
+ kcdb_identity_release(id_def);\r
+ }\r
+\r
+ done_with_defident:\r
+ ;\r
+ }\r
+\r
if (kcdb_identity_enum(KCDB_IDENT_FLAG_STICKY,\r
KCDB_IDENT_FLAG_STICKY,\r
NULL,\r
} else {\r
/* not found. create */\r
o = cw_new_outline_node(idarray[i]);\r
+ LPUSH(&tbl->outline, o);\r
o->flags = KHUI_CW_O_VISIBLE;\r
o->level = 0;\r
o->col = grouping[0];\r
o->data = (void *) h;\r
+ o->attr_id = KCDB_ATTR_ID;\r
+\r
+ if (grouping[0] == tbl->n_cols - 1)\r
+ o->flags |= KHUI_CW_O_NOOUTLINE;\r
}\r
\r
if (o->flags & KHUI_CW_O_STICKY)\r
x += tbl->scr_left;\r
y += tbl->scr_top - tbl->header_height;\r
\r
- if (tbl->flags & KHUI_CW_TBL_EXPIDENT) {\r
- int ty = 0;\r
-\r
- for (i=0; i < tbl->n_rows; i++) {\r
- if (tbl->rows[i].flags & KHUI_CW_ROW_EXPVIEW)\r
- ty += tbl->cell_height * CW_EXP_ROW_MULT;\r
- else\r
- ty += tbl->cell_height;\r
+ row = -1;\r
\r
- if (ty > y)\r
- break;\r
+ for (i=0; i < tbl->n_rows; i++) {\r
+ if (y >= tbl->rows[i].r_ext.top &&\r
+ y < tbl->rows[i].r_ext.bottom) {\r
+ row = i;\r
+ break;\r
}\r
-\r
- row = i;\r
- } else {\r
- row = y / tbl->cell_height;\r
}\r
\r
col = -1;\r
o = (khui_credwnd_outline *) tbl->rows[row].data;\r
\r
/* are we on a widget then? */\r
- x -= tbl->cols[tbl->rows[row].col].x;\r
+ x -= tbl->cols[o->col].x;\r
\r
if (!(o->flags & KHUI_CW_O_NOOUTLINE)) {\r
if(x >= 0 && x < KHUI_SMICON_CX) /* hit */ {\r
}\r
if(tbl->mouse_state & CW_MOUSE_WSTICKY) {\r
if (tbl->flags & KHUI_CW_TBL_EXPIDENT) {\r
- int ty = 0;\r
\r
- for (i=0; i < tbl->n_rows && i < tbl->mouse_row; i++) {\r
- if (tbl->rows[i].flags & KHUI_CW_ROW_EXPVIEW)\r
- ty += tbl->cell_height * CW_EXP_ROW_MULT;\r
- else\r
- ty += tbl->cell_height;\r
- }\r
-\r
- r.top = ty;\r
-\r
- if (tbl->mouse_row < tbl->n_rows &&\r
- (tbl->rows[tbl->mouse_row].flags & KHUI_CW_ROW_EXPVIEW)) {\r
- r.bottom = r.top + tbl->cell_height * CW_EXP_ROW_MULT;\r
- } else {\r
- r.bottom = r.top + tbl->cell_height;\r
- }\r
-\r
- if (tbl->mouse_row < tbl->n_rows &&\r
- (tbl->rows[tbl->mouse_row].flags & KHUI_CW_ROW_HEADER)) {\r
- khui_credwnd_outline * o;\r
-\r
- o = (khui_credwnd_outline *) tbl->rows[tbl->mouse_row].data;\r
-\r
- if (o->flags & KHUI_CW_O_NOOUTLINE) {\r
- r.left = tbl->cols[tbl->mouse_col].x - tbl->scr_left;\r
- } else {\r
- r.left = KHUI_SMICON_CX * 3 / 2 + tbl->cols[tbl->mouse_col].x - tbl->scr_left;\r
- }\r
+ if (tbl->mouse_row >= 0 && tbl->mouse_row < tbl->n_rows) {\r
+ r = tbl->rows[tbl->mouse_row].r_ext;\r
+ OffsetRect(&r, -tbl->scr_left, tbl->header_height - tbl->scr_top);\r
r.right = r.left + KHUI_SMICON_CX;\r
- } else {\r
-#ifdef DEBUG\r
- assert(FALSE);\r
-#endif\r
+ InvalidateRect(tbl->hwnd, &r, TRUE);\r
}\r
+\r
} else {\r
r.left = KHUI_SMICON_CX * 3 / 2 + \r
tbl->cols[tbl->mouse_col].x - tbl->scr_left;\r
}\r
if(tbl->mouse_state & CW_MOUSE_WSTICKY) {\r
if (tbl->flags & KHUI_CW_TBL_EXPIDENT) {\r
- int ty = 0;\r
-\r
- for (i=0; i < tbl->n_rows && i < tbl->mouse_row; i++) {\r
- if (tbl->rows[i].flags & KHUI_CW_ROW_EXPVIEW)\r
- ty += tbl->cell_height * CW_EXP_ROW_MULT;\r
- else\r
- ty += tbl->cell_height;\r
- }\r
-\r
- r.top = ty;\r
-\r
- if (tbl->mouse_row < tbl->n_rows &&\r
- (tbl->rows[tbl->mouse_row].flags & KHUI_CW_ROW_EXPVIEW)) {\r
- r.bottom = r.top + tbl->cell_height * CW_EXP_ROW_MULT;\r
- } else {\r
- r.bottom = r.top + tbl->cell_height;\r
- }\r
\r
- if (tbl->mouse_row < tbl->n_rows &&\r
- (tbl->rows[tbl->mouse_row].flags & KHUI_CW_ROW_HEADER)) {\r
- khui_credwnd_outline * o;\r
-\r
- o = (khui_credwnd_outline *) tbl->rows[tbl->mouse_row].data;\r
-\r
- if (o->flags & KHUI_CW_O_NOOUTLINE) {\r
- r.left = tbl->cols[tbl->mouse_col].x - tbl->scr_left;\r
- } else {\r
- r.left = KHUI_SMICON_CX * 3 / 2 + tbl->cols[tbl->mouse_col].x - tbl->scr_left;\r
- }\r
+ if (tbl->mouse_row >= 0 && tbl->mouse_row < tbl->n_rows) {\r
+ r = tbl->rows[tbl->mouse_row].r_ext;\r
+ OffsetRect(&r, -tbl->scr_left, tbl->header_height - tbl->scr_top);\r
r.right = r.left + KHUI_SMICON_CX;\r
- } else {\r
-#ifdef DEBUG\r
- assert(FALSE);\r
-#endif\r
+ InvalidateRect(tbl->hwnd, &r, TRUE);\r
}\r
+\r
} else {\r
r.left = KHUI_SMICON_CX * 3 / 2 + \r
tbl->cols[tbl->mouse_col].x - tbl->scr_left;\r
#define KHUI_CW_O_SELECTED 0x00000010\r
#define KHUI_CW_O_DATAALLOC 0x00000020\r
#define KHUI_CW_O_NOOUTLINE 0x00000040\r
+#define KHUI_CW_O_RELIDENT 0x00000080\r
\r
typedef struct khui_credwnd_row_t {\r
khm_int32 flags;\r