Přejít na obsah
Odoo Menu
  • Přihlásit se
  • Vyzkoušejte zdarma
  • Aplikace
    Finance
    • Účetnictví
    • Fakturace
    • Výdaje
    • Spreadsheet (BI)
    • Dokumenty
    • Podpisy
    Prodej
    • CRM
    • Prodej
    • POS Obchod
    • POS Restaurace
    • Předplatné
    • Pronájem
    Webové stránky
    • Webové stránky
    • E-shop
    • Blog
    • Fórum
    • Živý chat
    • eLearning
    Dodavatelský řetězec
    • Sklad
    • Výroba
    • PLM
    • Nákup
    • Údržba
    • Kvalita
    Lidské zdroje
    • Zaměstnanci
    • Nábor
    • Volno
    • Hodnocení zaměstnanců
    • Doporučení
    • Vozový park
    Marketing
    • Marketing sociálních sítí
    • Emailový marketing
    • SMS Marketing
    • Události
    • Marketingová automatizace
    • Dotazníky
    Služby
    • Projekt
    • Časové výkazy
    • Práce v terénu
    • Helpdesk
    • Plánování
    • Schůzky
    Produktivita
    • Diskuze
    • Schvalování
    • IoT
    • VoIP
    • Znalosti
    • WhatsApp
    Aplikace třetích stran Odoo Studio Odoo cloudová platforma
  • Branže
    Maloobchod
    • Knihkupectví
    • Obchod s oblečením
    • Obchod s nábytkem
    • Potraviny
    • Obchod s hardwarem
    • Hračkářství
    Jídlo a pohostinství
    • Bar a Pub
    • Restaurace
    • Fast Food
    • Penzion
    • Distributor nápojů
    • Hotel
    Nemovitost
    • Realitní kancelář
    • Architektonická firma
    • Stavba
    • Správa nemovitostí
    • Zahradnictví
    • Asociace vlastníků nemovitosti
    Poradenství
    • Účetní firma
    • Odoo Partner
    • Marketingová agentura
    • Právník
    • Akvizice talentů
    • Audit a certifikace
    Výroba
    • Textil
    • Kov
    • Nábytek
    • Jídlo
    • Pivovar
    • Korporátní dárky
    Zdraví a fitness
    • Sportovní klub
    • Prodejna brýli
    • Fitness Centrum
    • Wellness praktikové
    • Lékárna
    • Kadeřnictví
    Transakce
    • Údržbář
    • Podpora IT & hardware
    • Systémy solární energie
    • Výrobce obuvi
    • Úklidové služby
    • Služby HVAC
    Ostatní
    • Nezisková organizace
    • Agentura pro životní prostředí
    • Pronájem billboardů
    • Fotografování
    • Leasing jízdních kol
    • Prodejce softwaru
    Procházet všechna odvětví
  • Komunita
    Edukační program
    • Tutoriály
    • Dokumentace
    • Certifikace
    • Vzdělávání
    • Blog
    • Podcast
    Podpora vzdělávání
    • Vzdělávací program
    • Scale Up! Hra na firmu
    • Navštivte Odoo
    Získat software
    • Stáhnout
    • Porovnejte edice
    • Verze
    Spolupráce
    • Github
    • Fórum
    • Události
    • Překlady
    • Stát se partnerem
    • Služby pro partnery
    • Registrujte svou účetní firmu
    Získat služby
    • Najít partnera
    • Najít účetní
    • Setkejte se s poradcem
    • Implementační služby
    • Zákaznické reference
    • Podpora
    • Upgrady
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Dohodnout demo
  • Ceník
  • Pomoc

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Účetnictví
  • Sklad
  • PoS
  • Projekty
  • MRP
All apps
You need to be registered to interact with the community.
All Posts Lidé Odznaky
Štítky (View all)
odoo accounting v14 pos v15
O tomto fóru
You need to be registered to interact with the community.
All Posts Lidé Odznaky
Štítky (View all)
odoo accounting v14 pos v15
O tomto fóru
Pomoc

