BILLmanager இல்லாமல் ISPManager5 லைட்டில் பயனர்களின் தானியங்கி துண்டிப்பு

கொடுக்கப்பட்ட:

  1. நிரந்தர உரிமத்துடன் கூடிய VPS சர்வர் ispmanager lite 5
  2. ஒரு சேவையகத்திற்கு 10-20 பயனர்கள்
  3. ஹோஸ்டிங் முடிந்துவிட்டவர்களுக்கு வழக்கமான நினைவூட்டல்களுடன் Google Calendar
  4. வேறு எதற்கும் பணம் செலுத்துவது வெட்கக்கேடானது, குறிப்பாக சந்தாவுடன்.

ஹோஸ்டிங் செய்ய வாடிக்கையாளர் பணம் செலுத்த வேண்டிய கூகுள் காலண்டர் மற்றும் கைமுறை நினைவூட்டல்களை அகற்றுவதே குறிக்கோள். "அவர் இன்னும் கொஞ்சம் வேலை செய்யட்டும், அவர் விரைவில் பணம் செலுத்துவார்", "அதை முடக்குவது எப்படியோ சிரமமாக உள்ளது", மேலும் இதை ஆன்மா இல்லாத இயந்திரத்திடம் ஒப்படைக்கவும்.

நிச்சயமாக, நான் முதலில் கூகிள் செய்து தேடினேன், ஆனால் எந்த தீர்வும் கிடைக்கவில்லை, நீங்கள் BILLmanager க்கு குழுசேர வேண்டும் என்ற உண்மையைப் பற்றி எல்லாம் கொதித்தது, ஆனால் புள்ளி எண் 4 எனக்கு மிகவும் முக்கியமானது மற்றும் தீவிரமானது, நான் அதைப் பெறமாட்டேன் அதை அகற்று. மற்றும் முடிவு மிகவும் கடினம் அல்ல என்று மாறியது.

எனவே நாம் என்ன செய்வது?

பயனர்கள்.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

நாங்கள் பெறுகிறோம்:

BILLmanager இல்லாமல் 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

கருத்தைச் சேர்