Have you tried auth.user.id? -Jim
On Saturday, June 13, 2020 at 1:34:04 AM UTC-5, Константин Комков wrote: > > I use decorator for reduce count of sql queries for logged in users like > that: > def is_info(fun): > def decorated(): > if session.is_info is None: > entrant = db(db.a_persons.WEB_ID == auth.user_id).select( > db.a_persons.FILE_CODE0, db.a_persons.F, db.a_persons.I, > db.a_persons.O, db.a_persons.id, > db.a_persons.BIRTHDAY, db.a_persons.GENDER, > db.a_persons.BIRTHPLACE, db.a_persons.GRADUATION_LEVEL, > db.a_persons.COUNTRY, db.a_persons.REGION, > db.a_persons.ADR_INDEX, db.a_persons.ADR_DISTRICT, > db.a_persons.ADR_LOC_TYPE, db.a_persons.ADR_TOWN, > db.a_persons.ADR_STREET_TYPE, db.a_persons.ADR_STREET, > db.a_persons.ADR_HOUSE, db.a_persons.ADR_BUILDING, > db.a_persons.ADR_FLAT, db.a_persons.PHONE, > db.a_persons.NEED_HOSTEL, db.a_persons.PREP_COURSE, > db.a_persons.ARMY, db.a_persons.EXTRA, > db.a_persons.WORK_EXP, db.a_persons.PASS_ID, > db.a_persons.GRADUATION_YEAR, db.a_persons.EDU_REGION, > db.a_persons.LANGUAGE).first() > if entrant is None: > redirect(URL('user', 'index', args=['logout'])) > session.is_info = True > session.myvar = auth.user_id > session.is_info = True > session.file_code = entrant.FILE_CODE0 > session.middle_name = entrant.O > session.entrant_id = entrant.id > session.birthday = entrant.BIRTHDAY > session.sex = entrant.GENDER > session.birthplace = entrant.BIRTHPLACE > session.country = entrant.COUNTRY > session.region = entrant.REGION > session.adr_index = entrant.ADR_INDEX > session.adr_district = entrant.ADR_DISTRICT > session.adr_loc_type = entrant.ADR_LOC_TYPE > session.adr_town = entrant.ADR_TOWN > session.adr_street_type = entrant.ADR_STREET_TYPE > session.adr_street = entrant.ADR_STREET > session.adr_house = entrant.ADR_HOUSE > session.adr_building = entrant.ADR_BUILDING > session.adr_flat = entrant.ADR_FLAT > session.phone = entrant.PHONE > session.need_hostel = entrant.NEED_HOSTEL > session.prep_course = entrant.PREP_COURSE > session.army = entrant.ARMY > session.extra = entrant.EXTRA > session.work_exp = entrant.WORK_EXP > session.pass_id = entrant.PASS_ID > session.graduation_level = entrant.GRADUATION_LEVEL > session.graduation_year = entrant.GRADUATION_YEAR > session.edu_region = entrant.EDU_REGION > session.language = entrant.LANGUAGE > return fun() > else: > return fun() > return decorated > As I understund after that decorator inside my function I check > session.myvar and have None. I can't use auth.user_id inside decorator? > tables.py > db.define_table('a_persons', Field('FILE_CODE0', length=15), > Field('WEB_ID', 'reference auth_user') > # ... > ) > Why I don't have error in query, becouse db.a_persons.WEB_ID == None? I > have the first user information. > Web2py - 2.18.5-stable+timestamp.2019.04.08.04.22.03 > > -- Resources: - http://web2py.com - http://web2py.com/book (Documentation) - http://github.com/web2py/web2py (Source code) - https://code.google.com/p/web2py/issues/list (Report Issues) --- You received this message because you are subscribed to the Google Groups "web2py-users" group. To unsubscribe from this group and stop receiving emails from it, send an email to web2py+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/web2py/ac5eb0cc-1e54-4913-ba0d-c1997965b63co%40googlegroups.com.