Newer
Older
CosmosServer / src / main / java / com / example / cosmos_serversb / models / Users.java
package com.example.cosmos_serversb.models;

import java.util.List;
import java.util.UUID;
import javax.inject.Singleton;
import javax.ws.rs.WebApplicationException;

import com.example.cosmos_serversb.entities.*;
import org.hibernate.Session;
import org.hibernate.SessionFactory;


@Singleton
public class Users {
    private static Users theInstance = null;
    private static SessionFactory sessionFactory;
    private static String baseURI = "http://nitta-lab-www.is.konan-u.ac.jp/";
    private static String AppName = "cosmos";

    private Users() {
        sessionFactory = SessionFactoryManager.getInstance().getSessionFactory();
    }

    public static Users getInstance() {
        if (theInstance == null) {
            theInstance = new Users();
        }
        return theInstance;
    }

    public static Token createToken(String uId) {
        //Tokenを作成しuIdと関連付けしDBに保存し作成したTokenを返す
        String token = UUID.randomUUID().toString();
        Token testToken =new Token(token, uId);

        /*TODO:Session managerを作成しセッションの二重作成をしない
        Session session = sessionFactory.openSession();
        session.beginTransaction();
        session.save(testToken);
        session.getTransaction().commit();
        session.close();*/
        return testToken;
    }

    public static String createUId() {
        //uIdを作成し既存していないかチェック後DBに保存し作成したuIdを返す
        String uId = UUID.randomUUID().toString();
        return uId;
    }

    public static User createUser(String name, String pw, String iconImage) {
        String uId = getInstance().createUId();
        String uri = baseURI + AppName +"/users/" +uId;

        Session session = SessionManager.getInstance().getSession();
        createToken(uId);
        Password password = new Password(pw, uId);//パスワードとユーザー情報を紐づけ
        User testUser = new User(name, uId, uri, iconImage);//名前、uId、ユーザーuri、アイコンイメージを保存
        session.save(password);
        session.save(testUser);
        return testUser;
    }

    public static User setUser(String uId, String name, String pw, String iconImage) {
        Session session = SessionManager.getInstance().getSession();
        List usersList = session.createQuery( "from User" ).list();
        List passwordList = session.createQuery("from Password").list();
        for ( User user : (List<User>) usersList ) {
            if (user.getuId().equals(uId)) {//if (user.getuId().equals(uId) || password.getPw().equals(pw)) {
                user.setName(name);
                for ( Password password : (List<Password>) passwordList ) {
                    password.setPw(pw);
                    session.update(password);
                }
                if(iconImage != null) {
                    user.setIconUri(iconImage);
                }
                session.update(user);
                break;
            }
        }
        User findUser = (User) session.load(User.class, uId);
        return findUser;
    }

    public static User getUserById(String uId) {
        //与えられたuIdのUser情報を返す
        Session session = SessionManager.getInstance().getSession();
        List usersList = session.createQuery( "from User" ).list();
        //uIdを比較し、一致した場合はNameとiconUriを返す。一致しない場合はbreak
        for ( User user : (List<User>) usersList ) {
            if (user.getuId().equals(uId)) {
                User findUser = (User) session.load(User.class, uId);
//                System.out.println(mapper.valueToTree(findUser).toString());
                return findUser;
            }
        }
        throw  new WebApplicationException(404);
    }

    public static User getUserByToken(String token) {
        //与えられたTokenに紐づくUser情報を返す
        User testUser = new User("test",  getInstance().createUId(), "http://test.com", "http://localhost:8080/iconImage/b4bb7db0-cc0c-4ee1-816f-8304add12da8.jpg");
        return testUser;
    }

    public static DeleteResult deleteUser(String uId) {
        Session session = SessionManager.getInstance().getSession();
        User deleteUser = (User) session.load(User.class, uId);
        if(deleteUser != null){
            session.delete(deleteUser);
            System.out.println("massage: Already Deleted");
        }
        return DeleteResult.SUCCESS;
    }

    public static Token login(String uId,String pw) {
        if(checkPassword(uId,pw)) {
            Token testtoken = getInstance().createToken(uId);
            //tokenを作成後値を返す
            return testtoken;//testToken
        }else{
            throw  new WebApplicationException(401);
        }
    }

    public static DeleteResult logout(String uId,String token) {
        Session session = SessionManager.getInstance().getSession();
        List usersList = session.createQuery( "from User" ).list();
        for ( User user : (List<User>) usersList ) {
            if (user.getuId().equals(uId)) {
                if (Users.getInstance().getUserByToken(token).uId == null) {
                    return DeleteResult.FAILURE;
                } else {
//            Users.getInstance().getUserByToken(token).token.remove(Users.getInstance().getUserByToken(token).token.indexOf(token));
                    return DeleteResult.SUCCESS;
                }
            }
        }
        throw  new WebApplicationException(400);
    }

    public static boolean checkToken(String uId, String token) {
        //与えられたtokenとUserのtokenを比較し結果を返す
        return true;
    }

    public static boolean checkPassword(String uId, String pw) {
        //与えられたパスワードとUserのパスワードを比較し結果を返す
        Session session = SessionManager.getInstance().getSession();
        Password findPassword = (Password) session.load(Password.class, uId);
        if (findPassword.getPw().equals(pw)) {
            return true;
        } else {
            return false;
        }
    }
}