/****************************************************************************\ * * pleasdlg.cpp * * Created: William Taylor (wtaylor) 01/22/01 * * MS Ratings Access Denied Dialog * \****************************************************************************/ #include "msrating.h" #include "mslubase.h" #include "debug.h" #include "parselbl.h" #include "picsrule.h" #include "pleasdlg.h" // CPleaseDialog #include "hint.h" // CHint #include // Help Context ID's #include // SHWinHelpOnDemandWrap() and MLLoadStringA() #include // URL_COMPONENTS //The FN_INTERNETCRACKURL type describes the URLMON function InternetCrackUrl typedef BOOL (*FN_INTERNETCRACKURL)(LPCTSTR lpszUrl,DWORD dwUrlLength,DWORD dwFlags,LPURL_COMPONENTS lpUrlComponents); // $KLUDGE begins -- These should not be a global set outside the class!! extern BOOL g_fInvalid; extern DWORD g_dwDataSource; extern PICSRulesRatingSystem * g_pPRRS; extern array g_arrpPRRS; extern PICSRulesRatingSystem * g_pApprovedPRRS; extern PICSRulesRatingSystem * g_pApprovedPRRSPreApply; extern array g_arrpPICSRulesPRRSPreApply; extern BOOL g_fPICSRulesEnforced,g_fApprovedSitesEnforced; extern HMODULE g_hURLMON,g_hWININET; extern char g_szLastURL[INTERNET_MAX_URL_LENGTH]; // $KLUDGE ends -- These should not be a global set outside the class!! DWORD CPleaseDialog::aIds[] = { IDC_STATIC2, IDH_IGNORE, IDC_CONTENTLABEL, IDH_IGNORE, IDC_CONTENTERROR, IDH_RATINGS_DESCRIBE_RESTRICTED, IDC_CONTENTDESCRIPTION, IDH_RATINGS_DESCRIBE_RESTRICTED, IDC_STATIC4, IDH_IGNORE, IDC_STATIC5, IDH_IGNORE, IDC_STATIC3, IDH_IGNORE, IDC_BLOCKING_SITE, IDH_RATINGS_VIEW_RESTRICTED, IDC_BLOCKING_PAGE, IDH_RATINGS_VIEW_RESTRICTED, IDC_BLOCKING_ONCE, IDH_RATINGS_VIEW_RESTRICTED, IDC_OLD_HINT_LABEL, IDH_RATINGS_DISPLAY_PW_HINT, IDC_OLD_HINT_TEXT, IDH_RATINGS_DISPLAY_PW_HINT, IDC_STATIC1, IDH_RATINGS_SUPERVISOR_PASSWORD, IDC_PASSWORD, IDH_RATINGS_SUPERVISOR_PASSWORD, 0,0 }; // Array of Dialog Ids which are displayed for Please dialog and not for Deny dialog. DWORD CPleaseDialog::aPleaseIds[] = { IDC_STATIC4, IDC_STATIC3, IDC_STATIC5, IDC_BLOCKING_SITE, IDC_BLOCKING_PAGE, IDC_BLOCKING_ONCE, IDC_OLD_HINT_LABEL, IDC_OLD_HINT_TEXT, IDC_STATIC1, IDC_PASSWORD }; CPleaseDialog::CPleaseDialog( PleaseDlgData * p_ppdd ) { ASSERT( p_ppdd ); m_ppdd = p_ppdd; } LRESULT CPleaseDialog::OnInitDialog(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled) { ASSERT( m_ppdd ); if ( m_ppdd ) { ASSERT( m_ppdd->hwndDlg == NULL ); if ( m_ppdd->hwndDlg == NULL ) { m_ppdd->hwndDlg = m_hWnd; /* Attach our data structure to the dialog so we can find it when the * dialog is dismissed, and on the owner window passed to the API so * we can find it on subsequent API calls. */ SetProp( m_ppdd->hwndOwner, szRatingsProp, (HANDLE)m_ppdd ); } } // Display the Please dialog controls or hide them all. for ( int iIndex=0; iIndexhItemHandle, ::szHelpFile, HELP_WM_HELP, (DWORD_PTR)(LPSTR)aIds); return 0L; } LRESULT CPleaseDialog::OnContextMenu(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled) { SHWinHelpOnDemandWrap((HWND)wParam, ::szHelpFile, HELP_CONTEXTMENU, (DWORD_PTR)(LPVOID)aIds); return 0L; } LRESULT CPleaseDialog::OnNewDialog(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled) { InitPleaseDialog( (PleaseDlgData *) lParam ); return 0L; } void CPleaseDialog::AppendString(HWND hwndEC, LPCSTR pszString) { int cchEdit = ::GetWindowTextLength(hwndEC); ::SendMessage(hwndEC, EM_SETSEL, (WPARAM)cchEdit, (LPARAM)cchEdit); ::SendMessage(hwndEC, EM_REPLACESEL, 0, (LPARAM)pszString); } void CPleaseDialog::AddSeparator(HWND hwndEC, BOOL fAppendToEnd) { NLS_STR nlsTemp(MAX_RES_STR_LEN); if (nlsTemp.QueryError() != ERROR_SUCCESS) { TraceMsg( TF_WARNING, "PleaseDialog::AddSeparator() - Failed to allocate nlsTemp!" ); return; } if (fAppendToEnd) { nlsTemp.LoadString(IDS_DESCRIPTION_SEPARATOR); AppendString(hwndEC, nlsTemp.QueryPch()); } nlsTemp.LoadString(IDS_FRAME); if (fAppendToEnd) { AppendString(hwndEC, nlsTemp.QueryPch()); } else { ::SendMessage(hwndEC, EM_SETSEL, 0, 0); ::SendMessage(hwndEC, EM_REPLACESEL, 0, (LPARAM)(LPCSTR)nlsTemp.QueryPch()); } } void CPleaseDialog::InitPleaseDialog( PleaseDlgData * pdd ) { CComAutoCriticalSection critSec; /**** rated: for each URS with m_fInstalled = TRUE: for each UR with m_fFailed = TRUE: add line to EC not rated: no label list? --> report not rated invalid string in label list? --> report invalid rating any URS's with invalid strings? --> report invalid rating any URS's with error strings? --> report label error no URS's marked installed? --> report unknown rating system for installed URS's: for each UR: options has invalid string? --> report invalid rating options expired? --> report expired not fFound? --> report unknown rating ****/ ASSERT( pdd ); if ( ! pdd ) { TraceMsg( TF_ERROR, "CPleaseDialog::InitPleaseDialog() - pdd is NULL!" ); return; } ASSERT( pdd == m_ppdd ); CParsedLabelList *pLabelList = pdd->pLabelList; for (UINT i=0; icLabels && iapLabelStrings); i++) { if (pdd->apLabelStrings[i] == NULL) { if (pLabelList == NULL || pLabelList->m_pszOriginalLabel == NULL) { TraceMsg( TF_WARNING, "CPleaseDialog::InitPleaseDialog() - pLabelList is NULL or m_pszOriginalLabel is NULL!" ); return; } } else { if (pLabelList != NULL && pLabelList->m_pszOriginalLabel != NULL && ! ::strcmpf( pdd->apLabelStrings[i], pLabelList->m_pszOriginalLabel ) ) { TraceMsg( TF_WARNING, "CPleaseDialog::InitPleaseDialog() - apLabelStrings[%d]='%s' does not match m_pszOriginalLabel='%s'!", i, pdd->apLabelStrings[i], pLabelList->m_pszOriginalLabel ); return; } } } if (pdd->cLabels < ARRAYSIZE(pdd->apLabelStrings)) { if (pLabelList == NULL || pLabelList->m_pszOriginalLabel == NULL) { pdd->apLabelStrings[pdd->cLabels] = NULL; } else { pdd->apLabelStrings[pdd->cLabels] = new char[::strlenf(pLabelList->m_pszOriginalLabel)+1]; if (pdd->apLabelStrings[pdd->cLabels] != NULL) { ::strcpyf(pdd->apLabelStrings[pdd->cLabels], pLabelList->m_pszOriginalLabel); } } } CString strTitle; if ( pLabelList && pLabelList->m_pszURL && pLabelList->m_pszURL[0] != '\0' ) { strTitle.Format( IDS_CONTENT_ADVISOR_HTTP_TITLE, pLabelList->m_pszURL ); } else { strTitle.LoadString( IDS_CONTENT_ADVISOR_TITLE ); } SetWindowText( strTitle ); HWND hwndDescription = GetDlgItem(IDC_CONTENTDESCRIPTION); HWND hwndError = GetDlgItem(IDC_CONTENTERROR); HWND hwndPrevEC = pdd->hwndEC; /* There are two edit controls in the dialog. One, the "description" * control, has a horizontal scrollbar, because we don't want word wrap * for the category names (cleaner presentation). The other EC has no * scrollbar so that the lengthy error strings will wordwrap. * * If we've been using the description control and we add error-type * information, we need to copy the text out of the description control * into the error control and show it. */ BOOL fRatedPage = ( pLabelList != NULL && pLabelList->m_fRated ); if ( ! fRatedPage && pdd->hwndEC == hwndDescription ) { NLS_STR nlsTemp(::GetWindowTextLength(hwndDescription)); if (nlsTemp.QueryError() == ERROR_SUCCESS) { CHAR * tempStr = nlsTemp.Party(); if (tempStr) { ::GetWindowText(hwndDescription, tempStr, nlsTemp.QueryAllocSize()); nlsTemp.DonePartying(); ::SetWindowText(hwndError, nlsTemp.QueryPch()); } else { nlsTemp.DonePartying(); } } pdd->hwndEC = hwndError; } else if (pdd->hwndEC == NULL) { pdd->hwndEC = fRatedPage ? hwndDescription : hwndError; } if (pdd->hwndEC != hwndPrevEC) { BOOL fShowErrorCtl = (pdd->hwndEC == hwndError); if (::GetFocus() == hwndPrevEC) { ::SetFocus(pdd->hwndEC); } ShowHideControl( IDC_CONTENTERROR, fShowErrorCtl ); ShowHideControl( IDC_CONTENTDESCRIPTION, ! fShowErrorCtl ); } /* If there's already just one label in the list, prefix it with a * label "Frame:" since there will now be two. */ if (pdd->cLabels == 1) { AddSeparator(pdd->hwndEC, FALSE); } /* If this is not the first label we're adding, we need a full separator * appended before we add new descriptive text. */ if (pdd->cLabels > 0) { AddSeparator(pdd->hwndEC, TRUE); } if (g_fInvalid) { char szSourceMessage[MAX_PATH]; MLLoadString(IDS_TAMPEREDRATING1,(char *) szSourceMessage,MAX_PATH); AppendString(pdd->hwndEC, szSourceMessage); AppendString(pdd->hwndEC, "\x0D\x0A"); MLLoadString(IDS_TAMPEREDRATING2,(char *) szSourceMessage,MAX_PATH); AppendString(pdd->hwndEC, szSourceMessage); } else if (fRatedPage) { NLS_STR nlsTemplate(MAX_RES_STR_LEN); nlsTemplate.LoadString(IDS_RATINGTEMPLATE); NLS_STR nlsTmp; if (nlsTemplate.QueryError() || nlsTmp.QueryError()) { TraceMsg( TF_WARNING, "CPleaseDialog::InitPleaseDialog() - fRatedPage => nlsTemplate or nlsTmp Error!" ); return; } for (CParsedServiceInfo *ppsi = &pLabelList->m_ServiceInfo; ppsi != NULL; ppsi = ppsi->Next()) { if (!ppsi->m_fInstalled) continue; UserRatingSystem *pURS = pdd->pPU->FindRatingSystem(ppsi->m_pszServiceName); if (pURS == NULL || pURS->m_pPRS == NULL) continue; NLS_STR nlsSystemName(STR_OWNERALLOC, pURS->m_pPRS->etstrName.Get()); UINT cRatings = ppsi->aRatings.Length(); for (UINT i=0; iaRatings[i]; if (pRating->fFailed) { nlsTmp = nlsTemplate; UserRating *pUR = pURS->FindRating(pRating->pszTransmitName); if (pUR == NULL) continue; PicsCategory *pPC = pUR->m_pPC; if (pPC == NULL) continue; LPCSTR pszCategory; if (pPC->etstrName.fIsInit()) { pszCategory = pPC->etstrName.Get(); } else if (pPC->etstrDesc.fIsInit()) { pszCategory = pPC->etstrDesc.Get(); } else { pszCategory = pRating->pszTransmitName; } NLS_STR nlsCategoryName(STR_OWNERALLOC, (LPSTR)pszCategory); UINT cValues = pPC->arrpPE.Length(); PicsEnum *pPE; for (UINT iValue=0; iValuearrpPE[iValue]; if (pPE->etnValue.Get() == pRating->nValue) break; } LPCSTR pszValue = szNULL; char szNumBuf[20]; if (iValue < cValues) { if (pPE->etstrName.fIsInit()) { pszValue = pPE->etstrName.Get(); } else if (pPE->etstrDesc.fIsInit()) { pszValue = pPE->etstrDesc.Get(); } else { wsprintf(szNumBuf, "%d", pRating->nValue); pszValue = szNumBuf; } } NLS_STR nlsValueName(STR_OWNERALLOC, (LPSTR)pszValue); const NLS_STR *apnls[] = { &nlsSystemName, &nlsCategoryName, &nlsValueName, NULL }; nlsTmp.InsertParams(apnls); if (!nlsTmp.QueryError()) { AppendString(pdd->hwndEC, nlsTmp.QueryPch()); } } } } if ((g_fPICSRulesEnforced!=TRUE)&&(g_fApprovedSitesEnforced!=TRUE)) { UINT idSourceMsg; char szSourceMessage[MAX_PATH]; switch(g_dwDataSource) { case PICS_LABEL_FROM_HEADER: { idSourceMsg=IDS_SOURCE_SERVER; break; } case PICS_LABEL_FROM_PAGE: { idSourceMsg=IDS_SOURCE_EMBEDDED; break; } case PICS_LABEL_FROM_BUREAU: { idSourceMsg=IDS_SOURCE_BUREAU; break; } } MLLoadString(idSourceMsg,(char *) szSourceMessage,MAX_PATH); AppendString(pdd->hwndEC, "\x0D\x0A"); AppendString(pdd->hwndEC, szSourceMessage); } } else { UINT idMsg = 0; LPCSTR psz1=szNULL, psz2=szNULL; if ( pLabelList == NULL || pLabelList->m_fNoRating ) { idMsg = IDS_UNRATED; } else if (pLabelList->m_pszInvalidString) { idMsg = IDS_INVALIDRATING; psz1 = pLabelList->m_pszInvalidString; } else { BOOL fErrorFound = FALSE; BOOL fAnyInstalled = FALSE; CParsedServiceInfo *ppsi = &pLabelList->m_ServiceInfo; while (ppsi != NULL) { if (ppsi->m_pszInvalidString) { idMsg = IDS_INVALIDRATING; psz1 = ppsi->m_pszInvalidString; fErrorFound = TRUE; } else if (ppsi->m_pszErrorString) { idMsg = IDS_LABELERROR; psz1 = ppsi->m_pszErrorString; fErrorFound = TRUE; } else if (ppsi->m_fInstalled) { fAnyInstalled = TRUE; } ppsi = ppsi->Next(); } if (!fErrorFound) { if (!fAnyInstalled) { idMsg = IDS_UNKNOWNSYSTEM; psz1 = pLabelList->m_ServiceInfo.m_pszServiceName; } else { for (ppsi = &pLabelList->m_ServiceInfo; ppsi != NULL; ppsi = ppsi->Next()) { if ( ! ppsi->m_fInstalled ) continue; UINT cRatings = ppsi->aRatings.Length(); for (UINT i=0; iaRatings[i]; COptionsBase *pOpt = ppr->pOptions; if (pOpt->m_pszInvalidString) { idMsg = IDS_INVALIDRATING; psz1 = pOpt->m_pszInvalidString; break; } else if (pOpt->m_fdwFlags & LBLOPT_WRONGURL) { idMsg = IDS_WRONGURL; psz1 = pLabelList->m_pszURL; psz2 = pOpt->m_pszURL; } else if (pOpt->m_fdwFlags & LBLOPT_EXPIRED) { idMsg = IDS_EXPIRED; break; } else if (!ppr->fFound) { idMsg = IDS_UNKNOWNRATING; psz1 = ppr->pszTransmitName; UserRatingSystem *pURS = pdd->pPU->FindRatingSystem(ppsi->m_pszServiceName); if (pURS != NULL && pURS->m_pPRS != NULL) { if (pURS->m_pPRS->etstrName.fIsInit()) { psz2 = pURS->m_pPRS->etstrName.Get(); } } break; } } if (idMsg != 0) break; } } } } if (g_fPICSRulesEnforced==TRUE) { idMsg=IDS_PICSRULES_ENFORCED; } else if (g_fApprovedSitesEnforced==TRUE) { idMsg=IDS_APPROVEDSITES_ENFORCED; } /* It's theoretically possible that we got through all that and * didn't find anything explicitly wrong, yet the site was considered * unrated (perhaps it was a valid label with no actual ratings in it). * So if we didn't decide what error to display, just don't stick * anything in the edit control, and the dialog will just say "Sorry" * at the top. */ if (idMsg != 0) { NLS_STR nls1(STR_OWNERALLOC, (LPSTR)psz1); NLS_STR nls2(STR_OWNERALLOC, (LPSTR)psz2); const NLS_STR *apnls[] = { &nls1, &nls2, NULL }; NLS_STR nlsMessage(MAX_RES_STR_LEN); nlsMessage.LoadString((USHORT)idMsg, apnls); AppendString(pdd->hwndEC, nlsMessage.QueryPch()); } if (idMsg == IDS_UNKNOWNSYSTEM) { NLS_STR nlsTemplate(MAX_RES_STR_LEN); nlsTemplate.LoadString(IDS_UNKNOWNRATINGTEMPLATE); NLS_STR nlsTmp; if (nlsTemplate.QueryError() || nlsTmp.QueryError()) { TraceMsg( TF_WARNING, "CPleaseDialog::InitPleaseDialog() - IDS_UNKNOWNSYSTEM => nlsTemplate or nlsTmp Error!" ); return; } UINT cRatings = pLabelList->m_ServiceInfo.aRatings.Length(); for (UINT i=0; im_ServiceInfo.aRatings[i]; char szNumBuf[20]; wsprintf(szNumBuf, "%d", ppr->nValue); NLS_STR nlsCategoryName(STR_OWNERALLOC, ppr->pszTransmitName); NLS_STR nlsValueName(STR_OWNERALLOC, szNumBuf); const NLS_STR *apnls[] = { &nlsCategoryName, &nlsValueName, NULL }; nlsTmp = nlsTemplate; nlsTmp.InsertParams(apnls); if (!nlsTmp.QueryError()) { AppendString(pdd->hwndEC, nlsTmp.QueryPch()); } } } } if ( IsPleaseDialog() ) { SendDlgItemMessage(IDC_BLOCKING_ONCE, BM_SETCHECK, (WPARAM) BST_CHECKED, (LPARAM) 0); SendDlgItemMessage(IDC_BLOCKING_PAGE, BM_SETCHECK, (WPARAM) BST_UNCHECKED, (LPARAM) 0); SendDlgItemMessage(IDC_BLOCKING_SITE, BM_SETCHECK, (WPARAM) BST_UNCHECKED, (LPARAM) 0); } pdd->cLabels++; /* now one more label description in the box */ } void CPleaseDialog::EndPleaseDialog( BOOL fRet) { PleaseDlgData *ppdd = m_ppdd; ASSERT( m_ppdd ); if (ppdd != NULL) { ppdd->dwFlags = PDD_DONE | (fRet ? PDD_ALLOW : 0); ppdd->hwndDlg = NULL; SetProp( m_ppdd->hwndOwner, szRatingsValue, UlongToPtr( ppdd->dwFlags ) ); RemoveProp(ppdd->hwndOwner, szRatingsProp); } EndDialog(fRet); } HRESULT CPleaseDialog::AddToApprovedSites(BOOL fAlwaysNever,BOOL fSitePage) { PICSRulesPolicy * pPRPolicy; PICSRulesByURL * pPRByURL; PICSRulesByURLExpression * pPRByURLExpression; char * lpszSiteURL; HRESULT hRes; URL_COMPONENTS URLComponents; FN_INTERNETCRACKURL pfnInternetCrackUrl; INTERNET_SCHEME INetScheme=INTERNET_SCHEME_DEFAULT; INTERNET_PORT INetPort=INTERNET_INVALID_PORT_NUMBER; LPSTR lpszScheme,lpszHostName,lpszUserName, lpszPassword,lpszUrlPath,lpszExtraInfo; BOOL fAddedScheme=FALSE; int iCounter,iLoopCounter; lpszSiteURL=new char[INTERNET_MAX_URL_LENGTH]; if (lpszSiteURL==NULL) { return(E_OUTOFMEMORY); } strcpy(lpszSiteURL,g_szLastURL); if (g_pApprovedPRRS==NULL) { g_pApprovedPRRS=new PICSRulesRatingSystem; if (g_pApprovedPRRS==NULL) { return(E_OUTOFMEMORY); } } pPRPolicy=new PICSRulesPolicy; if (pPRPolicy==NULL) { return(E_OUTOFMEMORY); } pPRByURL=new PICSRulesByURL; if (pPRByURL==NULL) { return(E_OUTOFMEMORY); } if (fAlwaysNever==PICSRULES_NEVER) { pPRPolicy->m_PRPolicyAttribute=PR_POLICY_REJECTBYURL; pPRPolicy->AddItem(PROID_REJECTBYURL,pPRByURL); } else { pPRPolicy->m_PRPolicyAttribute=PR_POLICY_ACCEPTBYURL; pPRPolicy->AddItem(PROID_ACCEPTBYURL,pPRByURL); } pPRByURLExpression=new PICSRulesByURLExpression; if (pPRByURLExpression==NULL) { return(E_OUTOFMEMORY); } pPRByURL->m_arrpPRByURL.Append(pPRByURLExpression); //if we made it through all that, then we have a //PICSRulesByURLExpression to fill out, and need //to update the list box. lpszScheme=new char[INTERNET_MAX_SCHEME_LENGTH+1]; lpszHostName=new char[INTERNET_MAX_PATH_LENGTH+1]; lpszUserName=new char[INTERNET_MAX_PATH_LENGTH+1]; lpszPassword=new char[INTERNET_MAX_PATH_LENGTH+1]; lpszUrlPath=new char[INTERNET_MAX_PATH_LENGTH+1]; lpszExtraInfo=new char[INTERNET_MAX_PATH_LENGTH+1]; if (lpszScheme==NULL || lpszHostName==NULL || lpszUserName==NULL || lpszPassword==NULL || lpszUrlPath==NULL || lpszExtraInfo==NULL) { return(E_OUTOFMEMORY); } URLComponents.dwStructSize=sizeof(URL_COMPONENTS); URLComponents.lpszScheme=lpszScheme; URLComponents.dwSchemeLength=INTERNET_MAX_SCHEME_LENGTH; URLComponents.nScheme=INetScheme; URLComponents.lpszHostName=lpszHostName; URLComponents.dwHostNameLength=INTERNET_MAX_PATH_LENGTH; URLComponents.nPort=INetPort; URLComponents.lpszUserName=lpszUserName; URLComponents.dwUserNameLength=INTERNET_MAX_PATH_LENGTH; URLComponents.lpszPassword=lpszPassword; URLComponents.dwPasswordLength=INTERNET_MAX_PATH_LENGTH; URLComponents.lpszUrlPath=lpszUrlPath; URLComponents.dwUrlPathLength=INTERNET_MAX_PATH_LENGTH; URLComponents.lpszExtraInfo=lpszExtraInfo; URLComponents.dwExtraInfoLength=INTERNET_MAX_PATH_LENGTH; pfnInternetCrackUrl=(FN_INTERNETCRACKURL) GetProcAddress(g_hWININET,"InternetCrackUrlA"); if (pfnInternetCrackUrl==NULL) { return(E_UNEXPECTED); } pfnInternetCrackUrl(lpszSiteURL,0,ICU_DECODE,&URLComponents); delete lpszExtraInfo; //we don't do anything with this for now lpszExtraInfo = NULL; delete lpszPassword; //not supported by PICSRules lpszPassword = NULL; if (g_fApprovedSitesEnforced==TRUE) { int iCounter; PICSRulesPolicy * pPRFindPolicy; BOOL fFound=FALSE,fDeleted=FALSE; //we've already got an Approved Sites setting enforcing this //so check for an exact match, and if it exists, change it //instead of adding another for (iCounter=0;iCounterm_arrpPRPolicy.Length();iCounter++) { PICSRulesByURLExpression * pPRFindByURLExpression; PICSRulesByURL * pPRFindByURL; char * lpszTest; pPRFindPolicy=g_pApprovedPRRS->m_arrpPRPolicy[iCounter]; switch(pPRFindPolicy->m_PRPolicyAttribute) { case PR_POLICY_REJECTBYURL: { pPRFindByURL=pPRFindPolicy->m_pPRRejectByURL; break; } case PR_POLICY_ACCEPTBYURL: { pPRFindByURL=pPRFindPolicy->m_pPRAcceptByURL; break; } } pPRFindByURLExpression=pPRFindByURL->m_arrpPRByURL[0]; if ((pPRFindByURLExpression->m_bNonWild)&BYURL_SCHEME) { if (lpszScheme==NULL) { fFound=FALSE; continue; } lpszTest=pPRFindByURLExpression->m_etstrScheme.Get(); if (lstrcmpi(lpszScheme,lpszTest)==0) { fFound=TRUE; } else { fFound=FALSE; continue; } } else { fFound=TRUE; } if ((pPRFindByURLExpression->m_bNonWild)&BYURL_USER) { if (lpszUserName==NULL) { fFound=FALSE; continue; } lpszTest=pPRFindByURLExpression->m_etstrUser.Get(); if (lstrcmpi(lpszUserName,lpszTest)==0) { fFound=TRUE; } else { fFound=FALSE; continue; } } else { fFound=TRUE; } if ((pPRFindByURLExpression->m_bNonWild)&BYURL_HOST) { if (lpszHostName==NULL) { fFound=FALSE; continue; } lpszTest=pPRFindByURLExpression->m_etstrHost.Get(); if (lstrcmp(lpszHostName,lpszTest)==0) { fFound=TRUE; } else { fFound=FALSE; continue; } } else { fFound=TRUE; } if (fSitePage!=PICSRULES_SITE) { if ((pPRFindByURLExpression->m_bNonWild)&BYURL_PATH) { int iLen; if (lpszUrlPath==NULL) { fFound=FALSE; continue; } lpszTest=pPRFindByURLExpression->m_etstrPath.Get(); //kill trailing slashes iLen=lstrlen(lpszTest); if (lpszTest[iLen-1]=='/') { lpszTest[iLen-1]='\0'; } iLen=lstrlen(lpszUrlPath); if (lpszUrlPath[iLen-1]=='/') { lpszUrlPath[iLen-1]='\0'; } if (lstrcmp(lpszUrlPath,lpszTest)==0) { fFound=TRUE; } else { fFound=FALSE; continue; } } else { fFound=FALSE; continue; } } if (fFound==TRUE) { if (fSitePage==PICSRULES_PAGE) { break; } else { delete pPRFindPolicy; pPRFindPolicy = NULL; g_pApprovedPRRS->m_arrpPRPolicy[iCounter]=NULL; fDeleted=TRUE; } } } if (fDeleted==TRUE) { PICSRulesRatingSystem * pPRRSNew; pPRRSNew=new PICSRulesRatingSystem; if (pPRRSNew==NULL) { return(E_OUTOFMEMORY); } for (iCounter=0;iCounterm_arrpPRPolicy.Length();iCounter++) { if ((g_pApprovedPRRS->m_arrpPRPolicy[iCounter])!=NULL) { pPRRSNew->m_arrpPRPolicy.Append((g_pApprovedPRRS->m_arrpPRPolicy[iCounter])); } } g_pApprovedPRRS->m_arrpPRPolicy.ClearAll(); delete g_pApprovedPRRS; g_pApprovedPRRS=pPRRSNew; fFound=FALSE; } if (fFound==TRUE) { delete pPRFindPolicy; pPRFindPolicy= NULL; g_pApprovedPRRS->m_arrpPRPolicy[iCounter]=pPRPolicy; } else { hRes=g_pApprovedPRRS->AddItem(PROID_POLICY,pPRPolicy); if (FAILED(hRes)) { return(hRes); } } } else { hRes=g_pApprovedPRRS->AddItem(PROID_POLICY,pPRPolicy); if (FAILED(hRes)) { return(hRes); } } pPRByURLExpression->m_fInternetPattern=TRUE; if ((*lpszScheme!=NULL)&&(fAddedScheme==FALSE)) { pPRByURLExpression->m_bNonWild|=BYURL_SCHEME; pPRByURLExpression->m_etstrScheme.SetTo(lpszScheme); } else { delete lpszScheme; lpszScheme = NULL; } pPRByURLExpression->m_bSpecified|=BYURL_SCHEME; if (*lpszUserName!=NULL) { pPRByURLExpression->m_bNonWild|=BYURL_USER; pPRByURLExpression->m_etstrUser.SetTo(lpszUserName); } else { delete lpszUserName; lpszUserName = NULL; } pPRByURLExpression->m_bSpecified|=BYURL_USER; if (*lpszHostName!=NULL) { pPRByURLExpression->m_bNonWild|=BYURL_HOST; pPRByURLExpression->m_etstrHost.SetTo(lpszHostName); } else { delete lpszHostName; lpszHostName = NULL; } pPRByURLExpression->m_bSpecified|=BYURL_HOST; if (*lpszUrlPath!=NULL) { if (lstrcmp(lpszUrlPath,"/")!=0) { if (fSitePage==PICSRULES_PAGE) { pPRByURLExpression->m_bNonWild|=BYURL_PATH; pPRByURLExpression->m_etstrPath.SetTo(lpszUrlPath); } } } else { delete lpszUrlPath; lpszUrlPath = NULL; } pPRByURLExpression->m_bSpecified|=BYURL_PATH; if (URLComponents.nPort!=INTERNET_INVALID_PORT_NUMBER) { LPSTR lpszTemp; lpszTemp=new char[MAX_PATH]; if (lpszTemp==NULL) { char szTitle[MAX_PATH],szMessage[MAX_PATH]; //out of memory, so we init on the stack MLLoadString(IDS_ERROR,(LPTSTR) szTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_OUTOFMEMORY,(LPTSTR) szMessage,MAX_PATH); MessageBox((LPCTSTR) szMessage,(LPCTSTR) szTitle,MB_OK|MB_ICONERROR); return(E_OUTOFMEMORY); } wsprintf(lpszTemp,"%d",URLComponents.nPort); pPRByURLExpression->m_bNonWild|=BYURL_PORT; pPRByURLExpression->m_etstrPort.SetTo(lpszTemp); } pPRByURLExpression->m_bSpecified|=BYURL_PORT; if (fSitePage==PICSRULES_PAGE) { pPRByURLExpression->m_etstrURL.SetTo(lpszSiteURL); } else { pPRByURLExpression->m_etstrURL.Set(pPRByURLExpression->m_etstrHost.Get()); } //copy master list to the PreApply list so we can reorder the entries //to obtain the appropriate logic. if (g_pApprovedPRRSPreApply!=NULL) { delete g_pApprovedPRRSPreApply; } g_pApprovedPRRSPreApply=new PICSRulesRatingSystem; if (g_pApprovedPRRSPreApply==NULL) { char szTitle[MAX_PATH],szMessage[MAX_PATH]; //out of memory, so we init on the stack MLLoadString(IDS_ERROR,(LPTSTR) szTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_OUTOFMEMORY,(LPTSTR) szMessage,MAX_PATH); MessageBox((LPCTSTR) szMessage,(LPCTSTR) szTitle,MB_OK|MB_ICONERROR); return(E_OUTOFMEMORY); } for (iCounter=0;iCounterm_arrpPRPolicy.Length();iCounter++) { PICSRulesPolicy * pPRPolicy,* pPRPolicyToCopy; PICSRulesByURL * pPRByURL,* pPRByURLToCopy; PICSRulesByURLExpression * pPRByURLExpression,* pPRByURLExpressionToCopy; pPRPolicy=new PICSRulesPolicy; if (pPRPolicy==NULL) { char szTitle[MAX_PATH],szMessage[MAX_PATH]; //out of memory, so we init on the stack MLLoadString(IDS_ERROR,(LPTSTR) szTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_OUTOFMEMORY,(LPTSTR) szMessage,MAX_PATH); MessageBox((LPCTSTR) szMessage,(LPCTSTR) szTitle,MB_OK|MB_ICONERROR); return(E_OUTOFMEMORY); } pPRPolicyToCopy=g_pApprovedPRRS->m_arrpPRPolicy[iCounter]; pPRPolicy->m_PRPolicyAttribute=pPRPolicyToCopy->m_PRPolicyAttribute; pPRByURL=new PICSRulesByURL; if (pPRByURL==NULL) { char szTitle[MAX_PATH],szMessage[MAX_PATH]; //out of memory, so we init on the stack MLLoadString(IDS_ERROR,(LPTSTR) szTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_OUTOFMEMORY,(LPTSTR) szMessage,MAX_PATH); MessageBox((LPCTSTR) szMessage,(LPCTSTR) szTitle,MB_OK|MB_ICONERROR); return(E_OUTOFMEMORY); } if (pPRPolicy->m_PRPolicyAttribute==PR_POLICY_ACCEPTBYURL) { pPRByURLToCopy=pPRPolicyToCopy->m_pPRAcceptByURL; pPRPolicy->m_pPRAcceptByURL=pPRByURL; } else { pPRByURLToCopy=pPRPolicyToCopy->m_pPRRejectByURL; pPRPolicy->m_pPRRejectByURL=pPRByURL; } pPRByURLExpression=new PICSRulesByURLExpression; if (pPRByURLExpression==NULL) { char szTitle[MAX_PATH],szMessage[MAX_PATH]; //out of memory, so we init on the stack MLLoadString(IDS_ERROR,(LPTSTR) szTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_OUTOFMEMORY,(LPTSTR) szMessage,MAX_PATH); MessageBox((LPCTSTR) szMessage,(LPCTSTR) szTitle,MB_OK|MB_ICONERROR); return(E_OUTOFMEMORY); } pPRByURLExpressionToCopy=pPRByURLToCopy->m_arrpPRByURL[0]; if (pPRByURLExpressionToCopy==NULL) { char *lpszTitle,*lpszMessage; //we shouldn't ever get here lpszTitle=(char *) GlobalAlloc(GPTR,MAX_PATH); lpszMessage=(char *) GlobalAlloc(GPTR,MAX_PATH); MLLoadString(IDS_ERROR,(LPTSTR) lpszTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_NOAPPROVEDSAVE,(LPTSTR) lpszMessage,MAX_PATH); MessageBox((LPCTSTR) lpszMessage,(LPCTSTR) lpszTitle,MB_OK|MB_ICONERROR); GlobalFree(lpszTitle); lpszTitle = NULL; GlobalFree(lpszMessage); lpszMessage = NULL; delete pPRPolicy; pPRPolicy = NULL; return(E_UNEXPECTED); } pPRByURLExpression->m_fInternetPattern=pPRByURLExpressionToCopy->m_fInternetPattern; pPRByURLExpression->m_bNonWild=pPRByURLExpressionToCopy->m_bNonWild; pPRByURLExpression->m_bSpecified=pPRByURLExpressionToCopy->m_bSpecified; pPRByURLExpression->m_etstrScheme.Set(pPRByURLExpressionToCopy->m_etstrScheme.Get()); pPRByURLExpression->m_etstrUser.Set(pPRByURLExpressionToCopy->m_etstrUser.Get()); pPRByURLExpression->m_etstrHost.Set(pPRByURLExpressionToCopy->m_etstrHost.Get()); pPRByURLExpression->m_etstrPort.Set(pPRByURLExpressionToCopy->m_etstrPort.Get()); pPRByURLExpression->m_etstrPath.Set(pPRByURLExpressionToCopy->m_etstrPath.Get()); pPRByURLExpression->m_etstrURL.Set(pPRByURLExpressionToCopy->m_etstrURL.Get()); pPRByURL->m_arrpPRByURL.Append(pPRByURLExpression); g_pApprovedPRRSPreApply->m_arrpPRPolicy.Append(pPRPolicy); } if (g_pApprovedPRRS!=NULL) { delete g_pApprovedPRRS; } g_pApprovedPRRS=new PICSRulesRatingSystem; if (g_pApprovedPRRS==NULL) { char szTitle[MAX_PATH],szMessage[MAX_PATH]; //out of memory, so we init on the stack MLLoadString(IDS_ERROR,(LPTSTR) szTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_OUTOFMEMORY,(LPTSTR) szMessage,MAX_PATH); MessageBox((LPCTSTR) szMessage,(LPCTSTR) szTitle,MB_OK|MB_ICONERROR); return(E_OUTOFMEMORY); } for (iLoopCounter=0;iLoopCounter<2;iLoopCounter++) { for (iCounter=0;iCounterm_arrpPRPolicy.Length();iCounter++) { PICSRulesPolicy * pPRPolicy,* pPRPolicyToCopy; PICSRulesByURL * pPRByURL,* pPRByURLToCopy; PICSRulesByURLExpression * pPRByURLExpression,* pPRByURLExpressionToCopy; pPRPolicyToCopy=g_pApprovedPRRSPreApply->m_arrpPRPolicy[iCounter]; if (pPRPolicyToCopy->m_PRPolicyAttribute==PR_POLICY_ACCEPTBYURL) { pPRByURLToCopy=pPRPolicyToCopy->m_pPRAcceptByURL; } else { pPRByURLToCopy=pPRPolicyToCopy->m_pPRRejectByURL; } pPRByURLExpressionToCopy=pPRByURLToCopy->m_arrpPRByURL[0]; if (pPRByURLExpressionToCopy==NULL) { char *lpszTitle,*lpszMessage; //we shouldn't ever get here lpszTitle=(char *) GlobalAlloc(GPTR,MAX_PATH); lpszMessage=(char *) GlobalAlloc(GPTR,MAX_PATH); MLLoadString(IDS_ERROR,(LPTSTR) lpszTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_NOAPPROVEDSAVE,(LPTSTR) lpszMessage,MAX_PATH); MessageBox((LPCTSTR) lpszMessage,(LPCTSTR) lpszTitle,MB_OK|MB_ICONERROR); GlobalFree(lpszTitle); lpszTitle = NULL; GlobalFree(lpszMessage); lpszMessage = NULL; return(E_UNEXPECTED); } //we want to put all of the non-sitewide approved sites first //so that a user can specify, allow all of xyz.com except for //xyz.com/foo.htm switch(iLoopCounter) { case 0: { if ((pPRByURLExpressionToCopy->m_bNonWild)&BYURL_PATH) { break; } else { continue; } } case 1: { if (!((pPRByURLExpressionToCopy->m_bNonWild)&BYURL_PATH)) { break; } else { continue; } } } pPRPolicy=new PICSRulesPolicy; if (pPRPolicy==NULL) { char szTitle[MAX_PATH],szMessage[MAX_PATH]; //out of memory, so we init on the stack MLLoadString(IDS_ERROR,(LPTSTR) szTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_OUTOFMEMORY,(LPTSTR) szMessage,MAX_PATH); MessageBox((LPCTSTR) szMessage,(LPCTSTR) szTitle,MB_OK|MB_ICONERROR); return(E_OUTOFMEMORY); } pPRPolicy->m_PRPolicyAttribute=pPRPolicyToCopy->m_PRPolicyAttribute; pPRByURL=new PICSRulesByURL; if (pPRByURL==NULL) { char szTitle[MAX_PATH],szMessage[MAX_PATH]; //out of memory, so we init on the stack MLLoadString(IDS_ERROR,(LPTSTR) szTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_OUTOFMEMORY,(LPTSTR) szMessage,MAX_PATH); MessageBox((LPCTSTR) szMessage,(LPCTSTR) szTitle,MB_OK|MB_ICONERROR); return(E_OUTOFMEMORY); } if (pPRPolicy->m_PRPolicyAttribute==PR_POLICY_ACCEPTBYURL) { pPRPolicy->m_pPRAcceptByURL=pPRByURL; } else { pPRPolicy->m_pPRRejectByURL=pPRByURL; } pPRByURLExpression=new PICSRulesByURLExpression; if (pPRByURLExpression==NULL) { char szTitle[MAX_PATH],szMessage[MAX_PATH]; //out of memory, so we init on the stack MLLoadString(IDS_ERROR,(LPTSTR) szTitle,MAX_PATH); MLLoadString(IDS_PICSRULES_OUTOFMEMORY,(LPTSTR) szMessage,MAX_PATH); MessageBox((LPCTSTR) szMessage,(LPCTSTR) szTitle,MB_OK|MB_ICONERROR); return(E_OUTOFMEMORY); } pPRByURLExpression->m_fInternetPattern=pPRByURLExpressionToCopy->m_fInternetPattern; pPRByURLExpression->m_bNonWild=pPRByURLExpressionToCopy->m_bNonWild; pPRByURLExpression->m_bSpecified=pPRByURLExpressionToCopy->m_bSpecified; pPRByURLExpression->m_etstrScheme.Set(pPRByURLExpressionToCopy->m_etstrScheme.Get()); pPRByURLExpression->m_etstrUser.Set(pPRByURLExpressionToCopy->m_etstrUser.Get()); pPRByURLExpression->m_etstrHost.Set(pPRByURLExpressionToCopy->m_etstrHost.Get()); pPRByURLExpression->m_etstrPort.Set(pPRByURLExpressionToCopy->m_etstrPort.Get()); pPRByURLExpression->m_etstrPath.Set(pPRByURLExpressionToCopy->m_etstrPath.Get()); pPRByURLExpression->m_etstrURL.Set(pPRByURLExpressionToCopy->m_etstrURL.Get()); pPRByURL->m_arrpPRByURL.Append(pPRByURLExpression); g_pApprovedPRRS->m_arrpPRPolicy.Append(pPRPolicy); } } PICSRulesDeleteSystem(PICSRULES_APPROVEDSITES); PICSRulesSaveToRegistry(PICSRULES_APPROVEDSITES,&g_pApprovedPRRS); return(NOERROR); }