From 86ae854d0eaac7ee2f88348eb71b4335a4854fa1 Mon Sep 17 00:00:00 2001 From: elijah Date: Tue, 2 Feb 2016 18:06:05 -0800 Subject: allow legacy plain couchdb nodes to stay couchdb nodes, although issue a warning. --- provider_base/services/couchdb.rb | 24 +++++++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) diff --git a/provider_base/services/couchdb.rb b/provider_base/services/couchdb.rb index 124c1b6c..8271b9c5 100644 --- a/provider_base/services/couchdb.rb +++ b/provider_base/services/couchdb.rb @@ -6,11 +6,33 @@ # to always use plain couchdb, unless there are more than one couchdb # node or if "couch.mode" property is set to "multimaster". # +# in the past, it used to work like this: +# +# * if couch.master was set to true on one node, then do plain couchdb. +# * if couch.master was not set anywhere, then do bigcouch. +# * if couch.master was set on more than one node, then do bigcouch. +# +# Some of this legacy logic is still supported so that upgrading does +# not unexpectedly turn bigcouch nodes into plain couchdb nodes. +# + +if self.couch['master'] + LeapCli::log :warning, "The node property 'couch.master' is deprecated.\n" + + " In the future, you must set 'couch.mode' to either 'plain' or 'multimaster'.\n" + + " (node '#{self.name}')" +end couchdb_nodes = nodes_like_me['services' => 'couchdb'] -if couchdb_nodes.size > 1 || self['couch']['mode'] == "multimaster" +if couchdb_nodes.size > 1 apply_partial 'services/_couchdb_multimaster.json' +elsif self.couch.mode == "multimaster" + if self.couch['master'] + # The old deprecated way of specifying plain couch is still being used + apply_partial 'services/_couchdb_plain.json' + else + apply_partial 'services/_couchdb_multimaster.json' + end else apply_partial 'services/_couchdb_plain.json' end -- cgit v1.2.3