예제 #1
0
    def _prepare_project_sharing_session_info(self, project):
        session_info = request.env['ir.http'].session_info()
        user_context = request.session.get_context(
        ) if request.session.uid else {}
        mods = conf.server_wide_modules or []
        qweb_checksum = HomeStaticTemplateHelpers.get_qweb_templates_checksum(
            debug=request.session.debug, bundle="project.assets_qweb")
        lang = user_context.get("lang")
        translation_hash = request.env[
            'ir.translation'].get_web_translations_hash(mods, lang)
        cache_hashes = {
            "qweb": qweb_checksum,
            "translations": translation_hash,
        }

        project_company = project.company_id
        session_info.update(
            cache_hashes=cache_hashes,
            action_name='project.project_sharing_project_task_action',
            project_id=project.id,
            user_companies={
                'current_company': project_company.id,
                'allowed_companies': {
                    project_company.id: {
                        'id': project_company.id,
                        'name': project_company.name,
                    },
                },
            },
            # FIXME: See if we prefer to give only the currency that the portal user just need to see the correct information in project sharing
            currencies=request.env['ir.http'].get_currencies(),
        )
        return session_info
    def session_info(self):
        session_info = super(Http, self).session_info()
        user = request.env.user

        if user.check_user_is_draft_seller() or user.check_user_is_seller():
            user_context = request.session.get_context(
            ) if request.session.uid else {}
            mods = module_boot()
            qweb_checksum = HomeStaticTemplateHelpers.get_qweb_templates_checksum(
                addons=mods, debug=request.session.debug)
            lang = user_context.get("lang")
            translations_per_module, lang_params = request.env[
                'ir.translation'].get_translations_for_webclient(mods, lang)
            translation_cache = {
                'lang':
                lang,
                'lang_parameters':
                lang_params,
                'modules':
                translations_per_module,
                'multi_lang':
                len(request.env['res.lang'].sudo().get_installed()) > 1,
            }
            menu_json_utf8 = json.dumps(request.env['ir.ui.menu'].load_menus(
                request.session.debug),
                                        default=ustr,
                                        sort_keys=True).encode()
            translations_json_utf8 = json.dumps(translation_cache,
                                                sort_keys=True).encode()
            cache_hashes = {
                "load_menus": hashlib.sha1(menu_json_utf8).hexdigest(),
                "qweb": qweb_checksum,
                "translations":
                hashlib.sha1(translations_json_utf8).hexdigest(),
            }
            session_info.update({
                "user_companies": {
                    'current_company':
                    (user.company_id.id, user.company_id.name),
                    'allowed_companies':
                    [(comp.id, comp.name) for comp in user.company_ids]
                },
                "currencies":
                self.get_currencies(),
                "show_effect":
                True,
                "display_switch_company_menu":
                user.has_group('base.group_multi_company')
                and len(user.company_ids) > 1,
                "cache_hashes":
                cache_hashes,
            })
        return session_info
