草庐IT

ruby-on-rails - 为什么 PG::UniqueViolation: ERROR: duplicate key value violates unique constraint?

我有一个模型Post,每次创建帖子时,我都希望同时创建一个新的Moderation实例。所以在post.rb中我使用回调after_save:create_moderation然后写一个私有(private)方法:...includeReportableafter_save:create_moderationprivatedefcreate_moderationself.create_moderation!(blog:Blog.first)end但是在创建提案时出现此错误:PG::UniqueViolation:ERROR:duplicatekeyvalueviolatesunique

ruby - 如何为 Ruby 应用程序创建 REST API?

我想知道如何为Ruby应用程序提供RESTAPI。我可以基于Ruby的TCPServerAPI编写一些代码,但这似乎有点低级。你认为这是一个好的解决方案吗?或者您推荐更好的方法? 最佳答案 您可以使用Sinatra非常快速地编写微型、专注的Web应用程序和轻量级REST服务。在documentation他们重点介绍了有关该问题的几个视频:AdamWiggins和BlakeMizerany介绍Sinatra和RestClient在RubyConf2008.演讲详细介绍了Sinatra的基本理念,并反射(reflection)了如何使用

ruby - 为 API 包装器实现类似 ActiveRecord 的关联

我最近写了ParseResource,它是Parse.com's的RubyAPI包装器REST接口(interface)。下面是一些基本用法:classPost"Helloworld",:author=>"Alan",:body=>"ipsolorem")这个项目还很年轻,我真正想要实现的一个功能是关联。像这样:classAuthor"Alan",:email=>"alan@example.com")p=Post.create(:title=>"Associated!",:body=>"ipsolorem",:author=>a)p.author.class#=>Authorp.aut

ruby-on-rails - Rails 应用程序和 goliath api 以及数据库/模型共享

我正在尝试使用Goliath框架创建异步API。服务应该写入mysql,将消息添加到RabbitMQ并接收返回的响应。还应该有一个用Rails构建的单独的管理应用程序。我对此有几个问题:有没有办法在Rails和Goliath之间有效地共享模型?在em中使用Activerecord或任何其他orm有什么问题吗?是否有任何最佳实践、配置(连接池大小、驱动程序)或其他相关选项?我必须使用什么来接收来自AMQP的消息?构建一个单独的eventmachine守护进程会更好,还是我可以以某种方式使用Goliath的守护进程?感谢您的提前。 最佳答案

ruby-on-rails - neo4j 的哪个 Ruby REST API 客户端?

我想知道Ruby(不是JRuby,所以native绑定(bind)不是一个选项)可以使用哪些RESTAPI客户端?理想情况下,我希望API类似于neo4jgem或ActiveRecord(验证、迁移、观察者等)。当前可用的(REST)工具甚至无法与我们所拥有的相提并论,例如,在ActiveRecrod中:neograhy-只是普通RESTAPI。与模型等无关neology-只是对新地理学的包装,并不是功能齐全的ActiveModel。architect4r-符合ActiveModel,但仅提供一种查询数据的方式(Cypher语言),也不支持索引。我更喜欢architect4r的代码(主

ruby - 无法使用 key 与 Ruby 和 net/ssh 连接

我在使用“net-ssh”gem从ruby​​通过ssh连接时遇到问题,得到Net::SSH::AuthenticationFailed。代码如下require'net/ssh'keys=["path_to_private_key"]Net::SSH.start('host','user',:keys=>keys,:verbose=>:debug)do|ssh|#sshcodeend直接从命令行使用ssh是可行的:ssh-iuser@host我的sshAPI有误吗?我已经尝试将“user@host”和“user”作为用户名,结果相同。这是调试输出:D,[2011-07-26T19:42

ruby-on-rails - 缺少 `secret_token` 和 `secret_key_base` - Rails 4.2.0 with RVM

最近,我从Git中提取了一个存储库。启动服务器后,我收到以下消息:缺少secret_token和secret_key_base。这可能是因为我在我的.gitignore中包含了secrets.yml。我目前的设置Ubuntu14.04ruby2.2.0p0rails4.2.0rvm1.26.11本地服务器(非远程)开发环境许多在线资源指出我必须使用rakesecret生成新key并将其添加到secrets.yml中。将key放在secrets.yml中并重新启动Rails服务器不起作用。Edited:Addedcontentsofsecrets.ymlbelow.-04/30/159:

ruby-on-rails - 在 Rails 5.2 中分离 secret_key_base?

我刚刚从5.1升级到5.2,我对这种“更好”的secret存储方法感到很困惑...也许我不明白,但现在开发和生产似乎已经“合并”到一个单一的SECRET_KEY_BASE以及master.key中......这是正确的吗?如果没有,我如何在开发中使用单独的主key和SECRET_KEY_BASE?如果我有开发人员帮助我并且我不想让他们知道我在生产中使用的主key(或secret)怎么办? 最佳答案 Rails5.2对此做了很大的改变。对于开发和测试环境,secret_key_base是自动生成的,因此您可以将其从secrets.ym

ruby - 公司目录的 LinkedIn API

我正在尝试使用LinkedInAPI搜索公司,而不是用户。我特别不想要用户-只有公司。我查看了LinkedInAPI文档(RTFM等),但据我所知它不受支持。论坛上有2个帖子几乎直截了本地说明了这一点-here和here我基本上只是在寻找一个简单的搜索界面,类似于LinkedIn主页上正在发生的事情。我还想以某种方式显示返回的信息。我是否最好只对网站本身进行手动GET操作?我需要缓存结果吗?我需要手动解析返回的HTML吗?我计划在Ruby中实现它,但这并不是我真正关心的。 最佳答案 更新:现在有一个官方API:https://dev

ruby-on-rails - 安装 New Relic 而不向 repo 添加许可证 key

我想在我的一个开源Rails应用程序(v3.2.12)上安装NewRelic。我不想在repo协议(protocol)中拥有许可证key。我想用ENV之类的东西加载它。默认加载到newrelic.yml文件中。YAML文件在哪里加载?我想我可以手动将它与从ENV哈希加载许可证的哈希合并。关于如何做到这一点的任何提示? 最佳答案 我使用Figarogem使用ENV环境变量处理key,类似于您。对于NewRelic,我有:config/application.yml(.gitignored且未推送到源代码管理)#...NEW_RELIC