Payroll and leaves problem - "AttributeError: 'bool' object has no attribute 'upper'" when an employee register vacation

Odebírat

Get notified when there's activity on this post

This question has been flagged
errorpayrollleavesodoo11
1 Odpovědět
9840 Zobrazení
Avatar
Carlos Wong

I have create contracts and everything is setup for payroll. It works fine, but when an employee register vacation it failed with this error:


Error:

Odoo Server Error

Traceback (most recent call last):

  File "/odoo/odoo-server/odoo/http.py", line 646, in _handle_exception

    return super(JsonRequest, self)._handle_exception(exception)

  File "/odoo/odoo-server/odoo/http.py", line 307, in _handle_exception

    raise pycompat.reraise(type(exception), exception, sys.exc_info()[2])

  File "/odoo/odoo-server/odoo/tools/pycompat.py", line 87, in reraise

    raise value

  File "/odoo/odoo-server/odoo/http.py", line 683, in dispatch

    result = self._call_function(**self.params)

  File "/odoo/odoo-server/odoo/http.py", line 339, in _call_function

    return checked_call(self.db, *args, **kwargs)

  File "/odoo/odoo-server/odoo/service/model.py", line 97, in wrapper

    return f(dbname, *args, **kwargs)

  File "/odoo/odoo-server/odoo/http.py", line 332, in checked_call

    result = self.endpoint(*a, **kw)

  File "/odoo/odoo-server/odoo/http.py", line 927, in __call__

    return self.method(*args, **kw)

  File "/odoo/odoo-server/odoo/http.py", line 512, in response_wrap

    response = f(*args, **kw)

  File "/odoo/odoo-server/addons/web/controllers/main.py", line 924, in call_kw

    return self._call_kw(model, method, args, kwargs)

  File "/odoo/odoo-server/addons/web/controllers/main.py", line 916, in _call_kw

    return call_kw(request.env[model], method, args, kwargs)

  File "/odoo/odoo-server/odoo/api.py", line 689, in call_kw

    return call_kw_multi(method, model, args, kwargs)

  File "/odoo/odoo-server/odoo/api.py", line 680, in call_kw_multi

    result = method(recs, *args, **kwargs)

  File "/odoo/odoo-server/odoo/models.py", line 4996, in onchange

    record._onchange_eval(name, field_onchange[name], result)

  File "/odoo/odoo-server/odoo/models.py", line 4892, in _onchange_eval

    method_res = method(self)

  File "/odoo/odoo-server/addons/hr_payroll/models/hr_payslip.py", line 461, in onchange_employee

    worked_days_line_ids = self.get_worked_day_lines(contracts, date_from, date_to)

  File "/odoo/odoo-server/addons/hr_payroll/models/hr_payslip.py", line 178, in get_worked_day_lines

    for day_intervals in day_leave_intervals:

  File "/odoo/odoo-server/addons/resource/models/resource.py", line 463, in _iter_leave_intervals

    resource_id)

  File "/odoo/odoo-server/addons/resource/models/resource.py", line 393, in _get_day_leave_intervals

    end_datetime=datetime.datetime.combine(day_date, end_time))

  File "/odoo/odoo-server/addons/resource/models/resource.py", line 304, in _get_leave_intervals

    leave_date_to = to_tz(fields.Datetime.from_string(leave.date_to), leave.tz)

  File "/odoo/odoo-server/addons/resource/models/resource.py", line 37, in to_tz

    tz = pytz.timezone(tz_name)

  File "/usr/local/lib/python3.5/dist-packages/pytz/__init__.py", line 173, in timezone

    if zone.upper() == 'UTC':

AttributeError: 'bool' object has no attribute 'upper'


Can you help me?   

0
Avatar
Zrušit
Carlos Wong
Autor

