[Mailman-Users] add_members and email confirmation

Ren Bucholz ren at trubble.com
Sat Dec 10 21:45:29 CET 2005


Mark is officially awesome.  This works, and now my list can be 
confirmed-opt-in.  Thanks sooooo much!

-Ren

PS - If you want to see the final, working replacement for Add_Members, 
you can get it here:
   http://trubble.com/miscellaneous/new_add_members.txt

On Dec 10, 2005, at 2:43 PM, Mark Sapiro wrote:

> Ren Bucholz wrote:
>>
>> I'm still having a problem with the confirmations, however.  To recap,
>> I'm trying to use a modified version of add_members (call it
>> new_add_members) in order to subscribe people via my own webform 
>> (where
>> PHP executes add_members).  I modified it because I'd like the list to
>> be confirmed opt-in, but add_members assumes that the user has
>> confirmed their subscription and doesn't bother with the confirmation
>> message. There's a longer description of what I did in this list's
>> archives, if you're interested:
>>   http://www.mail-archive.com/mailman-users@python.org/msg35077.html
>>
>> The problem is that this script totally breaks Mailman's web
>> subscription features.  The first time I run new_add_members, I get a
>> seemingly normal looking confirmation.  Upon clicking the confirmation
>> link, I get the Mailman's generic "Sorry, We Hit A Bug!" message.  And
>> from that point forward, attempting to subscribe via the list's
>> standard Mailman info page (foo.com/mailman/listinfo/your_list)
>> generates the same error.  You can still subscribe by calling the
>> unmodified add_members.  The error logs say:
>>
>> admin(32487): [----- Mailman Version: 2.1.5 -----]
>> admin(32487): [----- Traceback ------]
>> admin(32487): Traceback (most recent call last):
>> admin(32487):   File "/usr/lib/mailman/scripts/driver", line 101, in
>> run_main
>> admin(32487):     main()
>> admin(32487):   File "/usr/lib/mailman/Mailman/Cgi/subscribe.py", line
>> 96, in main
>> admin(32487):     process_form(mlist, doc, cgidata, language)
>> admin(32487):   File "/usr/lib/mailman/Mailman/Cgi/subscribe.py", line
>> 176, in process_form
>> admin(32487):     mlist.AddMember(userdesc, remote)
>> admin(32487):   File "/usr/lib/mailman/Mailman/MailList.py", line 854,
>> in AddMember
>> admin(32487):     cookie = self.pend_new(Pending.SUBSCRIPTION, 
>> userdesc)
>> admin(32487):   File "/usr/lib/mailman/Mailman/Pending.py", line 65, 
>> in
>> pend_new
>> admin(32487):     db = self.__load()
>> admin(32487):   File "/usr/lib/mailman/Mailman/Pending.py", line 95, 
>> in
>> __load
>> admin(32487):     return cPickle.load(fp)
>> admin(32487): AttributeError: 'module' object has no attribute
>> 'UserDesc'
> <snip>
>
>> If anyone has any idea how to fix this, I'd be most appreciative.  I
>> should also mention that error isn't limited to a single address -
>> subscribing me at fake.com via new_add_members will cause a web
>> subscription for you at fake.com to fail. Thanks for reading this far!
>
>
> At this point, lists/listname/pending.pck is corrupt and has to be
> removed for normal stuff to proceed.
>
> The underlying problem is new_members defines the UserDesc class to be
> empty, thus when you call
>
> mlist.AddMember(userdesc, remote="Webpage")
>
> userdesc is not a valid UserDesc instance for AddMember which is where
> things go wrong.
>
> I think you need to do the following in your script.
>
> Add
>
> from Mailman.UserDesc import UserDesc
>
> Remove
>
> class UserDesc: pass
>
> It looks like that's all you need, but I haven't looked too thoroughly.
>
> -- 
> Mark Sapiro <msapiro at value.net>       The highway is for gamblers,
> San Francisco Bay Area, California    better use your sense - B. Dylan
>




More information about the Mailman-Users mailing list