- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
用户查看其他用户的个人资料并标记批准
或拒绝
,如 Tinder 或类似的约会应用程序。
我正在构建一个后端带有 ActiveRecord 和 PostgreSQL 的 Rails 服务器。
我正在考虑拥有一个User
模型,然后是一个具有user_id
和approved_id
的Approval
模型。
批准:
create_table "approvals", force: :cascade do |t|
t.integer "user_id"
t.integer "approved_id"
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.datetime "user1_approval"
t.datetime "user2_approval"
t.datetime "denied_at"
end
class User
has_many :approvals
has_many :approved, through: :approvals
has_many :inverse_users, class_name: "Approval", foreign_key: "approved_id"
has_many :inverse_approvals, through: :inverse_users, source: :user
class Approval
def self.user_approval(user1, user2)
sorted = [user1, user2].sort_by { |u| u.name}
Approval.find_or_create_by(user: sorted[0], approved: sorted[1])
end
这具有限制 Approval
对象数量的优势 - 每对 User
对象只有 1 个。但是,我不确定如何有效地查询此架构。
例如,在查找approve
或reject
操作时,我必须手动检查提交的user_id
是否与user_id 匹配
或 approved_id
以适本地设置 user1_approval
或 user2_approval
。
我正在考虑通过一个简单的过滤器(年龄范围在 10 年以内)查找用户
所以在 User
中我有:
def self.eligible(user)
users = User.where('age >= ? AND age <= ? AND id != ?', user.lowest_eligible_age,user.maximum_eligible_age, user.id).limit(20)
approvals = []
users.each do |u|
approvals.push(Approval.user_approval(user, u ))
end
approvals.reject! { |a| a.denied_at}
approvals
end
这对于获取符合条件的用户的候选名单非常有用。它还具有允许 /approvals/:id/approve
& /approvals/:id/reject
的 api 的优点。
我想知道使用像 /users/:id/approve
这样的 API 是否更有意义,然后让该操作相应地生成 Approval
。每个 Approval
对象都有一个 user_id
和一个 related_approval_id
所以它可以链接到一个相互的 Approval
(其中目标用户与链接批准的 user_id
相同)。
create_table "approvals", force: :cascade do |t|
t.integer "user_id"
t.integer "approved_id"
t.integer "related_approval_id"
这样做会在数据库中产生更多的行。
我希望这是有道理的。我正在寻找一个好的架构解决方案来解决用户相互批准和拒绝的问题,这样我就可以进行良好的查询,比如只显示 User
哪些 current_user
没有批准,哪些没有拒绝当前用户。
最佳答案
因为用户可以在 Tinder 中被“批准”或“拒绝”,所以将此模型称为决策更有意义。这就是我的看法。
create_table "users", force: :cascade do |t|
t.integer "id"
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.integer "age"
...etc...
end
用户模型表示将对另一个用户做出决定或另一个用户将对另一个用户做出决定的应用程序的任何用户。
create_table "decision", force: :cascade do |t|
t.integer "id"
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.integer "decision_maker_id"
t.integer "decision_receiver_id"
t.boolean "approved"
t.boolean "active"
...etc...
end
决策代表用户之间的任何交互。在用户身上向右滑动是一个决定。来自对方用户的响应滑动是另一个决定。这不是表示为一个完整的对象,而是表示为两个单独的“决策”交互。
让我解释一下 Decision 中的字段的含义:
在决策模型中,您需要一个 before_save 回调来检查正在保存的决策是否已经有对应的回复决策。如果是这样,那么您可能希望决定不再有效,这样它就不会再出现在提要中。然后,您可以通知用户他们同意/不同意,或者在您的应用中此时您希望做的任何事情。
before_save: check_for_existing_reply
def check_for_existing_reply
# if there is a decision object with this decision_maker_id and this
# decision_receiver_id but in opposite fields then you know there is a reply
# and you can take some action here
end
在用户模型中,您可以编写方法来查找所有存在的事件批准/拒绝。
scope :decisions, -> (id, approval_type) { where('decision_receiver_id = ? AND approved = ? AND active = true', approval_type) }
通过使用 User.decisions(user_id, true)
调用该范围,您可以获得用户的所有批准。通过使用 user.decisions(user_id, false)
调用该范围,您可以获得用户的所有拒绝。
您也可以将其分为两个独立的范围,一个用于批准,一个用于拒绝。
scope :approvals, -> (id) { where('decision_receiver_id = ? AND approved = ? AND active = true', true) }
scope :rejections, -> (id) { where('decision_receiver_id = ? AND approved = ? AND active = true', false) }
最后,您可以将其设为在 User 实例上调用的方法,这样您就不必传入 id 参数。
# where decision = true would mean approvals and decision = false would mean rejections
def get_decisions(decision)
return User.where('decision_receiver_id = self.id AND approved = decision AND active = true') }
end
您可以在 User 的实例上调用它,例如 user.get_decisions(true)
。
关于ruby-on-rails - 用户的 Postgres 架构 & 批准约会风格应用程序的用户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31259021/
构建用于批准或拒绝用户的 RESTful 资源的正确方法是什么? 此资源旨在由管理员审查用户。管理员可以批准或拒绝用户请求。请求需要有 user_id和 updated_status那可能是 appr
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 2年前关闭。 Improve this
我计划创建状态通知。例如,每当信息是 "Pending", it turns to color orange. When "Approved" it turns to color green and
假设我设置了一个存储库。我希望有的用户可以推送,有的用户我想先过一遍推送的内容再批准。有条件推送之类的概念吗?待批准推送队列? 最佳答案 您本质上需要一个代码审查工具。 git 有一些,但最好的可能是
我目前正在将我的一个网站从旧系统升级到 HTML5,但我在使用 Google Maps JavaScript API v3 时遇到了一些问题。要从他们的 API 获取数据,您必须有一个 key - 当
我们想将 JIRA 与 GITLAB 集成以获得批准。当 CICD Pipeline 运行时,它会部署到 DEV/QA,当它部署到 PROD 时,我们要检查两件事 经理/代码所有者批准了一项合并请求
我在我的网站中使用 Authy 进行 2 因素身份验证。我的代码发送了一个推送通知,我在手机上的 Authy 应用程序中收到了它。但问题是有时当我尝试接受/拒绝请求时,我收到一条错误消息 There
我正在修改网站以允许用户输入内容。但是,一旦他们创建了该内容,就需要在发布之前获得批准。这很容易通过在该内容的记录中设置一个“中等”位来实现,并且只需要一个表。 现在我还希望允许用户像在 StackO
我正在使用 ubuntu 12.04,我有一个应用程序,当我运行时,退出: ./ardrone_navigation Setting locale to en_GB.UTF-8 Errore di s
我在 gitlab 有两个分支 master 和 release。 在发布分支,我希望它只有提交消息,如:v0.1.0,v0.1.1。 说在我完成 v0.1.0 开发后,我在 master 中有几个功
我们为一家想要在自己的帐户下发布该应用程序的公司开发了一个应用程序。它是在我们的帐户上开发的,并且已从我们自己的帐户附加了配置文件。做这个的最好方式是什么?我是否必须向他们发送 xCode 项目并告诉
我正在构建一个网站,用户可以在其中更改其公开显示的个人资料。但是,我需要所有更改在上线之前都得到管理员的批准。在更改获得批准之前,他们的旧个人资料将显示。在管理员中应该有一个等待批准的配置文件列表。最
我正在构建一个网站,用户可以在其中更改其公开显示的个人资料。但是,我需要所有更改在上线之前都得到管理员的批准。在更改获得批准之前,他们的旧个人资料将显示。在管理员中应该有一个等待批准的配置文件列表。最
在我们的团队中,一名开发人员将应用送交审核。 它通过了,但在某些时候开发者证书不再有效。 我们现在无法在外部或内部测试人员中下载应用。 如果我们发布那个版本会怎样? 我将感谢您的经验和意见。 最佳答案
更新: $(document).ready(function () { $('#C1All').click(functio
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 8 年前。 Improve
我在 Gitlab 中找不到在我看来常见情况的选项,即仅批准 merge 请求,但不触发构建。我需要将流程分为两个操作:审批者审查并批准 merge 请求,但 merge 请求的作者将进行 merge
这个问题在这里已经有了答案: How to access the correct `this` inside a callback (15 个答案) 关闭 3 年前。
我正在尝试使用新的 Azure AD Privileged Identity Management REST API 批准/拒绝角色激活请求。 我已经能够使用以下请求读取所有待处理的角色激活请求: G
我的网站是一个用 AngularJs 编写的单页应用程序。 我正在尝试为某些页面添加 AdSense。提交后,我的网站被拒绝,原因如下:“内容不足”。 我的问题是:考虑到我们使用 escaped_fr
我是一名优秀的程序员,十分优秀!