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 osv import fields
32 from tools.translate import _
37 class survey_send_invitation(osv.osv_memory):
38 _name = 'survey.send.invitation'
40 'partner_ids': fields.many2many('res.partner','survey_res_partner','partner_id',\
41 'survey_id', "Answer", required=1),
42 'send_mail': fields.boolean('Send Mail for New User'),
43 'send_mail_existing': fields.boolean('Send Reminder for Existing User'),
44 'mail_subject': fields.char('Subject', size=256),
45 'mail_subject_existing': fields.char('Subject', size=256),
46 'mail_from': fields.char('From', size=256, required=1),
47 'mail': fields.text('Body')
51 'send_mail': lambda *a: 1,
52 'send_mail_existing': lambda *a: 1,
53 'mail_subject': lambda *a: "Invitation",
54 'mail_subject_existing': lambda *a: "Invitation",
55 'mail_from': lambda *a: tools.config['email_from']
59 chars = string.letters + string.digits
60 return ''.join([choice(chars) for i in range(6)])
62 def default_get(self, cr, uid, fields_list, context=None):
65 data = super(survey_send_invitation, self).default_get(cr, uid, fields_list, context)
66 survey_obj = self.pool.get('survey')
69 for sur in survey_obj.browse(cr, uid, context.get('active_ids', []), context=context):
70 name += "\t --> " + sur.title + "\n"
71 if sur.state != 'open':
72 msg += sur.title + "\n"
74 raise osv.except_osv(_('Warning!'), _('%sSurvey is not in open state') % msg)
75 data['mail'] = '''Hello %(name)s, \n\n We are inviting you for following survey. \
76 \n ''' + name + '''\n Your login ID: %(login)s, Your password: %(passwd)s
77 \n link :- http://'''+ str(socket.gethostname()) + ''':8080 \n\n Thanks,'''
80 def create_report(self, cr, uid, res_ids, report_name=False, file_name=False):
81 if not report_name or not res_ids:
82 return (False, Exception('Report name and Resources ids are required !!!'))
84 ret_file_name = addons.get_module_resource('survey', 'report') + file_name + '.pdf'
85 service = netsvc.LocalService(report_name);
86 (result, format) = service.create(cr, uid, res_ids, {}, {})
87 fp = open(ret_file_name, 'wb+');
91 print 'Exception in create report:',e
92 return (False, str(e))
93 return (True, ret_file_name)
96 def action_send(self, cr, uid, ids, context=None):
99 record = self.read(cr, uid, ids, [],context=context)
100 survey_ids = context.get('active_ids', [])
101 record = record and record[0]
102 partner_ids = record['partner_ids']
103 user_ref= self.pool.get('res.users')
104 survey_ref= self.pool.get('survey')
105 mail_message = self.pool.get('mail.message')
107 model_data_obj = self.pool.get('ir.model.data')
108 group_id = model_data_obj._get_id(cr, uid, 'base', 'group_survey_user')
109 group_id = model_data_obj.browse(cr, uid, group_id, context=context).res_id
111 act_id = self.pool.get('ir.actions.act_window')
112 act_id = act_id.search(cr, uid, [('res_model', '=' , 'survey.name.wiz'), \
113 ('view_type', '=', 'form')])
114 out = "login,password\n"
122 current_sur = survey_ref.browse(cr, uid, context.get('active_id'), context=context)
123 exist_user = current_sur.invited_user_ids
125 for use in exist_user:
126 new_user.append(use.id)
127 for id in survey_ref.browse(cr, uid, survey_ids):
128 report = self.create_report(cr, uid, [id.id], 'report.survey.form', id.title)
129 file = open(addons.get_module_resource('survey', 'report') + id.title +".pdf")
132 line = file.readline()
137 attachments[id.title +".pdf"] = file_data
138 os.remove(addons.get_module_resource('survey', 'report') + id.title +".pdf")
140 for partner in self.pool.get('res.partner').browse(cr, uid, partner_ids):
141 if not partner.email:
144 user = user_ref.search(cr, uid, [('login', "=", partner.email)])
146 if user[0] not in new_user:
147 new_user.append(user[0])
148 user = user_ref.browse(cr, uid, user[0])
149 user_ref.write(cr, uid, user.id, {'survey_id':[[6, 0, survey_ids]]})
150 mail = record['mail']%{'login':partner.email, 'passwd':user.password, \
151 'name' : partner.name}
152 if record['send_mail_existing']:
153 mail_message.schedule_with_attach(cr, uid, record['mail_from'], [partner.email] , \
154 record['mail_subject_existing'] , mail, context=context)
155 existing+= "- %s (Login: %s, Password: %s)\n" % (user.name, partner.email, \
159 passwd= self.genpasswd()
160 out+= partner.email + ',' + passwd + '\n'
161 mail= record['mail'] % {'login' : partner.email, 'passwd' : passwd, 'name' : partner.name}
162 if record['send_mail']:
163 ans = mail_message.schedule_with_attach(cr, uid, record['mail_from'], [partner.email], \
164 record['mail_subject'], mail, attachments=attachments, context=context)
166 res_data = {'name': partner.name or _('Unknown'),
167 'login': partner.email,
169 'address_id': partner.id,
170 'groups_id': [[6, 0, [group_id]]],
171 'action_id': act_id[0],
172 'survey_id': [[6, 0, survey_ids]]
174 user = user_ref.create(cr, uid, res_data)
175 if user not in new_user:
176 new_user.append(user)
177 created+= "- %s (Login: %s, Password: %s)\n" % (partner.name or _('Unknown'),\
178 partner.email, passwd)
180 error+= "- %s (Login: %s, Password: %s)\n" % (partner.name or _('Unknown'),\
181 partner.email, passwd)
184 new_vals.update({'invited_user_ids':[[6,0,new_user]]})
185 survey_ref.write(cr, uid, context.get('active_id'),new_vals)
188 note += 'Created users:\n%s\n\n' % (created)
190 note +='Already existing users:\n%s\n\n' % (existing)
192 note += "%d contacts where ignored (an email address is missing).\n\n" % (skipped)
194 note += 'Email not send successfully:\n====================\n%s\n' % (error)
195 context.update({'note' : note})
199 'res_model': 'survey.send.invitation.log',
200 'type': 'ir.actions.act_window',
204 survey_send_invitation()
206 class survey_send_invitation_log(osv.osv_memory):
207 _name = 'survey.send.invitation.log'
209 'note' : fields.text('Log', readonly=1)
212 def default_get(self, cr, uid, fields_list, context=None):
215 data = super(survey_send_invitation_log, self).default_get(cr, uid, fields_list, context)
216 data['note'] = context.get('note', '')
219 survey_send_invitation_log()
221 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: