aboutsummaryrefslogtreecommitdiffstats
path: root/trunk/etherpad/src/etherpad/db_migrations/m0036_create_missing_subscription_records.js
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/etherpad/src/etherpad/db_migrations/m0036_create_missing_subscription_records.js')
-rw-r--r--trunk/etherpad/src/etherpad/db_migrations/m0036_create_missing_subscription_records.js45
1 files changed, 45 insertions, 0 deletions
diff --git a/trunk/etherpad/src/etherpad/db_migrations/m0036_create_missing_subscription_records.js b/trunk/etherpad/src/etherpad/db_migrations/m0036_create_missing_subscription_records.js
new file mode 100644
index 0000000..ce77734
--- /dev/null
+++ b/trunk/etherpad/src/etherpad/db_migrations/m0036_create_missing_subscription_records.js
@@ -0,0 +1,45 @@
+/**
+ * Copyright 2009 Google Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS-IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import("dateutils");
+import("etherpad.utils.isPrivateNetworkEdition");
+import("sqlbase.sqlobj");
+
+function run() {
+ if (isPrivateNetworkEdition()) {
+ return;
+ }
+
+ var allDomains = sqlobj.selectMulti('pro_domains', {}, {});
+
+ allDomains.forEach(function(domain) {
+ var domainId = domain.id;
+ var accounts = sqlobj.selectMulti('pro_accounts', {domainId: domainId}, {});
+ if (accounts.length > 3) {
+ if (! sqlobj.selectSingle('billing_purchase', {product: "ONDEMAND", customer: domainId}, {})) {
+ sqlobj.insert('billing_purchase', {
+ product: "ONDEMAND",
+ paidThrough: dateutils.noon(new Date(Date.now()-1000*86400)),
+ type: 'subscription',
+ customer: domainId,
+ status: 'inactive',
+ cost: 0,
+ coupon: ""
+ });
+ }
+ }
+ });
+} \ No newline at end of file