Serving a payment option for my minecraft server so I don't have to pay for it all alone
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Plugin.php 17KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386
  1. <?php
  2. class MinecraftPaymentPlugin extends Plugin {
  3. public static function get_plugin_name(): string {
  4. return 'Minecraft Payment';
  5. }
  6. public function __construct( $_DB ) {
  7. $this->require_class( 'RCon' );
  8. }
  9. public function has_page(): bool {
  10. return true;
  11. }
  12. public function get_page_path() {
  13. return [
  14. '/minecraft-pay/' => [
  15. 'settings' => [
  16. null => 'settings_view',
  17. '/*' => 'server_settings_view'
  18. ],
  19. 'users' => [
  20. null => 'users_view',
  21. '/*' => 'user_view'
  22. ],
  23. 'grant' => 'grant_view',
  24. 'settle' => 'settle_view',
  25. 'balance' => 'balance_view',
  26. 'acredit' => 'acredit_view'
  27. ]
  28. ];
  29. // return [ '/minecraft-pay/settings', '/minecraft-pay/settings/*', '/minecraft-pay/users', '/minecraft-pay/grant', '/minecraft-pay/settle', '/minecraft-pay/balance', '/minecraft-pay/users/*', '/minecraft-pay/acredit' ];
  30. }
  31. public function grant_view( string $url ) {
  32. if ( !Permission::PERMITTED( 'Minecraft-Pay-Settings', 1 ) ) return;
  33. $params = [];
  34. if ( array_key_exists( 'GrantUserRights', $_POST ) && array_key_exists( 'ID', $_POST ) ) {
  35. $u = User::GetByID( $_POST[ 'ID' ] );
  36. $s = false;
  37. if ( !is_null( $u ) ) {
  38. $p = Permission::SEARCH( 'Minecraft-Possess-User' );
  39. $s = $p->grant_user( $u->GetID(), true ); $s = true;
  40. // echo $p;
  41. // echo $s;
  42. $params[ 'save_message' ] =
  43. // $s ?
  44. __( [ 'de' => 'Recht erfolgreich gew&auml;hrt', 'en' => 'Right granted successfully' ] ); // :
  45. // __( [ 'de' => 'Recht konnte nicht gew&auml;hrt werden', 'en' => 'Right could not be granted' ] );
  46. }
  47. else $params[ 'save_message' ] = __( [ 'de' => 'Benutzer nicht gefunden', 'en' => 'Could not find user' ] );
  48. $params[ 'save_success' ] = $s;
  49. }
  50. $this->show_template( 'GrantUser', $params );
  51. }
  52. private function settle( $m, $y ) {
  53. $mp = MinecraftMonthPaid::GetByUnique( 0, $m ,$y );
  54. if ( $mp ) {
  55. echo __( [ 'de' => 'Bereits abgerechnet', 'en' => 'Already settled' ] );
  56. return;
  57. }
  58. $sum = 0;
  59. foreach ( MinecraftServer::GetAll() as $server ) {
  60. $m = strlen( $m ) == 2 ? $m : '0' . $m;
  61. $f = "$y-$m-01";
  62. $cap = date( 't', strtotime( $f ) );
  63. $l = "$y-$m-$cap";
  64. $sid = $server->ID;
  65. $subscribers = MinecraftServerSubscription::GetAll( "ConcerningServerID = $sid AND SubscriptionDate BETWEEN '$f' AND '$l'" );
  66. $subsCount = count( $subscribers );
  67. $pot = $subsCount * $server->GetPerMonthPrice();
  68. $potPart = ceil( ( $pot / $subsCount ) * 100 ) / 100;
  69. if ( $pot == 0 ) continue;
  70. $potPart *= -1;
  71. if ( $pot > $server->GetMaxPerMonthPrice() ) $pot = $server->GetMaxPerMonthPrice();
  72. $sum += $pot;
  73. /* $dayssum = 0;
  74. $subs = [];
  75. $sum += $pot;
  76. $potheap = 0;
  77. $dayssumheap = 0;
  78. foreach( $subscribers as $subscriber ) {
  79. $days = date( 'd', strtotime( $subscriber->GetSubscriptionDate() ) );
  80. $dayssum += $days;
  81. $subs[] = [ $days, $subscriber ];
  82. }
  83. foreach ( $subs as $subscription ) {
  84. $price = $pot * ( $dayssum / $subscription[ 0 ] )
  85. }*/
  86. foreach( $subscribers as $subscriber ) {
  87. $u = $subscriber->GetUnlockedUser()->GetOwner();
  88. $ac = new MinecraftUserAccount();
  89. $ac->SetMod( $potPart );
  90. $ac->SetDebtor( $u );
  91. $ac->SetComment( 'Host-Relief for ' . $server->GetName() . ' for ' . $m . '-' . $y );
  92. $ac->Save();
  93. }
  94. $server->ClearWhitelist();
  95. }
  96. $mp = new MinecraftMonthPaid();
  97. $mp->SetAmount( $sum );
  98. $mp->SetMonth( $m );
  99. $mp->SetYear( $y );
  100. if ( $mp->Save() ) {
  101. echo __( [ 'de' => 'Abrechnung beendet', 'en' => 'Settled' ] );
  102. }
  103. }
  104. public function settle_view( string $url ) {
  105. // ORDER BY Year DESC, Month DESC LIMIT 1
  106. $nwst = MinecraftMonthPaid::GetAll( "1 ORDER BY Year DESC, Month DESC LIMIT 1" )[ 0 ];
  107. if ( !$nwst ) {
  108. $nwst = new MinecraftMonthPaid();
  109. $nwst->SetMonth( date( 'm' ) );
  110. $nwst->SetYear( date( 'Y' ) );
  111. }
  112. $m = array_key_exists( 'month', $_GET ) ? $_GET[ 'month' ] + 1 : date( 'm' );
  113. $y = array_key_exists( 'year', $_GET ) ? $_GET[ 'year' ] : date( 'Y' );
  114. if ( $m == '0' ) { $m = '12'; $y--; }
  115. $start = ( new DateTime( $nwst->GetYear() . '-' . $nwst->GetMonth() . '-' . '01' ) )->modify( 'first day of next month' );
  116. $end = ( new DateTime( date( "$y-$m-01" ) ) )->modify( 'first day of this month' );
  117. $interval = DateInterval::createFromDateString( '1 month' );
  118. $period = new DatePeriod( $start, $interval, $end );
  119. $settled = false;
  120. foreach ($period as $dt) {
  121. $settled = true;
  122. echo 'Settling ' . $dt->format("Y-m") . ': ';
  123. $this->settle( $dt->format( 'm' ), $dt->format( 'Y' ) );
  124. echo "<br>\n";
  125. }
  126. if( !$settled ) {
  127. echo 'Nothing to settle';
  128. }
  129. }
  130. public function acredit_view( string $url ) {
  131. if ( !Permission::PERMITTED( 'Minecraft-Pay-Settings', 1 ) ) return;
  132. $params = null;
  133. if (
  134. array_key_exists( 'AddAccountChange', $_POST ) &&
  135. array_key_exists( 'Mod', $_POST ) &&
  136. array_key_exists( 'DebtorID', $_POST ) &&
  137. array_key_exists( 'Comment', $_POST )
  138. ) {
  139. $ac = MinecraftUserAccount::FromPropertyArray( $_POST );
  140. $ac->SetDebtor( User::GetByID( $_POST[ 'DebtorID' ] ) );
  141. $params = [];
  142. $params[ 'save_success' ] = $ac->Save();
  143. $params[ 'save_message' ] =
  144. $params[ 'save_success' ] ?
  145. __( [ 'de' => 'Gutschrift erfolgreich', 'en' => 'Credit successful' ] ) :
  146. __( [ 'de' => 'Gutschrift fehlgeschlagen', 'en' => 'Credit failed' ] );
  147. }
  148. $this->show_template( 'AlterAccount', $params );
  149. }
  150. public function balance_view( string $url ) {
  151. if ( !Permission::PERMITTED( 'Minecraft-Possess-User', 1 ) ) return;
  152. $this->show_template( 'AccountList', null );
  153. }
  154. public function users_view( string $url ) {
  155. if ( !Permission::PERMITTED( 'Minecraft-Possess-User', 1 ) ) return;
  156. if ( $url == '/minecraft-pay/users' ) {
  157. $params = [];
  158. if ( array_key_exists( 'CreateMinecraftUser', $_POST ) && array_key_exists( 'Username', $_POST ) ) {
  159. $s = MinecraftUser::FromPropertyArray( $_POST );
  160. $s->SetOwner( User::CURRENT() );
  161. try {
  162. $s->Save();
  163. $params[ 'save_message' ] = __( [ 'de' => 'Minecraft Benutzer erfolgreich angelegt', 'en' => 'Created minecraft user successfully' ] );
  164. $params[ 'save_success' ] = true;
  165. } catch( Exception $ex ) {
  166. $params[ 'save_message' ] = $ex->getMessage();
  167. if ( startsWith( $params[ 'save_message' ], 'Duplicate entry' ) )
  168. $params[ 'save_message' ] = __(
  169. [
  170. 'de' => 'Doppelter Name oder es wurde bei einem anderen Server weder Domain noch Port angegeben',
  171. 'en' => 'Duplicated Name or another server has neither domain nor port'
  172. ]
  173. );
  174. $params[ 'save_success' ] = false;
  175. }
  176. }
  177. if ( array_key_exists( 'DeleteMinecraftUser', $_POST ) && array_key_exists( 'ID', $_POST ) ) {
  178. $s = MinecraftUser::GetByID( $_POST[ 'ID' ] );
  179. if ( User::CURRENT()->GetID() != $s->GetOwner()->GetID() ) {
  180. $params[ 'save_message' ] = __( [ 'de' => 'Dieser Benutzer geh&ouml;t Ihnen nicht!', 'en' => 'This user does not belong to you!' ] );
  181. $params[ 'save_success' ] = false;
  182. } else {
  183. try {
  184. $s->Delete();
  185. $params[ 'save_message' ] = __( [ 'de' => 'Minecraft Benutzer erfolgreich gel&ouml;scht', 'en' => 'Deleted minecraft user successfully' ] );
  186. $params[ 'save_success' ] = true;
  187. } catch( Exception $ex ) {
  188. $params[ 'save_message' ] = $ex->getMessage();
  189. $params[ 'save_success' ] = false;
  190. }
  191. }
  192. }
  193. $this->show_template( 'UsersList', $params );
  194. } else $this->user_view( $url );
  195. }
  196. public function user_view( string $url ) {
  197. if ( !Permission::PERMITTED( 'Minecraft-Possess-User', 1 ) ) return;
  198. if ( !preg_match( '/\/minecraft-pay\/users\/([0-9]+)/', $url, $m ) || is_null( MinecraftUser::GetByID( $m[ 1 ] ) ) ) {
  199. Alert::SHOW( __( [ 'de' => 'Dieser Benutzer existiert nicht', 'en' => 'This user does not exist' ] ) );
  200. return;
  201. }
  202. $params = [];
  203. if ( array_key_exists( 'RUnlockUser', $_POST ) && array_key_exists( 'ID', $_POST ) ) {
  204. $s = MinecraftServer::GetByID( $_POST[ 'ID' ] );
  205. $u = MinecraftUser::GetByID( $m[ 1 ] );
  206. if ( is_null( $s ) ) { $params[ 'save_message' ] = __( [ 'de' => 'Unbekannter Server', 'en' => 'Unknown server' ] ); $params[ 'save_success' ] = false; }
  207. else if ( is_null( $u ) ) { $params[ 'save_message' ] = __( [ 'de' => 'Unbekannter Benutzer', 'en' => 'Unknown user' ] ); $params[ 'save_success' ] = false; }
  208. else {
  209. if ( $s->Unlock( $u ) ) {
  210. if ( !$u->HasSubscripted( $s ) ) {
  211. $ms = new MinecraftServerSubscription();
  212. $ms->SetConcerningServer( $s );
  213. $ms->SetUnlockedUser( $u );
  214. $params[ 'save_success' ] = $ms->Save();
  215. $params[ 'save_message' ] =
  216. $params[ 'save_success' ] ?
  217. __( [ 'de' => 'Erfolgreich freigeschaltet', 'en' => 'Unlock successful' ] ) :
  218. __( [ 'de' => 'Freischaltung fehlgeschlagen', 'en' => 'Unlock failed' ] );
  219. if ( !$params[ 'save_success' ] ) $s->Lock( $u );
  220. } else { $params[ 'save_message' ] = __( [ 'de' => 'Erfolgreich freigeschaltet', 'en' => 'Unlock successful' ] ); $params[ 'save_success' ] = true; }
  221. } else { $params[ 'save_message' ] = __( [ 'de' => 'Freischaltung fehlgeschlagen', 'en' => 'Unlock failed' ] ); $params[ 'save_success' ] = false; }
  222. }
  223. }
  224. $params[ 'user' ] = MinecraftUser::GetByID( $m[ 1 ] );
  225. $this->show_template( 'Users', $params );
  226. }
  227. public function settings_view( string $url ) {
  228. if ( !Permission::PERMITTED( 'Minecraft-Pay-Settings', 1 ) ) return;
  229. if ( $url == '/minecraft-pay/settings' ) {
  230. $params = [];
  231. if ( array_key_exists( 'CreateServer', $_POST ) && array_key_exists( 'Name', $_POST ) ) {
  232. $s = MinecraftServer::FromPropertyArray( $_POST );
  233. try {
  234. $s->Save();
  235. $params[ 'save_message' ] = __( [ 'de' => 'Server erfolgreich angelegt', 'en' => 'Created server successfully' ] );
  236. $params[ 'save_success' ] = true;
  237. } catch( Exception $ex ) {
  238. $params[ 'save_message' ] = $ex->getMessage();
  239. if ( startsWith( $params[ 'save_message' ], 'Duplicate entry' ) )
  240. $params[ 'save_message' ] = __(
  241. [
  242. 'de' => 'Doppelter Name oder es wurde bei einem anderen Server weder Domain noch Port angegeben',
  243. 'en' => 'Duplicated Name or another server has neither domain nor port'
  244. ]
  245. );
  246. $params[ 'save_success' ] = false;
  247. }
  248. }
  249. if ( array_key_exists( 'DeleteServer', $_POST ) && array_key_exists( 'ID', $_POST ) ) {
  250. $s = MinecraftServer::FromPropertyArray( $_POST );
  251. try {
  252. $s->Delete();
  253. $params[ 'save_message' ] = __( [ 'de' => 'Server erfolgreich gel&ouml;scht', 'en' => 'Deleted server successfully' ] );
  254. $params[ 'save_success' ] = true;
  255. } catch( Exception $ex ) {
  256. $params[ 'save_message' ] = $ex->getMessage();
  257. $params[ 'save_success' ] = false;
  258. }
  259. }
  260. $this->show_template( 'SettingsList', $params );
  261. }
  262. else $this->server_settings_view( $url );
  263. // $this->show_template( 'Settings', [ 'settings' => (object) [ 'Server' => '', 'Port' => 35575, 'Password' => '' ] ] );
  264. }
  265. public function server_settings_view( string $url ) {
  266. if ( !Permission::PERMITTED( 'Minecraft-Pay-Settings', 1 ) ) return;
  267. if ( !preg_match( '/\/minecraft-pay\/settings\/([0-9]+)/', $url, $m ) || is_null( MinecraftServer::GetByID( $m[ 1 ] ) ) ) {
  268. Alert::SHOW( __( [ 'de' => 'Dieser Server existiert nicht', 'en' => 'This server does not exist' ] ) );
  269. return;
  270. }
  271. $params = [];
  272. if (
  273. array_key_exists( 'SaveServerSettings', $_POST ) &&
  274. array_key_exists( 'Domain', $_POST ) &&
  275. array_key_exists( 'Port', $_POST ) &&
  276. array_key_exists( 'Password', $_POST ) &&
  277. array_key_exists( 'ServerPath', $_POST )
  278. ) {
  279. if ( !$_POST[ 'Port' ] ) $_POST[ 'Port' ] = null;
  280. $o = MinecraftServer::GetByID( $m[ 1 ] );
  281. $s = MinecraftServer::FromPropertyArray( $_POST );
  282. $s->SetID( $o->GetID() );
  283. $s->SetName( $o->GetName() );
  284. try {
  285. $s->Save();
  286. $params[ 'save_message' ] = __( [ 'de' => 'Server erfolgreich gespeichert', 'en' => 'Saved server successfully' ] );
  287. $params[ 'save_success' ] = true;
  288. } catch( Exception $ex ) {
  289. $params[ 'save_message' ] = $ex->getMessage();
  290. if ( startsWith( $params[ 'save_message' ], 'Duplicate entry' ) )
  291. $params[ 'save_message' ] = __(
  292. [
  293. 'de' => 'Doppelte Domain noch Port Kombination',
  294. 'en' => 'Duplicated domain - port combination'
  295. ]
  296. );
  297. $params[ 'save_success' ] = false;
  298. }
  299. }
  300. $params[ 'settings' ] = MinecraftServer::GetByID( $m[ 1 ] );
  301. $this->show_template( 'Settings', $params );
  302. }
  303. public function load_plugin(): void {
  304. if ( is_null( Permission::GetByUnique( 0, 'Minecraft-Pay-Settings' ) ) ) {
  305. $p = Permission::FromArray( [], [] );
  306. $p->SetName( 'Minecraft-Pay-Settings' );
  307. $p->SetSlug( slugify( 'Minecraft-Pay-Settings' ) );
  308. $p->Save();
  309. }
  310. if ( is_null( Permission::GetByUnique( 0, 'Minecraft-Possess-User' ) ) ) {
  311. $p = Permission::FromArray( [], [] );
  312. $p->SetName( 'Minecraft-Possess-User' );
  313. $p->SetSlug( slugify( 'Minecraft-Possess-User' ) );
  314. $p->Save();
  315. }
  316. if ( User::ONLINE() && Permission::PERMITTED( 'Minecraft-Possess-User' ) ) {
  317. $me = new MenuEntry( 'Minecraft Payment' );
  318. $me->addImageFromResource( 'minecraft.svg', MinecraftPaymentPlugin::get_plugin_name() );
  319. $me->setFilter( 'none' );
  320. if ( Permission::PERMITTED( 'Minecraft-Pay-Settings' ) ) {
  321. $sub = new MenuEntry( 'Minecraft Payment', HOME_URL . 'minecraft-pay/settings' );
  322. $sub->addImageFromResource( 'settings.svg', Plugin_Plugin::get_plugin_name() );
  323. $me->addSubEntry( $sub );
  324. }
  325. $sub = new MenuEntry( [ 'de' => 'Minecraft Benutzer', 'en' => 'Minecraft Users' ], HOME_URL . 'minecraft-pay/users' );
  326. $sub->addImageFromResource( 'users.svg', UserManager_Plugin::get_plugin_name() );
  327. $me->addSubEntry( $sub );
  328. if ( Permission::PERMITTED( 'Minecraft-Pay-Settings' ) ) {
  329. $sub = new MenuEntry( [ 'de' => 'Gutschrift', 'en' => 'Credit' ], HOME_URL . 'minecraft-pay/acredit' );
  330. $sub->addImageFromResource( 'cash.svg', MinecraftPaymentPlugin::get_plugin_name() );
  331. $me->addSubEntry( $sub );
  332. }
  333. $sub = new MenuEntry( [ 'de' => 'Transaktionen', 'en' => 'Transactions' ], HOME_URL . 'minecraft-pay/balance' );
  334. $sub->addImageFromResource( 'cash.svg', MinecraftPaymentPlugin::get_plugin_name() );
  335. $me->addSubEntry( $sub );
  336. if ( Permission::PERMITTED( 'Minecraft-Pay-Settings' ) ) {
  337. $sub = new MenuEntry( [ 'de' => 'Recht gew&auml;hren', 'en' => 'Grant right' ], HOME_URL . 'minecraft-pay/grant' );
  338. $sub->addImageFromResource( 'key.svg', MinecraftPaymentPlugin::get_plugin_name() );
  339. $me->addSubEntry( $sub );
  340. };
  341. SideMenu::addMainMenuEntry( $me );
  342. }
  343. }
  344. }