1 # -*- coding: utf-8 -*-
2 ##############################################################################
4 # OpenERP, Open Source Management Solution
5 # Copyright (C) 2004-2010 Tiny SPRL (<http://tiny.be>)
7 # This program is free software: you can redistribute it and/or modify
8 # it under the terms of the GNU Affero General Public License as
9 # published by the Free Software Foundation, either version 3 of the
10 # License, or (at your option) any later version
12 # This program is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU Affero General Public License for more details
17 # You should have received a copy of the GNU Affero General Public License
18 # along with this program. If not, see <http://www.gnu.org/licenses/>
20 ##############################################################################
23 from random import choice
29 from openerp import addons, netsvc, tools
30 from openerp.osv import fields, osv
31 from openerp.tools.translate import _
34 class survey_send_invitation(osv.osv_memory):
35 _name = 'survey.send.invitation'
37 'partner_ids': fields.many2many('res.partner','survey_res_partner','partner_id',\
38 'survey_id', "Answer", required=1),
39 'send_mail': fields.boolean('Send Mail for New User'),
40 'send_mail_existing': fields.boolean('Send Reminder for Existing User'),
41 'mail_subject': fields.char('Subject', size=256),
42 'mail_subject_existing': fields.char('Subject', size=256),
43 'mail_from': fields.char('From', size=256, required=1),
44 'mail': fields.text('Body')
48 'send_mail': lambda *a: 1,
49 'send_mail_existing': lambda *a: 1,
53 chars = string.letters + string.digits
54 return ''.join([choice(chars) for i in range(6)])
56 def default_get(self, cr, uid, fields_list, context=None):
59 data = super(survey_send_invitation, self).default_get(cr, uid, fields_list, context)
60 survey_obj = self.pool.get('survey')
63 for sur in survey_obj.browse(cr, uid, context.get('active_ids', []), context=context):
64 name += "\n --> " + sur.title + "\n"
65 if sur.state != 'open':
66 msg += sur.title + "\n"
67 data['mail_subject'] = _("Invitation for %s") % (sur.title)
68 data['mail_subject_existing'] = _("Invitation for %s") % (sur.title)
69 data['mail_from'] = sur.responsible_id.email
71 raise osv.except_osv(_('Warning!'), _('The following surveys are not in open state: %s') % msg)
74 Would you please spent some of your time to fill-in our survey: \n%s\n
75 You can access this survey with the following parameters:
77 Your login ID: %%(login)s\n
78 Your password: %%(passwd)s\n
80 Thanks,''') % (name, self.pool.get('ir.config_parameter').get_param(cr, uid, 'web.base.url', default='http://localhost:8069', context=context))
83 def create_report(self, cr, uid, res_ids, report_name=False, file_name=False):
84 if not report_name or not res_ids:
85 return (False, Exception('Report name and Resources ids are required !!!'))
87 ret_file_name = addons.get_module_resource('survey', 'report') + file_name + '.pdf'
88 service = netsvc.LocalService(report_name);
89 (result, format) = service.create(cr, uid, res_ids, {}, {})
90 fp = open(ret_file_name, 'wb+');
94 print 'Exception in create report:',e
95 return (False, str(e))
96 return (True, ret_file_name)
99 def action_send(self, cr, uid, ids, context=None):
102 record = self.read(cr, uid, ids, [],context=context)
103 survey_ids = context.get('active_ids', [])
104 record = record and record[0]
105 partner_ids = record['partner_ids']
106 user_ref= self.pool.get('res.users')
107 survey_ref= self.pool.get('survey')
108 mail_message = self.pool.get('mail.message')
110 model_data_obj = self.pool.get('ir.model.data')
111 group_id = model_data_obj._get_id(cr, uid, 'base', 'group_survey_user')
112 group_id = model_data_obj.browse(cr, uid, group_id, context=context).res_id
114 act_id = self.pool.get('ir.actions.act_window')
115 act_id = act_id.search(cr, uid, [('res_model', '=' , 'survey.name.wiz'), \
116 ('view_type', '=', 'form')])
117 out = "login,password\n"
124 current_sur = survey_ref.browse(cr, uid, context.get('active_id'), context=context)
125 exist_user = current_sur.invited_user_ids
127 for use in exist_user:
128 new_user.append(use.id)
129 for id in survey_ref.browse(cr, uid, survey_ids):
130 report = self.create_report(cr, uid, [id.id], 'report.survey.form', id.title)
131 file = open(addons.get_module_resource('survey', 'report') + id.title +".pdf")
134 line = file.readline()
139 attachments[id.title +".pdf"] = file_data
140 os.remove(addons.get_module_resource('survey', 'report') + id.title +".pdf")
142 for partner in self.pool.get('res.partner').browse(cr, uid, partner_ids):
143 if not partner.email:
146 user = user_ref.search(cr, uid, [('login', "=", partner.email)])
148 if user[0] not in new_user:
149 new_user.append(user[0])
150 user = user_ref.browse(cr, uid, user[0])
151 user_ref.write(cr, uid, user.id, {'survey_id':[[6, 0, survey_ids]]})
152 mail = record['mail']%{'login':partner.email, 'passwd':user.password, \
153 'name' : partner.name}
154 if record['send_mail_existing']:
157 'subject': record['mail_subject_existing'],
158 'body_html': '<pre>%s</pre>' % mail,
159 'email_to': partner.email,
160 'email_from': record['mail_from'],
162 self.pool.get('mail.mail').create(cr, uid, vals, context=context)
163 existing+= "- %s (Login: %s, Password: %s)\n" % (user.name, partner.email, \
167 passwd= self.genpasswd()
168 out+= partner.email + ',' + passwd + '\n'
169 mail= record['mail'] % {'login' : partner.email, 'passwd' : passwd, 'name' : partner.name}
170 if record['send_mail']:
173 'subject': record['mail_subject'],
174 'body_html': '<pre>%s</pre>' % mail,
175 'email_to': partner.email,
176 'email_from': record['mail_from'],
179 vals['attachment_ids'] = [(0,0,{'name': a_name,
180 'datas_fname': a_name,
181 'datas': str(a_content).encode('base64')})
182 for a_name, a_content in attachments.items()]
183 ans = self.pool.get('mail.mail').create(cr, uid, vals, context=context)
185 res_data = {'name': partner.name or _('Unknown'),
186 'login': partner.email,
188 'address_id': partner.id,
189 'groups_id': [[6, 0, [group_id]]],
190 'action_id': act_id[0],
191 'survey_id': [[6, 0, survey_ids]]
193 user = user_ref.create(cr, uid, res_data)
194 if user not in new_user:
195 new_user.append(user)
196 created+= "- %s (Login: %s, Password: %s)\n" % (partner.name or _('Unknown'),\
197 partner.email, passwd)
199 error+= "- %s (Login: %s, Password: %s)\n" % (partner.name or _('Unknown'),\
200 partner.email, passwd)
203 new_vals.update({'invited_user_ids':[[6,0,new_user]]})
204 survey_ref.write(cr, uid, context.get('active_id'),new_vals)
207 note += 'Created users:\n%s\n\n' % (created)
209 note +='Already existing users:\n%s\n\n' % (existing)
211 note += "%d contacts where ignored (an email address is missing).\n\n" % (skipped)
213 note += 'Email not send successfully:\n====================\n%s\n' % (error)
214 context.update({'note' : note})
218 'res_model': 'survey.send.invitation.log',
219 'type': 'ir.actions.act_window',
223 survey_send_invitation()
225 class survey_send_invitation_log(osv.osv_memory):
226 _name = 'survey.send.invitation.log'
228 'note' : fields.text('Log', readonly=1)
231 def default_get(self, cr, uid, fields_list, context=None):
234 data = super(survey_send_invitation_log, self).default_get(cr, uid, fields_list, context)
235 data['note'] = context.get('note', '')
238 survey_send_invitation_log()
240 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: