java - 为协作 Android 应用程序创建全局 Realm 文件

标签 java android realm android-database realm-mobile-platform

我的应用程序是一个协作应用程序,用户应该能够写入/读取全局 Realm 文件以在他们之间共享数据。我还想在 Realm 文件中包含一些初始数据 (realmObjects),这些数据对所有用户来说都是通用的。

用户将注册,然后能够创建数据并与所有用户共享数据。初始数据仅创建一次,应该可供所有用户使用。

在每个新用户注册/登录应用程序后,我无法为其分配用户权限(写入/读取)。自查询以来,公共(public)数据被创建了多次(realm.where(realmObject.class).findall() 没有返回结果,即使它已经创建了。

public static final String AUTH_URL     = "http://" + BuildConfig.OBJECT_SERVER_IP + ":9080/auth";
public static final String REALM_URL    = "realm://" + BuildConfig.OBJECT_SERVER_IP + ":9080/default";

UserManager类

public class UserManager {

    // Supported authentication mode
    public enum AUTH_MODE {
        PASSWORD,
        FACEBOOK,
        GOOGLE
    }
    private static AUTH_MODE mode = AUTH_MODE.PASSWORD; // default

    public static void setAuthMode(AUTH_MODE m) {
        mode = m;
    }

    public static void logoutActiveUser() {
        switch (mode) {
            case PASSWORD: {
                break;
            }
            case FACEBOOK: {
                LoginManager.getInstance().logOut();
                break;
            }
            case GOOGLE: {
                break;
            }
        }
        SyncUser.currentUser().logout();
    }

    // Configure Realm for the current active user
    public static void setActiveUser(SyncUser user) {
        Realm.removeDefaultConfiguration();
        SyncConfiguration defaultConfig = new SyncConfiguration.Builder(user, REALM_URL).name("Realm").schemaVersion(0).build();
        Realm.setDefaultConfiguration(defaultConfig);
        setDefaultPermissionsRealm(user);
    }

    private static void setDefaultPermissionsRealm(SyncUser user){
        if (user.getIdentity().toString().equals(PRIVILAGE)){

            Realm realm = user.getManagementRealm();
            realm.executeTransaction(new Realm.Transaction() {
                @Override
                public void execute(Realm realm) {
                    Boolean mayRead = true; // Grant read access
                    Boolean mayWrite = true; // Keep current permission
                    Boolean mayManage = false; // Revoke management access
                    PermissionChange change = new PermissionChange(REALM_URL,
                            "*",
                            mayRead,
                            mayWrite,
                            mayManage);
                    realm.insert(change);
                }
            });
        }
    }
}

SplashActivity

SyncUser.loginAsync(SyncCredentials.usernamePassword(eMail, password, true), AUTH_URL, new SyncUser.Callback() {
                @Override
                public void onSuccess(SyncUser syncUser) {
                    loginRegistrationSuccess = true;
                    registrationComplete(syncUser);
                }

                @Override
                public void onError(ObjectServerError error) {
                    loginRegistrationSuccess = false;
                }
            });

facebookAuthRegistration    = new FacebookAuth((LoginButton) findViewById(R.id.sign_up_facebook), this) {
           @Override
           public void onRegistrationComplete(final LoginResult loginResult, User userInfo) {
               UserManager.setAuthMode(UserManager.AUTH_MODE.FACEBOOK);
               SyncCredentials credentials = SyncCredentials.facebook(loginResult.getAccessToken().getToken());
               SyncUser.loginAsync(credentials, AUTH_URL, SplashScreenActivity.this);
           }
        };

        googleAuthRegistration      = new GoogleAuth((Button) findViewById(R.id.sign_up_google), this, googleAuthLogin.getmGoogleApiClient()) {
            @Override
            public void onRegistrationComplete(GoogleSignInResult result) {
                UserManager.setAuthMode(UserManager.AUTH_MODE.GOOGLE);
                GoogleSignInAccount acct    = result.getSignInAccount();
                SyncCredentials credentials = SyncCredentials.google(acct.getIdToken());
                SyncUser.loginAsync(credentials, AUTH_URL, SplashScreenActivity.this);
            }
        };

@Override
    public void onSuccess(SyncUser syncUser) {
        loginRegistrationSuccess = true;
        showProgress(false);
        registrationComplete(syncUser);
    }

private void registrationComplete(SyncUser syncUser) {
        UserManager.setActiveUser(syncUser);
        Intent mainIntent = new Intent(SplashScreenActivity.this, MainActivity.class);
        mainIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
        SplashScreenActivity.this.startActivity(mainIntent);
        SplashScreenActivity.this.finish();
    }

看起来我正在为每个用户创建不同的 Realm ,即使我没有在 URL 中包含“~”。

谁能告诉我我做错了什么?

谢谢

最佳答案

最初,您需要使用管理员用户创建 Realm ,并设置所有其他用户可以访问它的权限。如果您使用的是 Pro 版本,您可以使用一个小的 node.js 脚本创建 Realm。或者,您可以创建一个小型内部应用程序,其唯一目的是使用管理员用户创建 Realm 。

用户只能在其主目录(~)内创建 Realm,但可以与其他用户共享。这样做时,您必须分发第一个用户的用户 ID。

关于java - 为协作 Android 应用程序创建全局 Realm 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44109534/

相关文章:

java - 使用 width 和 max-width 在 JOptionPane 中换行文本

java - 从心电图流计算心率 - java/Nymi Band

android - 异步视频流 Android

android 在多行文本上绘制描边

ios - 偶尔创建加密 Realm 对象失败的原因可能是什么?

Java 小程序安全警告复选框

java - Spring中DataBinder中setAllowedFields和setDisallowedFields方法的影响

php - 无法将我的 PHP 代码连接到数据库 - Android Studio

ios - 在 Realm.io 的多级键路径上使用关键字 : CONTAINS, BEGINSWITH、ENDSWITH

ios - LinkingObject 的用法