Serving a payment option for my minecraft server so I don't have to pay for it all alone
Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

Plugin.php 14KB

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