any body???

Avatar
Carlos Wong
Autor Nejlepší odpověď

First update...

I found out that it is related with Holidays module. If the employee does not have any "absent request", payroll works just fine. As soon as the employee register an "absent request" the problem shows up.


Also, I found out that in the work schedule module you have set the schedule in UTC (calculating UTC times) so the leaves module calculate in the right way the days quantity.


Any clue, about the payroll issue????


I really appreciate your help.


Second update

I found out something today debuging this problem... Actually, two issues:

First: The problem is generated because there is a table where leaves are duplicated from hr_holiday, it's called resource_calendar_leaves, but it has a tz column that is not being filled when copying the value, as hr_holiday uses UTC and does not fill a tz, it leave it null. I set it Default as 'Utc'.

After fixing that, I updated all rows with that value and another problem showed up, "zero division". This was the second issue.

Second Issue: The work schedule cannot be split, it generates a zero division. We have a working schedule from 8am to 12pm and from 1pm to 5pm (8 hours total). So I created a schedule with 2 entries for each day, morning and afternoon. I changed it to one entry per day from 8 to 5 and the problem disappear. But working days are not being calculated right in the payroll. Still checking this "last" issue.

Hope this help somebody else and maybe somebody can help me with the "last" issue.

0
Avatar
Zrušit
inian

I am also getting same error, did you find solution .. Please share

Carlos Wong
Autor

Sorry, I’m still looking how to solve it.

Carlos Wong
Autor

Update...

I found out something today debuging this problem... Actually, two issues:

First: The problem is generated because there is a table where leaves are duplicated from hr_holiday, it's called resource_calendar_leaves, but it has a tz column that is not being filled when copying the value, as hr_holiday uses UTC and does not fill a tz, it leave it null. I set it Default as 'Utc'.

After fixing that, I updated all rows with that value and another problem p\showed up, "zero division". This was the second issue.

Second Issue: The work schedule cannot be split, it generates a zero division. We have a working schedule from 8am to 12pm and from 1pm to 5pm (8 hours total). So I created a schedule with 2 entries for each day, morning and afternoon. I changed it to one da from 8 to 5 and the problem disappear. But working days are not being calculated right. Still checking the last issue.

Hope this help somebody else and maybe somebody can help me with the last issue.

inian

My issue got fixed . As you say holiday module stores in UTC format. When I changed date_from and date_to to Date instead of DateTime field, my error stopped appearing but leave hours comes up wrong.

Later I found that, If odoo doesn't find timezone set for user. It assigns UTC time to leave. So I changed all user timezone in user-> preference. Now everything works fine.

inian

Remove all leaves,set timezone for user from preference. Now apply again.

Carlos Wong
Autor

Nice catch!

I'll try that.

B.Khalil

hello,

i am facing the same problem, i changed employee timezone but steel have the same error message :

Traceback (most recent call last):

File "/usr/lib/python3/dist-packages/odoo/http.py", line 646, in _handle_exception

return super(JsonRequest, self)._handle_exception(exception)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 307, in _handle_exception

raise pycompat.reraise(type(exception), exception, sys.exc_info()[2])

File "/usr/lib/python3/dist-packages/odoo/tools/pycompat.py", line 87, in reraise

raise value

File "/usr/lib/python3/dist-packages/odoo/http.py", line 683, in dispatch

result = self._call_function(**self.params)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 339, in _call_function

return checked_call(self.db, *args, **kwargs)

File "/usr/lib/python3/dist-packages/odoo/service/model.py", line 97, in wrapper

return f(dbname, *args, **kwargs)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 332, in checked_call

result = self.endpoint(*a, **kw)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 927, in __call__

return self.method(*args, **kw)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 512, in response_wrap

response = f(*args, **kw)

File "/usr/lib/python3/dist-packages/odoo/addons/web/controllers/main.py", line 924, in call_kw

