用于构建成就系统的现代 Ruby/Rails 工具

Posted

技术标签:

【中文标题】用于构建成就系统的现代 Ruby/Rails 工具【英文标题】:Modern tools for Ruby/Rails for building an achievement system 【发布时间】:2012-03-25 08:52:40 【问题描述】:

我有兴趣为我的 Ruby on Rails 应用程序构建一个强大的成就系统。

成就可以通过多种方式发生。通常,我们会有一些标准可能会发生在几个模型上,一些是必需的,一些是可选的(混合和匹配)来触发成就。

我想说这类似于这里的成就系统或 Foursquare 徽章。理想情况下,如果有一个现代工具可以帮助抽象一些 DSL 中的大量工作,那就太好了。

我很想看看其他人如何使用 Ruby 或 Ruby on Rails 解决这个问题。从头开始构建这个听起来不合理,因为我确信它已经被反复解决了很多次。

【问题讨论】:

喜欢什么样的工具? DSL 有什么想法? 一颗宝石。现有的平台/服务。任何有助于在 Ruby 或 Ruby on Rails 应用程序中构建成就系统的东西,而无需从头开始编写。 【参考方案1】:

成就系统乍一看似乎很简单,但很快就会变得相当复杂。

首先,您必须确定您想要提供什么样的成就。您可以奖励:

    徽章 积分 排名

当然,您还需要对它们进行各种组合。 不明显但经常被问到的功能是:

能够了解其在特定排名徽章方面的进展。 能够隐藏一些徽章

在 RoR 世界中,我发现了 3 个免费提供的第三方库。通常,没有灵丹妙药,您必须根据自己的需要选择一种。

可标记

Badgeable 是一个简单的 DSL,它只实现了一个 badge 系统。它是动态的且易于理解。这个例子来自官方文档:

badge "Fancy Pants" do
  thing Meal
  subject :person
  count
    Meal.where(:price_cents.gte => 10000).count >= 12
  end
  conditions do |meal|
    meal.restaurant.city != meal.eater.city
  end
end

它会将 Fancy Pants 徽章奖励给吃过 12 顿昂贵餐点且奖励餐点不在城里的用餐者。它包括有趣的功能,例如 unseen 徽章,但不能多次授予相同的徽章。默认情况下,Badgeable 在创建观察记录后添加挂钩。在上面的示例中,徽章条件在每个 Meal 创建后执行。

它同时支持 ActiveRecord 和 Mongoid。

荣耀之路

Paths of Glory 与 Badgeable 完全不同。这颗宝石更倾向于 PointsRanks。它将计算徽章的逻辑(观察者)与描述徽章的逻辑(成就类)分开。如果您已经使用 Observer 模式,对您来说可能会更自然。请注意,它是纯 Ruby,在 Paths of Glory 中没有 DSL。

在成就类中,您描述了您的等级、您的计数以及如何奖励成就:

level 1, :quota => 2
level 2, :quota => 4
level 3, :quota => 6

set_thing_to_check  |user| user.posts.count 

def self.award_achievements_for(user)
  return unless user
  return if user.has_achievement?(self)
  user.award_achievement(self)
end

观察者部分非常经典:

  observe :post

  def after_save(post)
    Teacher.award_achievements_for(post.user) unless post.new_record?
  end

没有很好的文档记录,但您可以找到使用它的示例应用程序here。

它包括帮助器,以便跟踪下一个排名的进度。由于它使用经典的 Rails 功能,它应该与所有可用的 Rails ORM 兼容。

优点

Merit 似乎是关于这个主题的更完整的宝石,ATM。它允许使用 DSL 定义 badgespointsrules

对于徽章,它看起来像:

grant_on ['users#create', 'users#update'], :badge => 'autobiographer', :temporary => true do |user|
  user.name.present? && user.address.present?
end

如果用户输入了地址,它将检查创建和更新。如果用户删除其地址,它将删除徽章。

对于分数,它能够根据多个模型计算一个分数

score 20, :on => [ 'comments#create', 'photos#create' ]

对于等级,它与徽章非常相似。区别主要在级别

set_rank :stars, :level => 2, :to => Commiter.active do |commiter|
  commiter.branches > 1 && commiter.followers >= 10
end

set_rank :stars, :level => 3, :to => Commiter.active do |commiter|
  commiter.branches > 2 && commiter.followers >= 20
end

这个 gem 还提供了在 cron 作业中计算徽章或等级的方法,而不是在每次写入对象之后:

task :cron => :environment do
  MeritRankRules.new.check_rank_rules
end

在后台,Merit 使用Ambry 来存储徽章信息。它应该有助于减少数据存储上的噪音并使其更快一点。 MongoMapper 有一个实验性的支持。我还没有找到任何方法来获得unseen徽章或跟踪徽章的进度。

【讨论】:

这句话:“荣耀之路没有 DSL”本身已经是一种智慧。 惊人的答案,感谢您抽出宝贵的时间来写这篇文章。它对我帮助很大。【参考方案2】:

activerecord-reputation-system 如果您需要全面的解决方案,请通过 twitter 人员。

【讨论】:

【参考方案3】:

你看过Badgeable吗?

【讨论】:

【参考方案4】:

你可以使用http://www.badgeville.com/之类的东西

【讨论】:

以上是关于用于构建成就系统的现代 Ruby/Rails 工具的主要内容,如果未能解决你的问题,请参考以下文章

如何快速正确的安装 Ruby,Rails 运行环境 · Ruby China

构建之法现代软件工程自我介绍

Extjs 6 - 现代工具包 ui-mixins 构建错误

如何快速正确的安装 Ruby,Rails 运行环境 · Ruby China

使用 ruby​​/rails 将文件上传到网站

Ruby/Rails:重新打开与覆盖类