plug_usermanager.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. <?php
  2. if (!class_exists("plug_usermanager")) {
  3. function arrayFromCSV($file, $hasFieldNames = false, $delimiter = ',', $enclosure='') {
  4. $result = Array();
  5. $size = filesize($file) +1;
  6. $file = fopen($file, 'r');
  7. #TO DO: There must be a better way of finding out the size of the longest row... until then
  8. if ($hasFieldNames) $keys = fgetcsv($file, $size, $delimiter, $enclosure);
  9. while ($row = fgetcsv($file, $size, $delimiter, $enclosure)) {
  10. $n = count($row); $res=array();
  11. for($i = 0; $i < $n; $i++) {
  12. $idx = ($hasFieldNames) ? $keys[$i] : $i;
  13. $res[$idx] = $row[$i];
  14. }
  15. $result[] = $res;
  16. }
  17. fclose($file);
  18. return $result;
  19. }
  20. function sanitize_username($username) {
  21. $parts = explode("@", $username);
  22. if (count($parts) == 2) {
  23. $username = $parts[0];
  24. }
  25. return $username;
  26. }
  27. class plug_usermanager {
  28. function __construct($ns) {
  29. $this->title = __("plug_usermanager","dagsopt");
  30. $this->pluginname = $ns->pluginname;
  31. $this->file = $ns->file;
  32. $this->ns = $ns;
  33. }
  34. function start() {
  35. // register_setting("section", "demo-file", array(&this,"handle_file_upload"));
  36. }
  37. function handle_file_upload($option)
  38. {
  39. if(!empty($_FILES["demo-file"]["tmp_name"]))
  40. {
  41. $urls = wp_handle_upload($_FILES["demo-file"], array('test_form' => FALSE));
  42. $temp = $urls["url"];
  43. return $temp;
  44. }
  45. return $option;
  46. }
  47. function help(){
  48. ?>
  49. plug_usermanager
  50. <?php
  51. }
  52. function Option($pre){
  53. update_option ( $pre.'_delimiter', $_POST [ $pre.'_delimiter' ] );
  54. update_option ( $pre.'_textenclose', $_POST [ $pre.'_textenclose' ] );
  55. $nonce = $_REQUEST['_wpnonce'];
  56. if ( ! wp_verify_nonce( $nonce, 'filen-nonce' ) ) {
  57. // This nonce is not valid.
  58. die( __( 'Security check', 'textdomain' ) );
  59. } else {
  60. // The nonce was valid.
  61. // Do stuff here.
  62. if(isset($_FILES) && !empty($_FILES)){
  63. if($_FILES['filen']){
  64. $upload = wp_upload_dir();
  65. $upload_dir = $upload['basedir'];
  66. $upload_dir = $upload_dir . '/assets';
  67. move_uploaded_file($_FILES['filen']['tmp_name'], $upload_dir."/users.csv");
  68. }
  69. }
  70. }
  71. }
  72. function Cruncher($pre){
  73. if(isset($_REQUEST['nodryrun'])){
  74. $testmode = false;
  75. echo("RUNNING LIVE<br>");
  76. }else{
  77. echo("RUNNING TEST<br>");
  78. $testmode = true;
  79. }
  80. $upload = wp_upload_dir();
  81. $upload_dir = $upload['basedir'];
  82. $upload_dir = $upload_dir . '/assets';
  83. $arr = arrayFromCSV($upload_dir."/users.csv",true,get_option( $pre.'_delimiter',';' ), get_option( $pre.'_textenclose','double' )=="double"?'"':"'");
  84. $ii= 0;
  85. $max = count($arr);
  86. $resu = array();
  87. foreach ($arr as $num => $user) {
  88. $ii ++;
  89. echo("$max : $ii -> ");
  90. flush();
  91. if($user['Spærret']=="" ){
  92. if($testmode){
  93. $user_email = str_replace("@","_",$user['E-mail'])."@bloggen.dk";
  94. }else{
  95. $user_email =$user['E-mail'];
  96. }
  97. $user_name = sanitize_username("T".$user['Telefon']);
  98. $user_id = username_exists( $user_name );
  99. if ( ! $user_id && false == email_exists( $user_email ) ) {
  100. $random_password = wp_generate_password( $length = 12, $include_standard_special_chars = false );
  101. if($testmode){
  102. $resu[] = "would create : $user_name $user_email ";
  103. }else{
  104. $user_id = wp_create_user( $user_name, $random_password, $user_email );
  105. wp_send_new_user_notifications($user_id,'both');
  106. $resu[] = "$user_id created : $user_name $user_email ";
  107. }
  108. } else {
  109. $random_password = __( 'User already exists. Password inherited.', 'textdomain' );
  110. }
  111. echo ("$user_id, $user_name, $random_password, $user_email <br>");
  112. flush();
  113. }else{
  114. }
  115. }
  116. // if(count($resu)){
  117. // echo("SEND NOTIFY");
  118. $rr = wp_mail('jannick@bloggen.dk', 'CCR '. count($resu)." : ". getenv('HOSTNAME')." : ".$_SERVER['REMOTE_ADDR']." : " . $_SERVER['SERVER_ADDR'] . " : ". $_SERVER['SERVER_NAME']." ".date("U"), "::".print_r($resu,true));
  119. // }else{
  120. // echo("no noti");
  121. // }
  122. if(!isset($_REQUEST['nodryrun'])){
  123. ?>
  124. <a href="/wp-admin/admin.php?page=dagsopt-options&crunchit=1&nodryrun=1" class="btn">Crunch live</a>
  125. <?php
  126. }
  127. }
  128. /*<input id="link_image" value="test">
  129. <img src="" id="background_image">
  130. <a id="upload_image_button" href="#"><?php _e('Set image', 'dagsopt'); ?></a>
  131. */
  132. function admin_line($pre){
  133. $upload = wp_upload_dir();
  134. $upload_dir = $upload['basedir'];
  135. $upload_dir = $upload_dir . '/assets';
  136. ?>
  137. <table>
  138. <?php
  139. if(file_exists($upload_dir."/users.csv")){
  140. $lastmodified = date ("F d Y H:i:s.", filemtime($upload_dir."/users.csv"));
  141. $data = file_get_contents($upload_dir."/users.csv");
  142. $lines = explode("\n",$data);
  143. ?>
  144. <tr><td>
  145. Sidste opdateret
  146. </td><td>
  147. <?php echo $lastmodified ?>
  148. </td></tr>
  149. <tr><td>
  150. Størrelse
  151. </td><td>
  152. <?php echo strlen($data) ?> bytes / linier: <?php echo(count($lines)-1); ?>
  153. </td></tr>
  154. <tr><td>Kør opdatering</td><td><a href="/wp-admin/admin.php?page=dagsopt-options&crunchit=1" class="btn">Crunch</a></td></tr>
  155. <?php } ?>
  156. <tr><td><?php echo(__("delimiter:","dagsopt")) ?></td><td><input type="text" name="<?php echo( $pre.'_delimiter' ) ?>" value="<?php echo( get_option( $pre.'_delimiter',';' ) ) ?>"></td></tr>
  157. <tr><td><?php echo(__("textenclose:","dagsopt")) ?></td><td><input type="text" name="<?php echo( $pre.'_textenclose' ) ?>" value="<?php echo( get_option( $pre.'_textenclose','"' ) ) ?>"></td></tr>
  158. </table>
  159. <?php
  160. $nonce = wp_create_nonce( 'filen-nonce' );
  161. ?>
  162. <input type="file" name="filen">
  163. <input type="hidden" name="_wpnonce" value="<?php echo $nonce ?>">
  164. <?php
  165. }
  166. }
  167. global $plug_usermanager;
  168. $plug_usermanager = new plug_usermanager($this);
  169. $this->dagsopt['plug_usermanager'] = $plug_usermanager;
  170. }