return self._call_kw(model, method, args, kwargs)

File "/usr/lib/python3/dist-packages/odoo/addons/web/controllers/main.py", line 916, in _call_kw

return call_kw(request.env[model], method, args, kwargs)

File "/usr/lib/python3/dist-packages/odoo/api.py", line 689, in call_kw

return call_kw_multi(method, model, args, kwargs)

File "/usr/lib/python3/dist-packages/odoo/api.py", line 680, in call_kw_multi

result = method(recs, *args, **kwargs)

File "/usr/lib/python3/dist-packages/odoo/models.py", line 4993, in onchange

record._onchange_eval(name, field_onchange[name], result)

File "/usr/lib/python3/dist-packages/odoo/models.py", line 4889, in _onchange_eval

method_res = method(self)

File "/usr/lib/python3/dist-packages/odoo/addons/hr_payroll/models/hr_payslip.py", line 464, in onchange_employee

worked_days_line_ids = self.get_worked_day_lines(contracts, date_from, date_to)

File "/usr/lib/python3/dist-packages/odoo/addons/hr_payroll/models/hr_payslip.py", line 178, in get_worked_day_lines

for day_intervals in day_leave_intervals:

File "/usr/lib/python3/dist-packages/odoo/addons/resource/models/resource.py", line 463, in _iter_leave_intervals

resource_id)

File "/usr/lib/python3/dist-packages/odoo/addons/resource/models/resource.py", line 393, in _get_day_leave_intervals

end_datetime=datetime.datetime.combine(day_date, end_time))

File "/usr/lib/python3/dist-packages/odoo/addons/resource/models/resource.py", line 304, in _get_leave_intervals

leave_date_to = to_tz(fields.Datetime.from_string(leave.date_to), leave.tz)

File "/usr/lib/python3/dist-packages/odoo/addons/resource/models/resource.py", line 37, in to_tz

tz = pytz.timezone(tz_name)

File "/usr/local/lib/python3.5/dist-packages/pytz/__init__.py", line 173, in timezone

if zone.upper() == 'UTC':

AttributeError: 'bool' object has no attribute 'upper'

Please how to set default time zone to all employees ?? or give other solution !!

B.Khalil

Hi, i found the solution, you have just to give timezone to the user that is managing payroll, if it is undefined in preferences, that's my case

Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Přihlásit se
Related Posts Odpovědi Zobrazení Aktivita
"The character encoding of the HTML document was not declared" when connecting to odoo11 server
error odoo11
Avatar
0
lis 21
4060
Error: The field `effective_date` does not exist - odoo 11
error odoo11
Avatar
Avatar
1
lis 19
5822
Set leave balance as zero - Odoo 11
leaves odoo11
Avatar
Avatar
1
kvě 19
3270
How to change the existing model hr.holidays in odoo 11
leaves odoo11
Avatar
0
kvě 19
4294
Odoo Server Error "unable to create thread pipe"
error reporting odoo11
Avatar
0
led 22
4900
Komunita
  • Tutoriály
  • Dokumentace
  • Fórum
Open Source
  • Stáhnout
  • Github
  • Runbot
  • Překlady
Služby
  • Odoo.sh hostování
  • Podpora
  • Upgrade
  • Nestandardní vývoj
  • Edukační program
  • Najít účetní
  • Najít partnera
  • Stát se partnerem
O nás
  • Naše společnost
  • Podklady značky
  • Kontakujte nás
  • Práce
  • Události
  • Podcast
  • Blog
  • Zákazníci
  • Právní dokumenty • Soukromí
  • Zabezpečení
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo je balíček open-source aplikací, které pokrývají všechny potřeby vaší společnosti: CRM, e-shop, účetnictví, sklady, kasy, projektové řízení a další.

Unikátní nabídka od Odoo poskytuje velmi jednoduché uživatelské rozhraní a vše je integrované na jednom místě.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now