diff --git a/app/activitypub/util.py b/app/activitypub/util.py
index 683c35f7..425f5125 100644
--- a/app/activitypub/util.py
+++ b/app/activitypub/util.py
@@ -339,10 +339,19 @@ def refresh_user_profile_task(user_id):
if actor_data.status_code == 200:
activity_json = actor_data.json()
actor_data.close()
+
+ # update indexible state on their posts, if necessary
+ new_indexable = activity_json['indexable'] if 'indexable' in activity_json else True
+ if new_indexable != user.indexable:
+ db.session.execute(text('UPDATE "post" set indexable = :indexable WHERE user_id = :user_id'),
+ {'user_id': user.id,
+ 'indexable': new_indexable})
+
user.user_name = activity_json['preferredUsername']
user.about_html = parse_summary(activity_json)
user.ap_fetched_at = utcnow()
- user.public_key=activity_json['publicKey']['publicKeyPem']
+ user.public_key = activity_json['publicKey']['publicKeyPem']
+ user.indexable = new_indexable
avatar_changed = cover_changed = False
if 'icon' in activity_json:
@@ -594,6 +603,7 @@ def post_json_to_model(post_json, user, community) -> Post:
last_active=post_json['published'],
instance_id=user.instance_id
)
+ post.indexable = user.indexable
if 'source' in post_json and \
post_json['source']['mediaType'] == 'text/markdown':
post.body = post_json['source']['content']
@@ -1212,7 +1222,8 @@ def create_post(activity_log: ActivityPubLog, community: Community, request_json
type=constants.POST_TYPE_ARTICLE,
up_votes=1,
score=instance_weight(user.ap_domain),
- instance_id=user.instance_id
+ instance_id=user.instance_id,
+ indexable=user.indexable
)
# Get post content. Lemmy and Kbin put this in different places.
if 'source' in request_json['object'] and isinstance(request_json['object']['source'], dict) and request_json['object']['source']['mediaType'] == 'text/markdown': # Lemmy
diff --git a/app/community/util.py b/app/community/util.py
index 75132ded..f86e5811 100644
--- a/app/community/util.py
+++ b/app/community/util.py
@@ -164,6 +164,7 @@ def url_to_thumbnail_file(filename) -> File:
def save_post(form, post: Post):
+ post.indexable = current_user.indexable
post.nsfw = form.nsfw.data
post.nsfl = form.nsfl.data
post.notify_author = form.notify_author.data
diff --git a/app/models.py b/app/models.py
index c42f8a59..69449bd5 100644
--- a/app/models.py
+++ b/app/models.py
@@ -776,7 +776,7 @@ class Post(db.Model):
nsfl = db.Column(db.Boolean, default=False, index=True)
sticky = db.Column(db.Boolean, default=False)
notify_author = db.Column(db.Boolean, default=True)
- indexable = db.Column(db.Boolean, default=False)
+ indexable = db.Column(db.Boolean, default=True)
from_bot = db.Column(db.Boolean, default=False, index=True)
created_at = db.Column(db.DateTime, index=True, default=utcnow) # this is when the content arrived here
posted_at = db.Column(db.DateTime, index=True, default=utcnow) # this is when the original server created it
diff --git a/app/post/routes.py b/app/post/routes.py
index 0c5ed613..67472b84 100644
--- a/app/post/routes.py
+++ b/app/post/routes.py
@@ -216,6 +216,7 @@ def show_post(post_id: int):
canonical=post.ap_id, form=form, replies=replies, THREAD_CUTOFF_DEPTH=constants.THREAD_CUTOFF_DEPTH,
description=description, og_image=og_image, POST_TYPE_IMAGE=constants.POST_TYPE_IMAGE,
POST_TYPE_LINK=constants.POST_TYPE_LINK, POST_TYPE_ARTICLE=constants.POST_TYPE_ARTICLE,
+ noindex=not post.author.indexable,
etag=f"{post.id}{sort}_{hash(post.last_active)}", markdown_editor=current_user.is_authenticated and current_user.markdown_editor,
low_bandwidth=request.cookies.get('low_bandwidth', '0') == '1', SUBSCRIPTION_MEMBER=SUBSCRIPTION_MEMBER,
moderating_communities=moderating_communities(current_user.get_id()),
diff --git a/app/search/routes.py b/app/search/routes.py
index e4a96cf8..8edbcef7 100644
--- a/app/search/routes.py
+++ b/app/search/routes.py
@@ -5,11 +5,10 @@ from sqlalchemy import or_
from app.models import Post
from app.search import bp
-from app.utils import moderating_communities, joined_communities, render_template, blocked_domains
+from app.utils import moderating_communities, joined_communities, render_template, blocked_domains, blocked_instances
@bp.route('/search', methods=['GET', 'POST'])
-@login_required
def run_search():
if request.args.get('q') is not None:
q = request.args.get('q')
@@ -17,16 +16,26 @@ def run_search():
low_bandwidth = request.cookies.get('low_bandwidth', '0') == '1'
posts = Post.query.search(q)
- if current_user.ignore_bots:
+ if current_user.is_authenticated:
+ if current_user.ignore_bots:
+ posts = posts.filter(Post.from_bot == False)
+ if current_user.show_nsfl is False:
+ posts = posts.filter(Post.nsfl == False)
+ if current_user.show_nsfw is False:
+ posts = posts.filter(Post.nsfw == False)
+ domains_ids = blocked_domains(current_user.id)
+ if domains_ids:
+ posts = posts.filter(or_(Post.domain_id.not_in(domains_ids), Post.domain_id == None))
+ instance_ids = blocked_instances(current_user.id)
+ if instance_ids:
+ posts = posts.filter(or_(Post.instance_id.not_in(instance_ids), Post.instance_id == None))
+ else:
posts = posts.filter(Post.from_bot == False)
- if current_user.show_nsfl is False:
posts = posts.filter(Post.nsfl == False)
- if current_user.show_nsfw is False:
posts = posts.filter(Post.nsfw == False)
- domains_ids = blocked_domains(current_user.id)
- if domains_ids:
- posts = posts.filter(or_(Post.domain_id.not_in(domains_ids), Post.domain_id == None))
+ posts = posts.filter(Post.indexable == True)
+
posts = posts.paginate(page=page, per_page=100 if current_user.is_authenticated and not low_bandwidth else 50,
error_out=False)
diff --git a/app/templates/base.html b/app/templates/base.html
index 92c8e266..7e76319b 100644
--- a/app/templates/base.html
+++ b/app/templates/base.html
@@ -70,6 +70,9 @@
{% if rss_feed %}
{% endif %}
+ {% if noindex %}
+
+ {% endif %}