बिलमैनेजर के बिना ISPManager5 लाइट में उपयोगकर्ताओं का स्वचालित डिस्कनेक्शन

मई:

  1. स्थायी लाइसेंस के साथ VPS सर्वर ispmanager lite 5
  2. प्रति सर्वर 10-20 उपयोगकर्ता
  3. Google कैलेंडर उन लोगों के लिए नियमित अनुस्मारक के साथ जिनकी होस्टिंग समाप्त हो गई है
  4. किसी भी अन्य चीज़ के लिए भुगतान करना शर्म की बात है, विशेषकर सदस्यता के लिए।

लक्ष्य ग्राहक को Google कैलेंडर और मैन्युअल अनुस्मारक से छुटकारा दिलाना है कि उसे होस्टिंग के लिए भुगतान करना होगा। अपने आप को "उसे थोड़ा और काम करने दो, वह जल्द ही भुगतान करेगा", "इसे बंद करना किसी तरह से असुविधाजनक है" से मुक्त करें और इसे एक निष्प्राण मशीन को सौंप दें।

बेशक, मैंने पहले Google पर खोजा और खोजा, लेकिन कोई समाधान नहीं मिला, यह सब इस तथ्य पर आधारित था कि आपको BILLmanager की सदस्यता लेने की आवश्यकता है, लेकिन बिंदु संख्या 4 मेरे लिए बहुत महत्वपूर्ण और गंभीर है, मुझे नहीं मिलेगा इससे छुटकारा। और निर्णय इतना कठिन नहीं निकला।

तो हम क्या करें?

एक फ़ोल्डर user.addon बनाएं, /usr/local/mgr5/etc/sql/ निर्देशिका में, दो खाली फ़ाइलें:

  1. भुगतान की तिथि
  2. uwemail

यह पैनल को डेटाबेस बनाने का आदेश देगा
/usr/local/mgr5/etc/ispmgr.db
उपयोगकर्ता तालिका में दो संबंधित फ़ील्ड हैं जहां व्यवस्थापक पैनल से मान लिखे जाएंगे।

सामग्री के साथ /usr/local/mgr5/etc/xml फ़ोल्डर में ispmgr_mod_pay_data.xml नामक फ़ाइल बनाएं

<?xml version="1.0" encoding="UTF-8"?>
<mgrdata>
	<metadata name="user.edit">
		<form>
			<page name="main">
				<field name="pay_date">
					<input type="text" name="pay_date"/>
				</field>
				<field name="uwemail">
					<input type="text" name="uwemail"/>
				</field>
			</page>
		</form>
	</metadata>
	<lang name="ru">
		<messages name="user.edit">
			<msg name="pay_date" sqlname="pay_date">Оплачено до</msg>
			<msg name="uwemail" sqlname="uwemail">Пользовательский email</msg>
		</messages>
	</lang>	
	<lang name="en">
		<messages name="user.edit">
			<msg name="pay_date" sqlname="pay_date">Paid before</msg>
			<msg name="uwemail" sqlname="uwemail">User email</msg>
		</messages>
	</lang>
</mgrdata>

यह पैनल को एक नियम देता है ताकि हमारे फ़ील्ड उपयोगकर्ता के संपादन फॉर्म में प्रदर्शित हों।

पैनल को रीबूट करें:

/usr/local/mgr5/sbin/mgrctl -m ispmgr exit

हमें मिलता है:

बिलमैनेजर के बिना ISPManager5 लाइट में उपयोगकर्ताओं का स्वचालित डिस्कनेक्शन

फ़ील्ड में हम लिखते हैं कि होस्टिंग किस दिन तक काम करनी चाहिए, और उपयोगकर्ता का कौन सा ईमेल, कहाँ अनुस्मारक भेजना है कि होस्टिंग जल्द ही समाप्त हो जाएगी।

अब हमें एक ऐसी स्क्रिप्ट बनाने की ज़रूरत है जो उपयोगकर्ताओं को याद दिलाए कि होस्टिंग कुछ अंतराल पर समाप्त हो जाती है। व्यवस्थापक को सूचित करें कि होस्टिंग समाप्त हो रही है। उपयोगकर्ता और व्यवस्थापक को सूचित करें कि उपयोगकर्ता अक्षम है।

मुझे इस पर php पसंद है और मैंने एक स्क्रिप्ट लिखी है।

<?php
$adminemail = "[email protected]"; // email админа
$day_send_message = [30,7,5,3,1]; // за сколько дней и с какой переодичностью будет напоминать пользователю что хостинг заканчивается
$db = new SQLite3('/usr/local/mgr5/etc/ispmgr.db');
$results = $db->query('SELECT * FROM users WHERE active == "on" AND pay_date IS NOT NULL');
while ($user = $results->fetchArray()) {
		$days_left=floor( ( strtotime($user['pay_date']) - time() ) / (60 * 60 * 24));
		if(in_array($days_left, $day_send_message)){
			if($user['uwemail'] != ""){
				mail($user['uwemail'], 'ISPMANAGER заканчивается хостинг через '.$days_left.' днейя', "Текст для пользователя о том что осталось столько то дней");
			}
		}
		if( $days_left == 3 ) {
			mail($adminemail, 'ISPMANAGER USER '.$user['name'], $user['name'] . " Закончится хостинг через ".$days_left." дня");
		}
		if($days_left <= 0){
			mail($adminemail, 'ISPMANAGER USER '.$user['name'].' DISABLED', $user['name'].' Отключен');
			exec("/usr/local/mgr5/sbin/mgrctl -m ispmgr user.suspend elid=".$user["name"]);
			if( $user['uwemail'] != "" ) {
				mail($user['uwemail'], 'ISPMANAGER хостинг отключен', 'Текст для пользователя что хостинг закончился'); 
			}
		}
		// при желании можно еще написать небольшой IF что бы данные удалялись через некоторое время, но мне это не нужно
}

हम इस स्क्रिप्ट को कहीं भी सहेजते हैं और इसे जो चाहें नाम देते हैं, और इसे दिन में एक बार कॉल करने के लिए एक क्रॉन कार्य जोड़ते हैं। सब तैयार है.

अब मेरी अंतरात्मा साफ है, टॉड संतुष्ट है, और मैंने कोई अतिरिक्त लागत नहीं लगाई है।

जो कुछ बचा है, उसमें उपयोगकर्ताओं का डेटा भरना है कि किस तारीख को होस्टिंग के लिए भुगतान किया गया था, और उपयोगकर्ताओं का ईमेल जहां उपयोगकर्ताओं को अनुस्मारक भेजना है।

अगर यह किसी की मदद करता है तो ख़ुशी होगी।

स्रोत: www.habr.com

एक टिप्पणी जोड़ें