Skip to content

Commit

Permalink
shopinvader: store last_login_time
Browse files Browse the repository at this point in the history
Simply store the last login timestamp when /sign_in is called.
  • Loading branch information
simahawk committed May 14, 2024
1 parent 4bc85c3 commit 4b9720a
Show file tree
Hide file tree
Showing 6 changed files with 30 additions and 2 deletions.
2 changes: 1 addition & 1 deletion shopinvader/__manifest__.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
{
"name": "Shopinvader",
"summary": "Shopinvader",
"version": "14.0.5.24.12",
"version": "14.0.5.25.0",
"category": "e-commerce",
"website": "https://github.com/shopinvader/odoo-shopinvader",
"author": "Akretion",
Expand Down
11 changes: 11 additions & 0 deletions shopinvader/migrations/14.0.5.25.0/pre-migrate.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# Copyright 2022 ACSONE SA/NV (<http://acsone.eu>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).

from odoo.tools import sql


def migrate(cr, version):
if not version or sql.column_exists(cr, "shopinvader_partner", "last_login_time"):
return
# Pre-create new column
sql.create_column(cr, "shopinvader_partner", "last_login_time", "timestamp")
1 change: 1 addition & 0 deletions shopinvader/models/shopinvader_partner.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ class ShopinvaderPartner(models.Model):
# Having the same field on both models allows to use simple conditions to check.
# The compute methods offers a hook to modify the behavior.
is_shopinvader_active = fields.Boolean(compute="_compute_is_shopinvader_active")
last_login_time = fields.Datetime()

def _compute_is_shopinvader_active_depends(self):
return ()
Expand Down
3 changes: 2 additions & 1 deletion shopinvader/services/customer.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
# Simone Orsi <simone.orsi@camptocamp.com>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
# pylint: disable=consider-merging-classes-inherited,method-required-super
from odoo import _
from odoo import _, fields
from odoo.exceptions import UserError

from odoo.addons.component.core import Component
Expand Down Expand Up @@ -56,6 +56,7 @@ def update(self, _id, **params):
return self.get()

def sign_in(self, **params):
self.invader_partner.last_login_time = fields.Datetime.now()
return self._assign_cart_and_get_store_cache()

# The following method are 'private' and should be never never NEVER call
Expand Down
2 changes: 2 additions & 0 deletions shopinvader/tests/test_customer.py
Original file line number Diff line number Diff line change
Expand Up @@ -110,8 +110,10 @@ def test_sign_in_no_create_cart(self):
SaleOrder.search(sale_domain).unlink()

invader_partner = partner._get_invader_partner(self.backend)
self.assertFalse(invader_partner.last_login_time)
self.service._load_partner_work_context(invader_partner)
self.service.sign_in()
self.assertTrue(invader_partner.last_login_time)
self.assertFalse(SaleOrder.search(sale_domain))

def test_update_customer(self):
Expand Down
13 changes: 13 additions & 0 deletions shopinvader/views/shopinvader_partner_view.xml
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@
optional="show"
/>
<field name="sync_date" />
<field name="last_login_time" />
</tree>
</field>
</record>
Expand Down Expand Up @@ -84,6 +85,18 @@
context="{'group_by':'parent_id'}"
/>
</group>
<group string="Login time">
<filter
name="filter_login_never"
string="Never logged-in"
domain="[('last_login_time', '=', False)]"
/>
<filter
name="filter_login_last_month"
string="No login in a month"
domain="[('last_login_time', '&lt;=', (context_today() + relativedelta(months=-1)).strftime('%Y-%m-%d'))]"
/>
</group>
</search>
</field>
</record>
Expand Down

0 comments on commit 4b9720a

Please sign in to comment.