예제 #3
0
    def session_info(self):
        user = request.env.user
        version_info = odoo.service.common.exp_version()

        user_context = request.session.get_context() if request.session.uid else {}

        session_info = {
            "uid": request.session.uid,
            "is_system": user._is_system() if request.session.uid else False,
            "is_admin": user._is_admin() if request.session.uid else False,
            "user_context": request.session.get_context() if request.session.uid else {},
            "db": request.session.db,
            "server_version": version_info.get('server_version'),
            "server_version_info": version_info.get('server_version_info'),
            "name": user.name,
            "username": user.login,
            "partner_display_name": user.partner_id.display_name,
            "company_id": user.company_id.id if request.session.uid else None,  # YTI TODO: Remove this from the user context
            "partner_id": user.partner_id.id if request.session.uid and user.partner_id else None,
            "web.base.url": self.env['ir.config_parameter'].sudo().get_param('web.base.url', default=''),
        }
        if self.env.user.has_group('base.group_user'):
            # the following is only useful in the context of a webclient bootstrapping
            # but is still included in some other calls (e.g. '/web/session/authenticate')
            # to avoid access errors and unnecessary information, it is only included for users
            # with access to the backend ('internal'-type users)
            mods = module_boot()
            qweb_checksum = HomeStaticTemplateHelpers.get_qweb_templates_checksum(addons=mods, debug=request.session.debug)
            lang = user_context.get("lang")
            translations_per_module, lang_params = request.env['ir.translation'].get_translations_for_webclient(mods, lang)
            translation_cache = {
                'lang': lang,
                'lang_parameters': lang_params,
                'modules': translations_per_module,
                'multi_lang': len(request.env['res.lang'].sudo().get_installed()) > 1,
            }
            menu_json_utf8 = json.dumps(request.env['ir.ui.menu'].load_menus(request.session.debug), default=ustr, sort_keys=True).encode()
            translations_json_utf8 = json.dumps(translation_cache, sort_keys=True).encode()
            cache_hashes = {
                "load_menus": hashlib.sha512(menu_json_utf8).hexdigest()[:64], # sha512/256
                "qweb": qweb_checksum,
                "translations": hashlib.sha512(translations_json_utf8).hexdigest()[:64], # sha512/256
            }
            session_info.update({
                # current_company should be default_company
                "user_companies": {'current_company': (user.company_id.id, user.company_id.name), 'allowed_companies': [(comp.id, comp.name) for comp in user.company_ids]},
                "currencies": self.get_currencies(),
                "show_effect": True,
                "display_switch_company_menu": user.has_group('base.group_multi_company') and len(user.company_ids) > 1,
                "cache_hashes": cache_hashes,
            })
        return session_info
예제 #4
0
    def session_info(self):

        user = request.env.user

        user_context = request.session.get_context(
        ) if request.session.uid else {}

        result = super().session_info()
        if self.env.user.has_group('base.group_portal'):
            # the following is only useful in the context of a webclient bootstrapping
            # but is still included in some other calls (e.g. '/web/session/authenticate')
            # to avoid access errors and unnecessary information, it is only included for users
            # with access to the backend ('internal'-type users)
            mods = module_boot()
            qweb_checksum = HomeStaticTemplateHelpers.get_qweb_templates_checksum(
                addons=mods, debug=request.session.debug)
            lang = user_context.get("lang")
            translation_hash = request.env[
                'ir.translation'].get_web_translations_hash(mods, lang)
            menu_json_utf8 = json.dumps(request.env['ir.ui.menu'].load_menus(
                request.session.debug),
                                        default=ustr,
                                        sort_keys=True).encode()
            cache_hashes = {
                "load_menus": hashlib.sha1(menu_json_utf8).hexdigest(),
                "qweb": qweb_checksum,
                "translations": translation_hash,
            }
            result.update({
                # current_company should be default_company
                "user_companies": {
                    'current_company':
                    (user.company_id.id, user.company_id.name),
                    'allowed_companies':
                    [(comp.id, comp.name) for comp in user.company_ids]
                },
                "currencies":
                self.get_currencies(),
                "show_effect":
                True,
                "display_switch_company_menu":
                user.has_group('base.group_multi_company')
                and len(user.company_ids) > 1,
                "cache_hashes":
                cache_hashes,
            })
        return result
예제 #5
0
    def session_info(self):
        user = request.env.user
        version_info = odoo.service.common.exp_version()

        user_context = request.session.get_context() if request.session.uid else {}

        mods = module_boot()
        qweb_checksum = HomeStaticTemplateHelpers.get_qweb_templates_checksum(addons=mods, debug=request.session.debug)

        lang = user_context.get("lang")
        translations_per_module, lang_params = request.env['ir.translation'].get_translations_for_webclient(mods, lang)
        translation_cache = {
            'lang': lang,
            'lang_parameters': lang_params,
            'modules': translations_per_module,
            'multi_lang': len(request.env['res.lang'].sudo().get_installed()) > 1,
        }

        menu_json_utf8 = json.dumps(request.env['ir.ui.menu'].load_menus(request.session.debug), default=ustr, sort_keys=True).encode()
        translations_json_utf8 = json.dumps(translation_cache, sort_keys=True).encode()

        return {
            "uid": request.session.uid,
            "is_system": user._is_system() if request.session.uid else False,
            "is_admin": user._is_admin() if request.session.uid else False,
            "user_context": request.session.get_context() if request.session.uid else {},
            "db": request.session.db,
            "server_version": version_info.get('server_version'),
            "server_version_info": version_info.get('server_version_info'),
            "name": user.name,
            "username": user.login,
            "partner_display_name": user.partner_id.display_name,
            "company_id": user.company_id.id if request.session.uid else None,  # YTI TODO: Remove this from the user context
            "partner_id": user.partner_id.id if request.session.uid and user.partner_id else None,
            # current_company should be default_company
            "user_companies": {'current_company': (user.company_id.id, user.company_id.name), 'allowed_companies': [(comp.id, comp.name) for comp in user.company_ids]},
            "currencies": self.get_currencies() if request.session.uid else {},
            "web.base.url": self.env['ir.config_parameter'].sudo().get_param('web.base.url', default=''),
            "show_effect": True,
            "display_switch_company_menu": user.has_group('base.group_multi_company') and len(user.company_ids) > 1,
            "cache_hashes": {
                "load_menus": hashlib.sha1(menu_json_utf8).hexdigest(),
                "qweb": qweb_checksum,
                "translations": hashlib.sha1(translations_json_utf8).hexdigest(),
            },
        }
