266 lines
6.7 KiB
Ruby
266 lines
6.7 KiB
Ruby
module Adamantium
|
|
module Repos
|
|
class PostRepo < Adamantium::Repo[:posts]
|
|
Sequel.extension :pg_json
|
|
Sequel.extension :pg_json_ops
|
|
commands update: :by_pk
|
|
|
|
def create(post_attrs)
|
|
posts.transaction do
|
|
new_post = posts.changeset(:create, post_attrs).commit
|
|
|
|
post_attrs[:category].each do |tag_name|
|
|
next if tag_name == ""
|
|
|
|
tag = posts.tags.where(label: tag_name).one ||
|
|
posts
|
|
.tags
|
|
.changeset(:create, {label: tag_name, slug: tag_name.downcase.strip.tr(" ", "-").gsub(/[^\w-]/, "")})
|
|
.commit
|
|
|
|
posts.post_tags.changeset(:create, {
|
|
post_id: new_post.id,
|
|
tag_id: tag[:id]
|
|
})
|
|
.commit
|
|
end
|
|
|
|
new_post
|
|
end
|
|
end
|
|
|
|
def tag_post(post_id:, tags:)
|
|
tags.each do |tag_name|
|
|
next if tag_name == ""
|
|
|
|
tag = posts.tags.where(label: tag_name).one ||
|
|
posts
|
|
.tags
|
|
.changeset(:create, {label: tag_name, slug: tag_name.downcase.strip.tr(" ", "-").gsub(/[^\w-]/, "")})
|
|
.commit
|
|
|
|
posts.post_tags.changeset(:create, {
|
|
post_id: post_id,
|
|
tag_id: tag[:id]
|
|
})
|
|
.commit
|
|
end
|
|
end
|
|
|
|
def auto_tag_post(post_id:, tag_id:)
|
|
return if posts
|
|
.post_tags
|
|
.where(
|
|
post_id: post_id,
|
|
tag_id: tag_id
|
|
).count > 0
|
|
|
|
posts
|
|
.post_tags
|
|
.changeset(:create, {
|
|
post_id: post_id,
|
|
tag_id: tag_id
|
|
})
|
|
.commit
|
|
end
|
|
|
|
def by_title(title_contains:)
|
|
posts
|
|
.where(post_type: "post")
|
|
.published
|
|
.where(Sequel.ilike(:name, "%#{title_contains}%")).to_a
|
|
end
|
|
|
|
def by_content(body_contains:)
|
|
posts
|
|
.where(post_type: "post")
|
|
.published
|
|
.where(Sequel.ilike(:content, "%#{body_contains}%")).to_a
|
|
end
|
|
|
|
def remove_tag(post_id:, tag:)
|
|
tag = posts.tags.where(label: tag).one
|
|
|
|
posts.post_tags.where(post_id: post_id, tag_id: tag[:id]).changeset(:delete).commit if tag
|
|
end
|
|
|
|
def by_year(year:)
|
|
posts
|
|
.where(post_type: "post", location: nil)
|
|
.exclude(name: nil)
|
|
.published
|
|
.where { Sequel.&(Sequel.extract(:year, :published_at) =~ year) }
|
|
.combine(:tags)
|
|
.to_a
|
|
end
|
|
|
|
def post_listing(limit: nil)
|
|
posts
|
|
.where(post_type: "post", location: nil)
|
|
.exclude(name: nil)
|
|
.published
|
|
.combine(:tags)
|
|
.order(Sequel.desc(:published_at))
|
|
.limit(limit)
|
|
.to_a
|
|
end
|
|
|
|
def photo_listing(limit: nil)
|
|
posts
|
|
.where(post_type: ["post", "checkin"])
|
|
.where(Sequel[:photos].pg_json.array_length > 0)
|
|
.published
|
|
.combine(:tags)
|
|
.order(Sequel.desc(:published_at))
|
|
.limit(limit)
|
|
.to_a
|
|
end
|
|
|
|
def places_listing(limit: nil)
|
|
posts
|
|
.where(post_type: ["checkin", "post"])
|
|
.exclude(location: nil)
|
|
.published
|
|
.combine(:tags)
|
|
.order(Sequel.desc(:published_at))
|
|
.limit(limit)
|
|
.to_a
|
|
end
|
|
|
|
def books_listing(limit: nil)
|
|
posts
|
|
.where(post_type: "book")
|
|
.published
|
|
.order(Sequel.desc(:published_at))
|
|
.limit(limit)
|
|
.to_a
|
|
end
|
|
|
|
def bookmark_listing(query: nil)
|
|
base = posts
|
|
.where(post_type: "bookmark")
|
|
.published
|
|
.combine(:tags)
|
|
.order(Sequel.desc(:published_at))
|
|
|
|
query ? base.where(Sequel.ilike(:name, "%#{query}%")).to_a : base.to_a
|
|
end
|
|
|
|
def statuses_listing(limit: nil)
|
|
posts
|
|
.where(post_type: "post", name: nil)
|
|
.exclude(Sequel.pg_jsonb_op(:syndication_sources).has_key?("instagram"))
|
|
.published
|
|
.combine(:tags)
|
|
.order(Sequel.desc(:published_at))
|
|
.limit(limit)
|
|
.to_a
|
|
end
|
|
|
|
def latest_status
|
|
posts
|
|
.where(name: nil)
|
|
.published
|
|
.order(Sequel.desc(:published_at))
|
|
.limit(1)
|
|
.one
|
|
end
|
|
|
|
def last_location
|
|
posts
|
|
.where(post_type: "checkin")
|
|
.published
|
|
.order(Sequel.desc(:published_at))
|
|
.limit(1)
|
|
.one
|
|
end
|
|
|
|
def from_the_archives(start_date:, end_date:)
|
|
# SELECT * FROM posts
|
|
# WHERE EXTRACT(month FROM "published_at") >= 2
|
|
# WHERE EXTRACT(month FROM "published_at") <= 2+
|
|
# AND EXTRACT(day FROM "published_at") > 20
|
|
# AND EXTRACT(day FROM "published_at") < 27
|
|
# AND post_type = 'post';
|
|
|
|
posts
|
|
.where(post_type: "post")
|
|
.published
|
|
.where { Sequel.extract(:year, :published_at) < start_date.year }
|
|
.where { Sequel.extract(:month, :published_at) >= start_date.month }
|
|
.where { Sequel.extract(:month, :published_at) <= end_date.month }
|
|
.where { Sequel.extract(:day, :published_at) >= start_date.day }
|
|
.where { Sequel.extract(:day, :published_at) <= end_date.day }
|
|
.to_a
|
|
end
|
|
|
|
def for_rss
|
|
posts
|
|
.where(post_type: "post", location: nil)
|
|
.exclude(name: nil)
|
|
.published
|
|
.combine(:tags)
|
|
.order(Sequel.desc(:published_at))
|
|
.to_a
|
|
end
|
|
|
|
def statuses_for_rss
|
|
posts
|
|
.where(post_type: "post", name: nil, location: nil)
|
|
.published
|
|
.combine(:tags)
|
|
.order(Sequel.desc(:published_at))
|
|
.to_a
|
|
end
|
|
|
|
def fetch!(slug)
|
|
posts
|
|
.published
|
|
.combine(:tags, :trips)
|
|
.where(slug: slug)
|
|
.one!
|
|
end
|
|
|
|
def fetch_unpublished!(slug)
|
|
posts
|
|
.combine(:tags)
|
|
.where(slug: slug)
|
|
.one!
|
|
end
|
|
|
|
def find!(id)
|
|
posts
|
|
.by_pk(id)
|
|
.one!
|
|
end
|
|
|
|
def slug_exists?(slug)
|
|
!!posts
|
|
.where(slug: slug)
|
|
.one
|
|
end
|
|
|
|
def delete!(slug)
|
|
delete_post = posts.where(slug: slug).command(:update)
|
|
delete_post.call(published_at: nil)
|
|
end
|
|
|
|
def restore!(slug)
|
|
delete_post = posts.where(slug: slug).command(:update)
|
|
delete_post.call(published_at: Time.now)
|
|
end
|
|
|
|
def post_years
|
|
posts
|
|
.where(post_type: "post", location: nil)
|
|
.exclude(name: nil)
|
|
.published
|
|
.dataset
|
|
.group_and_count(Sequel.extract(:year, :published_at).as(:year))
|
|
.order(:year)
|
|
.to_a
|
|
end
|
|
end
|
|
end
|
|
end
|