I agree, writing code to an include file does present a security risk. However: 1. the original poster asked how to replace evaluate(de()) - this has been done, albeit in an unsecure fashion 2. no mention was made or sought as to how the original HTMLBody variable was created. I assumed it was internal (authenticated,trustworthy) users and there would not be any inherent security risk. 3. agreed, I should have stated the obvious security risk present within the solution offered.
4. evaluate(de()) can also be dangerous:
eg: replace the original HTMLBody with the following

<cfset HTMLBody = "
##title##
Current server var list: ##structkeylist(server)## |
O/S: ##server.os.name## |
Boot.ini sections: ##iif(server.os.name contains 'windows', de(structkeylist(GetProfileSections('c:\boot.ini'))), de('linux'))## |
Set a var: ##setvariable('session.test', 'Hacked')## |
Current session var list: ##structkeylist(session)## |
Current application var list: ##structkeylist(application)## |
Current variables: ##structkeylist(variables)## |
Change a var: ##setvariable('session.test', 'again')##
">

regards
Aaron

Chris Stoner wrote:
While this is a very simple way to implement your solution its a fairly large security risk. Anything inside that mail.inc now becomes cold fusion code that a clever user could do all sorts of nasty things with. By setting up the mail body with any kind of malicious code (cfexecute, cfregistry, cffile deletes, sql drops, etc.) the user can then execute it by sending an email.

You are better off just using the {{ variable name }} idea. While its more work for the developer and more limiting for the user its a much safer solution.

-- Chris Stoner

On 6/9/06, *Aaron DC* <[EMAIL PROTECTED] <mailto:[EMAIL PROTECTED]>> wrote:

    When your HTMLBody variable is created, save its contents to a
    file (eg:
    mail.inc) with the cfmail tag wrapped around it. I am guessing the
    HTMLBody variable is statically dynamic ie can be changed but probably
    isn't changed all that much. You will then end up with the following:

    mailit.cfm:
    <cfset var campaign = GetCampaign() />
    <cfinclude template="mail.inc">

    mail.inc

    <cfmail query="recipients"

    to="#recipients.email#"

    from="#Campaign.GetEmailFrom()# (#Campaign.GetEmailFromAlias()#)"

    subject="Campaign ## #campaign.GetCampaignID()#"

    failto="#Campaign.GetEmailFailTo()#"

    mailerid="Summit Projects, Inc. "

    type="HTML">

    #Email#

    #FirstName# #LastName#
    #CompanyName#

    #AddressLine1#
    etc
    </cfmail>

    NB: The cfmail (or cfoutput, etc) tags are required to force CF to
    process the variables. Just including a file of #<somevar># variables
    will not work.
    Your question prompted me to abandon my broken CF 6 media and
    download,
    install and configure CF7, so no beers necessary if this solution
    helps :-)

    HTH
    Aaron



    Seth MacPherson wrote:
    >
    > Hello all,
    >
    > I have some code that sends email to a list of recipients but I'm
    > having trouble and I'd love some advice.
    >
    > <cfset var campaign = GetCampaign() />
    >
    > <cfmail query="recipients"
    >
    > to="#recipients.email#"
    >
    > from="#Campaign.GetEmailFrom()# (#Campaign.GetEmailFromAlias()#)"
    >
    > subject="Campaign ## #campaign.GetCampaignID()#"
    >
    > failto="#Campaign.GetEmailFailTo()#"
    >
    > mailerid="Summit Projects, Inc. "
    >
    > type="HTML">
    >
    > #HTMLBody#
    >
    > </cfmail>
    >
    > When I execute the (above) code it works, sort of. It sends
    email just
    > as expected except for one thing, the message looks like this
    (forgive
    > the lame content – it's just test material)
    >
    > BEGIN CUSTOM FIELDS
    > #Email#
    >
    > #FirstName#
    >
    > #LastName#
    >
    > #CompanyName#
    >
    > #AddressLine1#
    >
    > #AddressLine2#
    >
    > #AddressLine3#
    >
    > #City#
    >
    > #StateProvince#
    >
    > #PostalCode#
    >
    > #Country#
    >
    > #MailFormat#
    >
    > #BLAMMO#
    >
    > #CRAMMO#
    >
    > #FLAMMO#
    >
    > #SLAMMO#
    >
    > #WHAMMO#
    >
    > As you might have guessed, the fields above are all variables that
    > need to be populated from the query but are actually the content of
    > the HTMLBody variable. After fooling around with it for a while I
    > found that using Evaluate(DE(HTMLBody)) properly replaces the CF
    > variables with the appropriate query data. Good grief. I hate using
    > Evaluate, let alone Evaluate coupled with DE.
    >
    > Can I get some advice on how I could avoid using either
    Evaluate, DE,
    > or both altogether?
    >
    > Thanks in advance.
    >
    > I shiny bottle of beer at CFUnited to the person who tackles the
    beast.
    >
    > **Seth ***MacPherson**
    > *Application Developer
    > 101.5 OAK STREET
    > HOOD RIVER, OR 97031
    > 541.387.8883x246 (w)
    > 360.241.8329 (c)
    > [EMAIL PROTECTED] <mailto:[EMAIL PROTECTED]>
    <mailto:[EMAIL PROTECTED] <mailto:[EMAIL PROTECTED]>>
    >
    > ----------------------------------------------------------
    > You are subscribed to cfcdev. To unsubscribe, send an email to
    > cfcdev@cfczone.org <mailto:cfcdev@cfczone.org> with the words
    'unsubscribe cfcdev' as the subject
    > of the email.
    >
    > CFCDev is run by CFCZone (www.cfczone.org
    <http://www.cfczone.org>) and supported by CFXHosting
    > (www.cfxhosting.com <http://www.cfxhosting.com>).
    >
    > An archive of the CFCDev list is available at
    > www.mail-archive.com/cfcdev@cfczone.org
    <http://www.mail-archive.com/cfcdev@cfczone.org>


    ----------------------------------------------------------
    You are subscribed to cfcdev. To unsubscribe, send an email to
    cfcdev@cfczone.org <mailto:cfcdev@cfczone.org> with the words
    'unsubscribe cfcdev' as the subject of the email.

    CFCDev is run by CFCZone (www.cfczone.org
    <http://www.cfczone.org>) and supported by CFXHosting (
    www.cfxhosting.com <http://www.cfxhosting.com>).

    An archive of the CFCDev list is available at
    www.mail-archive.com/cfcdev@cfczone.org
    <http://www.mail-archive.com/cfcdev@cfczone.org>



----------------------------------------------------------
You are subscribed to cfcdev. To unsubscribe, send an email to cfcdev@cfczone.org with the words 'unsubscribe cfcdev' as the subject of the email.

CFCDev is run by CFCZone (www.cfczone.org) and supported by CFXHosting (www.cfxhosting.com).

An archive of the CFCDev list is available at www.mail-archive.com/cfcdev@cfczone.org


----------------------------------------------------------
You are subscribed to cfcdev. To unsubscribe, send an email to 
cfcdev@cfczone.org with the words 'unsubscribe cfcdev' as the subject of the 
email.

CFCDev is run by CFCZone (www.cfczone.org) and supported by CFXHosting 
(www.cfxhosting.com).

An archive of the CFCDev list is available at 
www.mail-archive.com/cfcdev@cfczone.org


Reply via email to