[FIX] website_forum: post edition working again
[odoo/odoo.git] / addons / website_event / controllers / main.py
1 # -*- coding: utf-8 -*-
2 ##############################################################################
3 #
4 #    OpenERP, Open Source Management Solution
5 #    Copyright (C) 2013-Today OpenERP SA (<http://www.openerp.com>).
6 #
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.
11 #
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.
16 #
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/>.
19 #
20 ##############################################################################
21
22 from openerp import SUPERUSER_ID
23 from openerp.addons.web import http
24 from openerp.addons.web.http import request
25 from openerp.tools.translate import _
26 from openerp.addons.website.controllers.main import Website as controllers
27 controllers = controllers()
28
29 import logging
30 _logger = logging.getLogger(__name__)
31
32 from datetime import datetime, timedelta
33 import time
34 from dateutil.relativedelta import relativedelta
35 from openerp import tools
36 import werkzeug.urls
37
38 try:
39     import GeoIP
40 except ImportError:
41     GeoIP = None
42     _logger.warn("Please install GeoIP python module to use events localisation.")
43
44 class website_event(http.Controller):
45     @http.route(['/event', '/event/page/<int:page>'], type='http', auth="public", website=True, multilang=True)
46     def events(self, page=1, **searches):
47         cr, uid, context = request.cr, request.uid, request.context
48         event_obj = request.registry['event.event']
49         type_obj = request.registry['event.type']
50         country_obj = request.registry['res.country']
51
52         searches.setdefault('date', 'all')
53         searches.setdefault('type', 'all')
54         searches.setdefault('country', 'all')
55
56         domain_search = {}
57
58         def sdn(date):
59             return date.strftime('%Y-%m-%d 23:59:59')
60         def sd(date):
61             return date.strftime(tools.DEFAULT_SERVER_DATETIME_FORMAT)
62         today = datetime.today()
63         dates = [
64             ['all', _('Next Events'), [("date_end", ">", sd(today))], 0],
65             ['today', _('Today'), [
66                 ("date_end", ">", sd(today)),
67                 ("date_begin", "<", sdn(today))],
68                 0],
69             ['week', _('This Week'), [
70                 ("date_end", ">=", sd(today + relativedelta(days=-today.weekday()))),
71                 ("date_begin", "<", sdn(today  + relativedelta(days=6-today.weekday())))],
72                 0],
73             ['nextweek', _('Next Week'), [
74                 ("date_end", ">=", sd(today + relativedelta(days=7-today.weekday()))),
75                 ("date_begin", "<", sdn(today  + relativedelta(days=13-today.weekday())))],
76                 0],
77             ['month', _('This month'), [
78                 ("date_end", ">=", sd(today.replace(day=1))),
79                 ("date_begin", "<", (today.replace(day=1) + relativedelta(months=1)).strftime('%Y-%m-%d 00:00:00'))],
80                 0],
81             ['nextmonth', _('Next month'), [
82                 ("date_end", ">=", sd(today.replace(day=1) + relativedelta(months=1))),
83                 ("date_begin", "<", (today.replace(day=1)  + relativedelta(months=2)).strftime('%Y-%m-%d 00:00:00'))],
84                 0],
85             ['old', _('Old Events'), [
86                 ("date_end", "<", today.strftime('%Y-%m-%d 00:00:00'))],
87                 0],
88         ]
89
90         # search domains
91         current_date = None
92         current_type = None
93         current_country = None
94         for date in dates:
95             if searches["date"] == date[0]:
96                 domain_search["date"] = date[2]
97                 if date[0] != 'all':
98                     current_date = date[1]
99         if searches["type"] != 'all':
100             current_type = type_obj.browse(cr, uid, int(searches['type']), context=context)
101             domain_search["type"] = [("type", "=", int(searches["type"]))]
102         if searches["country"] != 'all':
103             current_country = country_obj.browse(cr, uid, int(searches['country']), context=context)
104             domain_search["country"] = [("country_id", "=", int(searches["country"]))]
105
106         def dom_without(without):
107             domain = [('state', "in", ['draft','confirm','done'])]
108             for key, search in domain_search.items():
109                 if key != without:
110                     domain += search
111             return domain
112
113         # count by domains without self search
114         for date in dates:
115             if date[0] <> 'old':
116                 date[3] = event_obj.search(
117                     request.cr, request.uid, dom_without('date') + date[2],
118                     count=True, context=request.context)
119
120         domain = dom_without('type')
121         types = event_obj.read_group(
122             request.cr, request.uid, domain, ["id", "type"], groupby="type",
123             orderby="type", context=request.context)
124         type_count = event_obj.search(request.cr, request.uid, domain,
125                                       count=True, context=request.context)
126         types.insert(0, {
127             'type_count': type_count,
128             'type': ("all", _("All Categories"))
129         })
130
131         domain = dom_without('country')
132         countries = event_obj.read_group(
133             request.cr, request.uid, domain, ["id", "country_id"],
134             groupby="country_id", orderby="country_id", context=request.context)
135         country_id_count = event_obj.search(request.cr, request.uid, domain,
136                                             count=True, context=request.context)
137         countries.insert(0, {
138             'country_id_count': country_id_count,
139             'country_id': ("all", _("All Countries"))
140         })
141
142         step = 5
143         event_count = event_obj.search(
144             request.cr, request.uid, dom_without("none"), count=True,
145             context=request.context)
146         pager = request.website.pager(url="/event", total=event_count, page=page, step=step, scope=5)
147
148         order = 'website_published desc, date_begin'
149         if searches.get('date','all') == 'old':
150             order = 'website_published desc, date_begin desc'
151         obj_ids = event_obj.search(
152             request.cr, request.uid, dom_without("none"), limit=step,
153             offset=pager['offset'], order=order, context=request.context)
154         events_ids = event_obj.browse(request.cr, request.uid, obj_ids,
155                                       context=request.context)
156
157         values = {
158             'current_date': current_date,
159             'current_country': current_country,
160             'current_type': current_type,
161             'event_ids': events_ids,
162             'dates': dates,
163             'types': types,
164             'countries': countries,
165             'pager': pager,
166             'searches': searches,
167             'search_path': "?%s" % werkzeug.url_encode(searches),
168         }
169
170         return request.website.render("website_event.index", values)
171
172     @http.route(['/event/<model("event.event"):event>/page/<page:page>'], type='http', auth="public", website=True, multilang=True)
173     def event_page(self, event, page, **post):
174         values = {
175             'event': event,
176             'main_object': event
177         }
178         return request.website.render(page, values)
179
180     @http.route(['/event/<model("event.event"):event>'], type='http', auth="public", website=True, multilang=True)
181     def event(self, event, **post):
182         if event.menu_id and event.menu_id.child_id:
183             target_url = event.menu_id.child_id[0].url
184         else:
185             target_url = '/event/%s/register' % str(event.id)
186         if post.get('enable_editor') == '1':
187             target_url += '?enable_editor=1'
188         return request.redirect(target_url);
189
190     @http.route(['/event/<model("event.event"):event>/register'], type='http', auth="public", website=True, multilang=True)
191     def event_register(self, event, **post):
192         values = {
193             'event': event,
194             'main_object': event,
195             'range': range,
196         }
197         return request.website.render("website_event.event_description_full", values)
198
199     @http.route('/event/add_event', type='http', auth="user", multilang=True, methods=['POST'], website=True)
200     def add_event(self, event_name="New Event", **kwargs):
201         return self._add_event(event_name, request.context, **kwargs)
202
203     def _add_event(self, event_name=None, context={}, **kwargs):
204         if not event_name:
205             event_name = _("New Event")
206         Event = request.registry.get('event.event')
207         date_begin = datetime.today() + timedelta(days=(14))
208         vals = {
209             'name': event_name,
210             'date_begin': date_begin.strftime('%Y-%m-%d'),
211             'date_end': (date_begin + timedelta(days=(1))).strftime('%Y-%m-%d'),
212         }
213         event_id = Event.create(request.cr, request.uid, vals, context=context)
214         return request.redirect("/event/%s?enable_editor=1" % event_id)
215
216     def get_visitors_country(self):
217         GI = GeoIP.open('/usr/share/GeoIP/GeoIP.dat', 0)
218         return {'country_code': GI.country_code_by_addr(request.httprequest.remote_addr), 'country_name': GI.country_name_by_addr(request.httprequest.remote_addr)}
219     
220     def get_formated_date(self, event):
221         start_date = datetime.strptime(event.date_begin, tools.DEFAULT_SERVER_DATETIME_FORMAT).date()
222         end_date = datetime.strptime(event.date_end, tools.DEFAULT_SERVER_DATETIME_FORMAT).date()
223         return ('%s %s%s') % (start_date.strftime("%b"), start_date.strftime("%e"), (end_date != start_date and ("-"+end_date.strftime("%e")) or ""))
224     
225     @http.route('/event/get_country_event_list', type='http', auth='public', website=True)
226     def get_country_events(self ,**post):
227         if not GeoIP:
228             return ""
229         country_obj = request.registry['res.country']
230         event_obj = request.registry['event.event']
231         cr, uid, context,event_ids = request.cr, request.uid, request.context,[]
232         country_code = self.get_visitors_country()['country_code']
233         result = {'events':[],'country':False}
234         if country_code:
235             country_ids = country_obj.search(request.cr, request.uid, [('code', '=', country_code)], context=request.context)
236             event_ids = event_obj.search(request.cr, request.uid, ['|', ('address_id', '=', None),('country_id.code', '=', country_code),('date_begin','>=', time.strftime('%Y-%m-%d 00:00:00')),('state', '=', 'confirm')], order="date_begin", context=request.context)
237         if not event_ids:
238             event_ids = event_obj.search(request.cr, request.uid, [('date_begin','>=', time.strftime('%Y-%m-%d 00:00:00')),('state', '=', 'confirm')], order="date_begin", context=request.context)
239         for event in event_obj.browse(request.cr, request.uid, event_ids, context=request.context)[:6]:
240             if country_code and event.country_id.code == country_code:
241                 result['country'] = country_obj.browse(request.cr, request.uid, country_ids[0], context=request.context)
242             result['events'].append({
243                  "date": self.get_formated_date(event),
244                  "event": event,
245                  "url": event.website_url})
246         return request.website.render("website_event.country_events_list",result)