diff --git a/apps/syndie/java/src/net/i2p/syndie/BlogManager.java b/apps/syndie/java/src/net/i2p/syndie/BlogManager.java
index f3fd0fb1c2f17fcf171a572637772138ab321b02..b755245b455f810e74aabf5a278f5fdac4c183e2 100644
--- a/apps/syndie/java/src/net/i2p/syndie/BlogManager.java
+++ b/apps/syndie/java/src/net/i2p/syndie/BlogManager.java
@@ -284,6 +284,14 @@ public class BlogManager {
         }
     }
     
+    public boolean changePasswrd(User user, String oldPass, String pass0, String pass1) {
+        boolean ok = user.changePassword(oldPass, pass0, pass1);
+        if (ok)
+            saveUser(user);
+        return ok;
+    }
+
+    
     public User login(String login, String pass) {
         User u = new User(_context);
         String ok = login(u, login, pass);
@@ -438,7 +446,7 @@ public class BlogManager {
     private static final String PROP_DEFAULT_LOGIN = "syndie.defaultSingleUserLogin";
     private static final String PROP_DEFAULT_PASS = "syndie.defaultSingleUserPass";
     
-    private String getDefaultLogin() {
+    public String getDefaultLogin() {
         String login = _context.getProperty(PROP_DEFAULT_LOGIN);
         if ( (login == null) || (login.trim().length() <= 0) )
             login = DEFAULT_LOGIN;
diff --git a/apps/syndie/java/src/net/i2p/syndie/web/BaseServlet.java b/apps/syndie/java/src/net/i2p/syndie/web/BaseServlet.java
index 19ea125902d8646baa957f849590c7e812675738..b220c075385d142458d44226fe7998b29b330a68 100644
--- a/apps/syndie/java/src/net/i2p/syndie/web/BaseServlet.java
+++ b/apps/syndie/java/src/net/i2p/syndie/web/BaseServlet.java
@@ -319,6 +319,14 @@ public abstract class BaseServlet extends HttpServlet {
             }
         }
         
+        String pass0 = req.getParameter("password");
+        String pass1 = req.getParameter("passwordConfirm");
+        String oldPass = req.getParameter("oldPassword");
+        
+        if ( (pass0 != null) && (pass1 != null) && (pass0.equals(pass1)) ) {
+            BlogManager.instance().changePasswrd(user, oldPass, pass0, pass1);
+        }
+        
         boolean updated = BlogManager.instance().updateMetadata(user, user.getBlog(), opts);
     }
     
diff --git a/apps/syndie/java/src/net/i2p/syndie/web/ProfileServlet.java b/apps/syndie/java/src/net/i2p/syndie/web/ProfileServlet.java
index 7aed5bc2413157433630ff0d51b46226ad9dc991..abb94154ffc9d5a2ef734d4ed4ff5b295d45866c 100644
--- a/apps/syndie/java/src/net/i2p/syndie/web/ProfileServlet.java
+++ b/apps/syndie/java/src/net/i2p/syndie/web/ProfileServlet.java
@@ -87,6 +87,16 @@ public class ProfileServlet extends BaseServlet {
         }
         out.write("</textarea></td></tr>\n");
 
+        if (user.getAuthenticated()) {
+            if ( (user.getUsername() == null) || (user.getUsername().equals(BlogManager.instance().getDefaultLogin())) ) {
+                // this is the default user, don't let them change the password
+            } else {
+                out.write("<tr><td colspan=\"3\">Old Password: <input type=\"password\" name=\"oldPassword\" /></td></tr>\n");
+                out.write("<tr><td colspan=\"3\">Password: <input type=\"password\" name=\"password\" /></td></tr>\n");
+                out.write("<tr><td colspan=\"3\">Password again: <input type=\"password\" name=\"passwordConfirm\" /></td></tr>\n");
+            }
+        }
+        
         out.write("<tr><td colspan=\"3\"><input type=\"submit\" name=\"action\" value=\"Update profile\" /></td></tr>\n");
         out.write("</form>\n");
     }