예제 #6
0
 def session_info(self):
     user = request.env.user
     result = super(IrHttp, self).session_info()
     if self.env.user.has_group('base.group_user'):
         result['notification_type'] = user.notification_type
     assets_discuss_public_hash = HomeStaticTemplateHelpers.get_qweb_templates_checksum(debug=request.session.debug, bundle='mail.assets_discuss_public')
     result['cache_hashes']['assets_discuss_public'] = assets_discuss_public_hash
     guest = self.env.context.get('guest')
     if guest:
         user_context = {'lang': guest.lang}
         mods = odoo.conf.server_wide_modules or []
         lang = user_context.get("lang")
         translation_hash = request.env['ir.translation'].sudo().get_web_translations_hash(mods, lang)
         result['cache_hashes']['translations'] = translation_hash
         result.update({
             'name': guest.name,
             'user_context': user_context,
         })
     return result
예제 #7
0
파일: portal.py 프로젝트: budisentosa/odoo
    def render_project_backend_view(self, project_id):
        project = request.env['project.project'].sudo().browse(project_id)
        if not project.exists() or not project.with_user(
                request.env.user)._check_project_sharing_access():
            return request.not_found()

        session_info = request.env['ir.http'].session_info()
        user_context = request.session.get_context(
        ) if request.session.uid else {}
        mods = conf.server_wide_modules or []
        qweb_checksum = HomeStaticTemplateHelpers.get_qweb_templates_checksum(
            debug=request.session.debug, bundle="project.assets_qweb")
        lang = user_context.get("lang")
        translation_hash = request.env[
            'ir.translation'].get_web_translations_hash(mods, lang)
        cache_hashes = {
            "qweb": qweb_checksum,
            "translations": translation_hash,
        }

        project_company = project.company_id
        session_info.update(
            cache_hashes=cache_hashes,
            action_name='project.project_sharing_project_task_action',
            project_id=project.id,
            user_companies={
                'current_company': project_company.id,
                'allowed_companies': {
                    project_company.id: {
                        'id': project_company.id,
                        'name': project_company.name,
                    },
                },
            },
        )

        return request.render(
            'project.project_sharing_embed',
            {'session_info': session_info},
        )
