Textpattern CMS support forum
You are not logged in. Register | Login | Help
- Topics: Active | Unanswered
#1 2015-05-12 05:26:22
- dorka
- Member
- Registered: 2012-10-04
- Posts: 90
[REQUEST] Add file upload to contact form
Hi, I am not a developer so I am not sure if I am entitled to place my wish in this list, but it is the best place I found.
I need an extention to zem_contact_reborn enabeling (perhaps with the help of mem_form) sending attachment to a mail recipient via contact form.
I will be glad to commission this work to someone. Only I need help estimating the budget. Thanks.
Offline
Re: [REQUEST] Add file upload to contact form
dorka wrote #290663:
I need an extention to zem_contact_reborn enabeling (perhaps with the help of mem_form) sending attachment to a mail recipient via contact form.
The new in-development zem_contact_reborn ought to be able to handle this with a module (plug-in). It would probably offer:
- A tag for inserting a file input box (although you might be able to use
<txp:zem_contact_text type="file" />
, it’d be better to have a dedicated tag so it could check file size limits and permit only certain mime types, etc). - A mechanism for receiving the file, encoding it and adding the appropriate headers to the mail message, then returning the bundle to ZCR to do the mailing process.
The latter could either be done on submit, or using a jQuery uploader plugin which transmits the file via AJAX in the background like Gmail does. The submit handler is simpler, but less user friendly. The AJAX method is sexier, a lot more involved code-wise, and possibly with more potential to clutter your file system with part-finished uploaded files from bots using the contact form. Not really thought it through fully.
I could certainly try and knock up a module to see how well it works.
btw, although tempting, I’d shy away from permitting multi-file uploads. If people really want to send you many files, they can zip them up.
mem_form would work as an alternative, but, well it’s mem_form so the documentation is fun to decipher. Not sure if it’s possible to integrate the two plugins or you’d have to use it in lieu of ZCR.
The smd plugin menagerie — for when you need one more gribble of power from Textpattern. Bleeding-edge code available on GitHub.
Txp Builders – finely-crafted code, design and Txp
Offline
#3 2015-05-13 08:02:44
- dorka
- Member
- Registered: 2012-10-04
- Posts: 90
Re: [REQUEST] Add file upload to contact form
Hi Bloke,
thank you, that will be great!
if I get it right, there are two steps involved:
1. releasing the new version of ZCR
2. writing the module that will handle the file submition – the one you write about.
I surfed around a bit to find out how far is the new ZCR from launch, but didn’find much. Is there someone out there who knows? Ruud probably?
And is there something I can do to motivate you guys to spare your little time and big skills to this little gadget?
Offline
Re: [REQUEST] Add file upload to contact form
dorka wrote #290707:
I surfed around a bit to find out how far is the new ZCR from launch, but didn’find much. Is there someone out there who knows? Ruud probably?
No, that would be bloke/stef
Offline
Re: [REQUEST] Add file upload to contact form
dorka wrote #290707:
how far is the new ZCR from launch
It’s basically done but I have one pending bug report to chase down when I get a moment.
is there something I can do to motivate you guys to spare your little time and big skills to this little gadget?
Let me know how you’d prefer it to work (AJAX or on-submit) and I’ll see what I can do.
The smd plugin menagerie — for when you need one more gribble of power from Textpattern. Bleeding-edge code available on GitHub.
Txp Builders – finely-crafted code, design and Txp
Offline
#6 2015-05-13 11:21:46
- dorka
- Member
- Registered: 2012-10-04
- Posts: 90
Re: [REQUEST] Add file upload to contact form
On submit is just fine.
I suppose when you say “on submit” you mean that the upload of the file starts when the user submits the entire mail. I am thinking of a solution when you can upload the file with separate command and submit the entire mail afterwards: Choose file > Upload file > Submit mail. This will prevent interrupting the upload by clicking away. Or is this solved otherwise?
Offline
Re: [REQUEST] Add file upload to contact form
dorka wrote #290719:
when you say “on submit” you mean that the upload of the file starts when the user submits the entire mail.
Yes, nothing is done until the user clicks Send
.
The alternative is to do like Gmail and other mail clients, whereby the moment you select a file it begins uploading in the background, then gets attached at Send time. That’s a lot more work because it requires public-side AJAX / jQuery code.
Things we need to do under this approach:
- Prevent form submission until the upload has finished, which requires signalling.
- Check only one file is uploaded per mail (which seems reasonable given that zip exists).
- Tie the uploaded file (dangling in some server-based no-mans-land temp directory) to the mail.
- Ensure any used, unused, partially-uploaded, broken, or dangerous files are purged to avoid cluttering the file system of the server.
Since the default upload place is a temporary folder and Textpattern ships with this tmp
folder publicly accessible, there’s a chance that someone could upload a script or some payload which would be runnable from any browser. In theory of course. That might not be a legitimate concern if the system temp folder is used, I’m not sure without trying it.
The smd plugin menagerie — for when you need one more gribble of power from Textpattern. Bleeding-edge code available on GitHub.
Txp Builders – finely-crafted code, design and Txp
Offline
#8 2015-05-13 11:51:48
- dorka
- Member
- Registered: 2012-10-04
- Posts: 90
Re: [REQUEST] Add file upload to contact form
How about sticking to the first option, but uploding manualy with a separate command as I wrote above?
Offline
#9 2015-05-13 11:55:02
- dorka
- Member
- Registered: 2012-10-04
- Posts: 90
Re: [REQUEST] Add file upload to contact form
I guess the issue with publicly acsessible tmp folder is irrelevant to the process of uploading we chose. Am I right?
Offline
Re: [REQUEST] Add file upload to contact form
dorka wrote #290725:
How about sticking to the first option, but uploding manualy with a separate command as I wrote above?
Not entirely sure how to get that to work.
ZCR uses the first pass (displaying the form) to configure itself to know what to expect later, and then the second pass (on submission) validates form inputs and checks no violations have taken place. So it needs to “know” in advance to expect the file. EDIT: Maybe if it was a discrete process, and always executed first, we could somehow write a hidden or secret field to the form to indicate which file the mail should attach. Kind of inconvenient if someone decides on a whim to add a file after they’ve started typing though…
dorka wrote #290726:
I guess the issue with publicly acsessible tmp folder is irrelevant to the process of uploading we chose. Am I right?
Yeah. It’s probably of little concern as PHP will most likely use the system tmp directory.
Note to self: find a way to bust this conversation away from the sticky topic in which it resides as it’s kind of off-topic!
Last edited by Bloke (2015-05-13 12:04:08)
The smd plugin menagerie — for when you need one more gribble of power from Textpattern. Bleeding-edge code available on GitHub.
Txp Builders – finely-crafted code, design and Txp
Offline
Re: [REQUEST] Add file upload to contact form
Bloke wrote #290721:
Since the default upload place is a temporary folder and Textpattern ships with this
tmp
folder publicly accessible…
I always move that below the root of the site as I hope that it boost’s the site’s security
Yiannis
——————————
NeMe | hblack.art | EMAP | A Sea change | Toolkit of Care
I do my best editing after I click on the submit button.
Offline
#12 2015-05-13 12:16:58
- dorka
- Member
- Registered: 2012-10-04
- Posts: 90
Re: [REQUEST] Add file upload to contact form
Ok, I see I understand too little to be a good partner in this decision. I guess I am fine with On submit option, but if you decide AJAX would appeal to more users and will take longer before refactoring becomes absolutely necessary, I won’t argue.
Offline