def inject(): now = datetime.datetime.now() return dict(channels=Channel.objects(published=True, available_at__lte=now, parent=None), Config=Config, Content=Content, Channel=Channel, homepage=Channel.get_homepage(), Link=Link)
def inject(): now = datetime.datetime.now() return dict( channels=Channel.objects(published=True, available_at__lte=now, parent=None), Config=Config, Content=Content, Channel=Channel, homepage=Channel.get_homepage() )
def configure(app): app.add_url_rule('/mediafiles/<path:filename>', view_func=media) app.add_url_rule('/template_files/<path:filename>', view_func=template_files) app.add_url_rule('/theme_template_files/<identifier>/<path:filename>', view_func=theme_template_files) for filepath in app.config.get('MAP_STATIC_ROOT', []): app.add_url_rule(filepath, view_func=static_from_root) # Match content detail, .html added to distinguish from channels # better way? how? CONTENT_EXTENSION = app.config.get("CONTENT_EXTENSION", "html") app.add_url_rule('/<path:long_slug>.{0}'.format(CONTENT_EXTENSION), view_func=ContentDetail.as_view('detail')) # Atom Feed app.add_url_rule('/<path:long_slug>.atom', view_func=FeedAtom.as_view('atom_list')) app.add_url_rule('/tag/<tag>.atom', view_func=TagAtom.as_view('atom_tag')) # Tag list app.add_url_rule('/tag/<tag>/', view_func=TagList.as_view('tag')) # Match channels by its long_slug mpath app.add_url_rule('/<path:long_slug>/', view_func=ContentList.as_view('list')) # Home page app.add_url_rule( '/', view_func=ContentList.as_view('home'), defaults={"long_slug": Channel.get_homepage('long_slug') or "home"})
def configure(app): app.add_url_rule('/mediafiles/<path:filename>', view_func=media) app.add_url_rule('/template_files/<path:filename>', view_func=template_files) app.add_url_rule('/theme_template_files/<identifier>/<path:filename>', view_func=theme_template_files) for filepath in app.config.get('MAP_STATIC_ROOT', []): app.add_url_rule(filepath, view_func=static_from_root) # Match content detail, .html added to distinguish from channels # better way? how? CONTENT_EXTENSION = app.config.get("CONTENT_EXTENSION", "html") app.add_url_rule('/<path:long_slug>.{0}'.format(CONTENT_EXTENSION), view_func=ContentDetail.as_view('detail')) # Atom Feed app.add_url_rule('/<path:long_slug>.atom', view_func=FeedAtom.as_view('atom_list')) app.add_url_rule('/tag/<tag>.atom', view_func=TagAtom.as_view('atom_tag')) # Tag list app.add_url_rule('/tag/<tag>/', view_func=TagList.as_view('tag')) # Match channels by its long_slug mpath app.add_url_rule('/<path:long_slug>/', view_func=ContentList.as_view('list')) # Home page app.add_url_rule( '/', view_func=ContentList.as_view('home'), defaults={"long_slug": Channel.get_homepage('long_slug') or "home"} )
def configure(app): app.add_url_rule('/mediafiles/<path:filename>', view_func=media) app.add_url_rule('/template_files/<path:filename>', view_func=template_files) for filepath in app.config.get('MAP_STATIC_ROOT', []): app.add_url_rule(filepath, view_func=static_from_root) # Match content detail, .html added to distinguish from channels # better way? how? app.add_url_rule('/<path:long_slug>.html', view_func=ContentDetail.as_view('detail')) # Match channels by its long_slug mpath app.add_url_rule('/<path:long_slug>/', view_func=ContentList.as_view('list')) app.add_url_rule('/questions/<path:pretty_slug>.html', view_func=QuestionDetail.as_view('question-detail')) # Home page app.add_url_rule( '/', view_func=ContentList.as_view('home'), defaults={"long_slug": Channel.get_homepage('long_slug') or "home"} )
def get_default_channel(cls): default_channel = cls.DEFAULT_CHANNEL try: return Channel.objects.get(long_slug=default_channel) except Exception as e: logger.warning(str(e)) return Channel.get_homepage()
def configure(app): # Match content detail, .html added to distinguish from channels # better way? how? app.add_url_rule('/<path:long_slug>.html', view_func=ContentDetail.as_view('detail')) # Match channels by its long_slug mpath app.add_url_rule('/<path:long_slug>/', view_func=ContentList.as_view('list')) # Home page app.add_url_rule( '/', view_func=ContentList.as_view('home'), defaults={"long_slug": Channel.get_homepage('slug') or "home"} )
def configure(app): app.add_url_rule('/mediafiles/<path:filename>', view_func=media) app.add_url_rule('/template_files/<path:filename>', view_func=template_files) for filepath in app.config.get('MAP_STATIC_ROOT', []): app.add_url_rule(filepath, view_func=static_from_root) # Match content detail, .html added to distinguish from channels # better way? how? app.add_url_rule('/<path:long_slug>.html', view_func=ContentDetail.as_view('detail')) # Match channels by its long_slug mpath app.add_url_rule('/<path:long_slug>/', view_func=ContentList.as_view('list')) # Home page app.add_url_rule( '/', view_func=ContentList.as_view('home'), defaults={"long_slug": Channel.get_homepage('long_slug') or "home"})
def get(self, long_slug): now = datetime.now() path = long_slug.split('/') mpath = ",".join(path) mpath = ",{0},".format(mpath) channel = Channel.objects.get_or_404(mpath=mpath, published=True) if not is_accessible(roles_accepted=channel.roles): raise abort(403, "User has no role to view this channel content") if channel.is_homepage and request.path != channel.get_absolute_url(): return redirect(channel.get_absolute_url()) published_channels = Channel.objects(published=True).values_list('id') if channel.redirect_url: return redirect(channel.redirect_url) if channel.render_content: return ContentDetail().get( channel.render_content.content.long_slug, True) self.channel = channel base_filters = {} filters = { 'published': True, 'available_at__lte': now, 'show_on_channel': True, 'channel__in': published_channels } if not channel.is_homepage: base_filters['__raw__'] = { '$or': [{ 'mpath': { '$regex': "^{0}".format(mpath) } }, { 'related_mpath': { '$regex': "^{0}".format(mpath) } }] } else: # list only allowed items in homepage user_roles = [role.name for role in get_current_user().roles] if 'admin' not in user_roles: base_filters['__raw__'] = { "$or": [ { "channel_roles": { "$in": user_roles } }, { "channel_roles": { "$size": 0 } }, # the following filters are for backwards compatibility { "channel_roles": None }, { "channel_roles": { "$exists": False } } ] } filters.update(channel.get_content_filters()) contents = Content.objects(**base_filters).filter(**filters) sort = request.args.get('sort') if sort: contents = contents.order_by(sort) elif channel.sort_by: contents = contents.order_by(*channel.sort_by) disabled_pagination = False if not current_app.config.get("PAGINATION_ENABLED", True): disabled_pagination = contents.count() pagination_arg = current_app.config.get("PAGINATION_ARG", "page") page = request.args.get(pagination_arg, 1) per_page = (disabled_pagination or request.args.get('per_page') or channel.per_page or current_app.config.get("PAGINATION_PER_PAGE", 10)) contents = contents.paginate(page=int(page), per_page=int(per_page)) themes = channel.get_themes() return render_template(self.get_template_names(), theme=themes, contents=contents, channel=channel)
def get(self, long_slug): now = datetime.now() path = long_slug.split('/') mpath = ",".join(path) mpath = ",{0},".format(mpath) channel = Channel.objects.get_or_404(mpath=mpath, published=True) if not is_accessible(roles_accepted=channel.roles): raise abort(403, "User has no role to view this channel content") if channel.is_homepage and request.path != channel.get_absolute_url(): return redirect(channel.get_absolute_url()) published_channels = Channel.objects(published=True).values_list('id') if channel.redirect_url: return redirect(channel.redirect_url) if channel.render_content: return ContentDetail().get( channel.render_content.content.long_slug, True) self.channel = channel base_filters = {} filters = { 'published': True, 'available_at__lte': now, 'show_on_channel': True, 'channel__in': published_channels } if not channel.is_homepage: base_filters['__raw__'] = { '$or': [ {'mpath': {'$regex': "^{0}".format(mpath)}}, {'related_mpath': {'$regex': "^{0}".format(mpath)}} ] } else: # list only allowed items in homepage user_roles = [role.name for role in get_current_user().roles] if 'admin' not in user_roles: base_filters['__raw__'] = { "$or": [ {"channel_roles": {"$in": user_roles}}, {"channel_roles": {"$size": 0}}, # the following filters are for backwards compatibility {"channel_roles": None}, {"channel_roles": {"$exists": False}} ] } filters.update(channel.get_content_filters()) contents = Content.objects(**base_filters).filter(**filters) sort = request.args.get('sort') if sort: contents = contents.order_by(sort) elif channel.sort_by: contents = contents.order_by(*channel.sort_by) disabled_pagination = False if not current_app.config.get("PAGINATION_ENABLED", True): disabled_pagination = contents.count() pagination_arg = current_app.config.get("PAGINATION_ARG", "page") page = request.args.get(pagination_arg, 1) per_page = ( disabled_pagination or request.args.get('per_page') or channel.per_page or current_app.config.get("PAGINATION_PER_PAGE", 10) ) contents = contents.paginate(page=int(page), per_page=int(per_page)) themes = channel.get_themes() return render_template(self.get_template_names(), theme=themes, contents=contents, channel=channel)
def inject_channels(): now = datetime.datetime.now() return dict(channels=Channel.objects(published=True, available_at__lte=now, parent=None))
def inject_channels(): now = datetime.datetime.now() return dict(channels=Channel.objects( published=True, available_at__lte=now, parent=None))