예제 #8
0
파일: ir_http.py 프로젝트: iCart/odoo
    def session_info(self):
        user = request.env.user
        version_info = odoo.service.common.exp_version()

        user_context = request.session.get_context(
        ) if request.session.uid else {}
        IrConfigSudo = self.env['ir.config_parameter'].sudo()
        max_file_upload_size = int(
            IrConfigSudo.get_param(
                'web.max_file_upload_size',
                default=128 * 1024 * 1024,  # 128MiB
            ))

        session_info = {
            "uid":
            request.session.uid,
            "is_system":
            user._is_system() if request.session.uid else False,
            "is_admin":
            user._is_admin() if request.session.uid else False,
            "user_context":
            request.session.get_context() if request.session.uid else {},
            "db":
            request.session.db,
            "server_version":
            version_info.get('server_version'),
            "server_version_info":
            version_info.get('server_version_info'),
            "name":
            user.name,
            "username":
            user.login,
            "partner_display_name":
            user.partner_id.display_name,
            "company_id":
            user.company_id.id if request.session.uid else
            None,  # YTI TODO: Remove this from the user context
            "partner_id":
            user.partner_id.id
            if request.session.uid and user.partner_id else None,
            "web.base.url":
            IrConfigSudo.get_param('web.base.url', default=''),
            "active_ids_limit":
            int(IrConfigSudo.get_param('web.active_ids_limit',
                                       default='20000')),
            'profile_session':
            request.session.profile_session,
            'profile_collectors':
            request.session.profile_collectors,
            'profile_params':
            request.session.profile_params,
            "max_file_upload_size":
            max_file_upload_size,
        }
        if self.env.user.has_group('base.group_user'):
            # the following is only useful in the context of a webclient bootstrapping
            # but is still included in some other calls (e.g. '/web/session/authenticate')
            # to avoid access errors and unnecessary information, it is only included for users
            # with access to the backend ('internal'-type users)
            mods = odoo.conf.server_wide_modules or []
            if request.db:
                mods = list(request.registry._init_modules) + mods
            qweb_checksum = HomeStaticTemplateHelpers.get_qweb_templates_checksum(
                debug=request.session.debug, bundle="web.assets_qweb")
            lang = user_context.get("lang")
            translation_hash = request.env[
                'ir.translation'].get_web_translations_hash(mods, lang)
            menu_json_utf8 = json.dumps(request.env['ir.ui.menu'].load_menus(
                request.session.debug),
                                        default=ustr,
                                        sort_keys=True).encode()
            cache_hashes = {
                "load_menus":
                hashlib.sha512(menu_json_utf8).hexdigest()[:64],  # sha512/256
                "qweb": qweb_checksum,
                "translations": translation_hash,
            }
            session_info.update({
                # current_company should be default_company
                "user_companies": {
                    'current_company': user.company_id.id,
                    'allowed_companies': {
                        comp.id: {
                            'id': comp.id,
                            'name': comp.name,
                        }
                        for comp in user.company_ids
                    },
                },
                "currencies":
                self.get_currencies(),
                "show_effect":
                True,
                "display_switch_company_menu":
                user.has_group('base.group_multi_company')
                and len(user.company_ids) > 1,
                "cache_hashes":
                cache_hashes,
            })
        return session_info
예제 #9
0
            "company_id": user.company_id.id if request.session.uid else None,  # YTI TODO: Remove this from the user context
            "partner_id": user.partner_id.id if request.session.uid and user.partner_id else None,
<<<<<<< HEAD
            "web.base.url": self.env['ir.config_parameter'].sudo().get_param('web.base.url', default=''),
=======
            "web.base.url": IrConfigSudo.get_param('web.base.url', default=''),
            "active_ids_limit": int(IrConfigSudo.get_param('web.active_ids_limit', default='20000')),
>>>>>>> f0a66d05e70e432d35dc68c9fb1e1cc6e51b40b8
        }
        if self.env.user.has_group('base.group_user'):
            # the following is only useful in the context of a webclient bootstrapping
            # but is still included in some other calls (e.g. '/web/session/authenticate')
            # to avoid access errors and unnecessary information, it is only included for users
            # with access to the backend ('internal'-type users)
            mods = module_boot()
            qweb_checksum = HomeStaticTemplateHelpers.get_qweb_templates_checksum(addons=mods, debug=request.session.debug)
            lang = user_context.get("lang")
            translation_hash = request.env['ir.translation'].get_web_translations_hash(mods, lang)
            menu_json_utf8 = json.dumps(request.env['ir.ui.menu'].load_menus(request.session.debug), default=ustr, sort_keys=True).encode()
            cache_hashes = {
<<<<<<< HEAD
                "load_menus": hashlib.sha1(menu_json_utf8).hexdigest(),
=======
                "load_menus": hashlib.sha512(menu_json_utf8).hexdigest()[:64], # sha512/256
>>>>>>> f0a66d05e70e432d35dc68c9fb1e1cc6e51b40b8
                "qweb": qweb_checksum,
                "translations": translation_hash,
            }
            session_info.update({
                # current_company should be default_company
                "user_companies": {'current_company': (user.company_id.id, user.company_id.name), 'allowed_companies': [(comp.id, comp.name) for comp in user.company_ids]},