]> git.defcon.no Git - hermes/blobdiff - user.php
Changed list node to provide more data. Added change_pw functionality/node. Changed...
[hermes] / user.php
index f4ca316b89132afab56c5f62c283f17d44a77465..87dbe53d811cf1cc8858058beea079c75d282bee 100644 (file)
--- a/user.php
+++ b/user.php
@@ -386,6 +386,7 @@ if ( !$config['sql_link'] )
                        /*
                        Required parameters should be...
                                ( username & domain ) | user
+                               password
                        
                        * Verify that no associations/relations exist in 'provision.phones'
                        * Verify that the user exists ...
@@ -395,8 +396,9 @@ if ( !$config['sql_link'] )
                        * Update user passwords in 'provision' and 'kamailio' as appropriate
                        * On other failures, return 'response' => 'failed' with 'cause' => 'error' (may set 'detail' => 'message')
                        */
-                       if ( ( array_key_exists( 'username', $_GET) && array_key_exists( 'domain', $_GET ) ) 
-                               || array_key_exists('user', $_GET) )
+                       if (    array_key_exists('password', $_GET) &&
+                               ( ( array_key_exists( 'username', $_GET) && array_key_exists( 'domain', $_GET ) ) 
+                                       || array_key_exists('user', $_GET) ))
 
                        {
                                $username = "";
@@ -416,7 +418,38 @@ if ( !$config['sql_link'] )
                                        }
                                        list ( $username, $domain ) = $user;
                                }
-                               print json_encode ( array( 'response' => 'failed', 'cause' => 'notimplemented', 'detail' => 'Requested feature valid, but not implemented' ) );
+                               $password = $_GET['password'];
+
+                               // Check compatibility of password? TODO...
+                               // Fetch old password for rollback? TODO...
+                               // Verify that user exists for provisioning
+                               if ( ! is_provision_user( $username, $domain ) )
+                               {
+                                       print json_encode( array ( 'response' => 'failed', 'cause' => 'nonexistant', 'detail' => '' . $username . '@' . $domain . ' does not exist.'));
+                                       break;
+                               }
+                               if ( is_provision_user( $username, $domain ) )
+                               {
+                               print "WTF";
+                                       // Update provisioning password
+                                       if (! update_provision_pw( $username, $domain, $password ) )
+                                       {
+                                               print json_encode( array( 'response' => 'failed', 'cause' => 'dbfail', 'detail' => 'Failed to update provisioning password' ) );
+                                               break;
+                                       }
+                               }
+                               // Check for user in kamailio
+                               if ( is_kamailio_subscriber( $username, $domain ) )
+                               {
+                                       // Update kamailio password
+                                       if (! update_kamailio_pw( $username, $domain, $password ) )
+                                       {
+                                               print json_encode( array( 'response' => 'failed', 'cause' => 'dbfail', 'detail' => 'Failed to update kamailio password' ) );
+                                               break;
+                                       }
+                               }
+                               print json_encode( array ( 'response' => 'ok', 'detail' => 'Password changed for user '.$username.'@'.$domain.'.'));
+                               break;
                        }
                        else 
                                print json_encode( array( 'response' => 'invalid', 'cause' => 'parameters' ) );