From c0d227aa56d40f5b66b1c21469fe95fef5d24a95 Mon Sep 17 00:00:00 2001 From: Mir Bhatia Date: Fri, 27 Mar 2026 15:17:35 +0100 Subject: [PATCH] Add migration to backfill sharing values for old onetime templates --- ...sharing_for_existing_one_time_templates.rb | 45 +++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 modules/meeting/db/migrate/20260327140627_backfill_sharing_for_existing_one_time_templates.rb diff --git a/modules/meeting/db/migrate/20260327140627_backfill_sharing_for_existing_one_time_templates.rb b/modules/meeting/db/migrate/20260327140627_backfill_sharing_for_existing_one_time_templates.rb new file mode 100644 index 00000000000..179e8f32044 --- /dev/null +++ b/modules/meeting/db/migrate/20260327140627_backfill_sharing_for_existing_one_time_templates.rb @@ -0,0 +1,45 @@ +# frozen_string_literal: true + +#-- copyright +# OpenProject is an open source project management software. +# Copyright (C) the OpenProject GmbH +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License version 3. +# +# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows: +# Copyright (C) 2006-2013 Jean-Philippe Lang +# Copyright (C) 2010-2013 the ChiliProject Team +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation; either version 2 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +# +# See COPYRIGHT and LICENSE files for more details. +#++ + +class BackfillSharingForExistingOneTimeTemplates < ActiveRecord::Migration[8.1] + def up + execute <<~SQL.squish + UPDATE meetings + SET sharing = 'none' + WHERE template = TRUE + AND recurring_meeting_id IS NULL + AND sharing IS NULL + SQL + end + + def down + # no-op as user set vs. migration set "none" values cannot be distinguished + end +end