BILLmanager లేకుండా ISPManager5 లైట్‌లోని వినియోగదారుల ఆటోమేటిక్ డిస్‌కనెక్ట్

May:

  1. శాశ్వత లైసెన్స్ ispmanager లైట్ 5తో VPS సర్వర్
  2. సర్వర్‌కు 10-20 మంది వినియోగదారులు
  3. హోస్టింగ్ అయిపోయిన వారి కోసం రెగ్యులర్ రిమైండర్‌లతో Google క్యాలెండర్
  4. ముఖ్యంగా సబ్‌స్క్రిప్షన్‌తో ఏదైనా చెల్లించడం సిగ్గుచేటు.

క్లయింట్ హోస్టింగ్ కోసం చెల్లించాల్సిన Google క్యాలెండర్ మరియు మాన్యువల్ రిమైండర్‌లను వదిలించుకోవడమే లక్ష్యం. "అతను కొంచెం ఎక్కువ పని చేయనివ్వండి, అతను త్వరలో చెల్లిస్తాడు", "దీన్ని ఆఫ్ చేయడం ఏదో ఒకవిధంగా అసౌకర్యంగా ఉంది" నుండి మిమ్మల్ని మీరు విడిపించుకోండి మరియు దీనిని ఆత్మలేని యంత్రానికి అప్పగించండి.

అయితే, నేను మొదట గూగుల్ చేసి శోధించాను, కానీ పరిష్కారాలు ఏవీ కనుగొనబడలేదు, మీరు BILLmanagerకి సబ్‌స్క్రయిబ్ చేసుకోవాల్సిన అవసరం ఉంది, కానీ పాయింట్ నెం. 4 నాకు చాలా ముఖ్యమైనది మరియు తీవ్రమైనది, నేను పొందలేను దాన్ని వదిలించుకోండి. మరియు నిర్ణయం అంత కష్టం కాదని తేలింది.

కాబట్టి మనం ఏమి చేయాలి?

ఫోల్డర్‌ను సృష్టించండి users.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

ఒక వ్యాఖ్యను జోడించండి