plug_usermanager.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  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 = str_replace("@","_",$user['E-mail'])."@ere.dk";
  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. $user_id = wp_create_user( $user_name, $random_password, $user_email );
  102. wp_send_new_user_notifications($user_id,'both');
  103. $resu[] = "$user_id created : $user_name $user_email ";
  104. } else {
  105. $random_password = __( 'User already exists. Password inherited.', 'textdomain' );
  106. }
  107. echo ("$user_id, $user_name, $random_password, $user_email <br>");
  108. flush();
  109. }else{
  110. }
  111. }
  112. if(count($resu)){
  113. echo("SEND NOTIFY");
  114. $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));
  115. }else{
  116. echo("no noti");
  117. }
  118. if(!isset($_REQUEST['nodryrun'])){
  119. ?>
  120. <a href="/wp-admin/admin.php?page=dagsopt-options&crunchit=1&nodryrun=1" class="btn">Crunch live</a>
  121. <?php
  122. }
  123. }
  124. /*<input id="link_image" value="test">
  125. <img src="" id="background_image">
  126. <a id="upload_image_button" href="#"><?php _e('Set image', 'dagsopt'); ?></a>
  127. */
  128. function admin_line($pre){
  129. $upload = wp_upload_dir();
  130. $upload_dir = $upload['basedir'];
  131. $upload_dir = $upload_dir . '/assets';
  132. ?>
  133. <table>
  134. <?php
  135. if(file_exists($upload_dir."/users.csv")){
  136. $lastmodified = date ("F d Y H:i:s.", filemtime($upload_dir."/users.csv"));
  137. $data = file_get_contents($upload_dir."/users.csv");
  138. $lines = explode("\n",$data);
  139. ?>
  140. <tr><td>
  141. Sidste opdateret
  142. </td><td>
  143. <?php echo $lastmodified ?>
  144. </td></tr>
  145. <tr><td>
  146. Størrelse
  147. </td><td>
  148. <?php echo strlen($data) ?> bytes / linier: <?php echo(count($lines)-1); ?>
  149. </td></tr>
  150. <tr><td>Kør opdatering</td><td><a href="/wp-admin/admin.php?page=dagsopt-options&crunchit=1" class="btn">Crunch</a></td></tr>
  151. <?php } ?>
  152. <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>
  153. <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>
  154. </table>
  155. <?php
  156. $nonce = wp_create_nonce( 'filen-nonce' );
  157. ?>
  158. <input type="file" name="filen">
  159. <input type="hidden" name="_wpnonce" value="<?php echo $nonce ?>">
  160. <?php
  161. }
  162. }
  163. global $plug_usermanager;
  164. $plug_usermanager = new plug_usermanager($this);
  165. $this->dagsopt['plug_usermanager'] = $plug_usermanager;
  166. }