Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
A
AloqaIM-Android
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
AloqaIM-Android
Commits
760fe05b
Commit
760fe05b
authored
Dec 07, 2016
by
Yusuke Iwaki
Browse files
Options
Browse Files
Download
Plain Diff
FIX #58 Merge branch 'stream-notify' into develop
parents
d9834a6c
35de4115
Changes
16
Show whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
429 additions
and
34 deletions
+429
-34
MethodCallHelper.java
...c/main/java/chat/rocket/android/api/MethodCallHelper.java
+1
-1
SidebarMainFragment.java
.../rocket/android/fragment/sidebar/SidebarMainFragment.java
+1
-1
User.java
app/src/main/java/chat/rocket/android/model/ddp/User.java
+6
-0
RocketChatWebSocketThread.java
...hat/rocket/android/service/RocketChatWebSocketThread.java
+6
-4
AbstractDDPDocEventSubscriber.java
...et/android/service/ddp/AbstractDDPDocEventSubscriber.java
+41
-17
AbstractBaseSubscriber.java
...cket/android/service/ddp/base/AbstractBaseSubscriber.java
+28
-0
ActiveUsersSubscriber.java
...ocket/android/service/ddp/base/ActiveUsersSubscriber.java
+2
-2
LoginServiceConfigurationSubscriber.java
...service/ddp/base/LoginServiceConfigurationSubscriber.java
+2
-2
UserDataSubscriber.java
...t/rocket/android/service/ddp/base/UserDataSubscriber.java
+2
-2
AbstractStreamNotifyEventSubscriber.java
...rvice/ddp/stream/AbstractStreamNotifyEventSubscriber.java
+49
-0
StreamNotifyUserSubscriptionsChanged.java
...vice/ddp/stream/StreamNotifyUserSubscriptionsChanged.java
+37
-0
StreamRoomMessage.java
.../rocket/android/service/ddp/stream/StreamRoomMessage.java
+45
-0
AbstractRocketChatCacheObserver.java
...oid/service/internal/AbstractRocketChatCacheObserver.java
+59
-0
StreamRoomMessageManager.java
...et/android/service/internal/StreamRoomMessageManager.java
+62
-0
CurrentUserObserver.java
.../rocket/android/service/observer/CurrentUserObserver.java
+78
-0
SessionObserver.java
...chat/rocket/android/service/observer/SessionObserver.java
+10
-5
No files found.
app/src/main/java/chat/rocket/android/api/MethodCallHelper.java
View file @
760fe05b
...
@@ -215,7 +215,7 @@ public class MethodCallHelper {
...
@@ -215,7 +215,7 @@ public class MethodCallHelper {
/**
/**
* request "subscriptions/get".
* request "subscriptions/get".
*/
*/
public
Task
<
Void
>
getRooms
()
{
public
Task
<
Void
>
getRoom
Subscription
s
()
{
return
call
(
"subscriptions/get"
,
TIMEOUT_MS
).
onSuccessTask
(
CONVERT_TO_JSON_ARRAY
)
return
call
(
"subscriptions/get"
,
TIMEOUT_MS
).
onSuccessTask
(
CONVERT_TO_JSON_ARRAY
)
.
onSuccessTask
(
task
->
{
.
onSuccessTask
(
task
->
{
final
JSONArray
result
=
task
.
getResult
();
final
JSONArray
result
=
task
.
getResult
();
...
...
app/src/main/java/chat/rocket/android/fragment/sidebar/SidebarMainFragment.java
View file @
760fe05b
...
@@ -67,7 +67,7 @@ public class SidebarMainFragment extends AbstractFragment {
...
@@ -67,7 +67,7 @@ public class SidebarMainFragment extends AbstractFragment {
.
setOnUpdateListener
(
list
->
roomListManager
.
setRooms
(
list
));
.
setOnUpdateListener
(
list
->
roomListManager
.
setRooms
(
list
));
currentUserObserver
=
realmHelper
currentUserObserver
=
realmHelper
.
createObjectObserver
(
realm
->
realm
.
where
(
User
.
class
).
isNotEmpty
(
"emails"
)
)
.
createObjectObserver
(
User:
:
queryCurrentUser
)
.
setOnUpdateListener
(
this
::
onRenderCurrentUser
);
.
setOnUpdateListener
(
this
::
onRenderCurrentUser
);
methodCallHelper
=
new
MethodCallHelper
(
getContext
(),
serverConfigId
);
methodCallHelper
=
new
MethodCallHelper
(
getContext
(),
serverConfigId
);
...
...
app/src/main/java/chat/rocket/android/model/ddp/User.java
View file @
760fe05b
package
chat
.
rocket
.
android
.
model
.
ddp
;
package
chat
.
rocket
.
android
.
model
.
ddp
;
import
io.realm.Realm
;
import
io.realm.RealmList
;
import
io.realm.RealmList
;
import
io.realm.RealmObject
;
import
io.realm.RealmObject
;
import
io.realm.RealmQuery
;
import
io.realm.annotations.PrimaryKey
;
import
io.realm.annotations.PrimaryKey
;
/**
/**
...
@@ -60,4 +62,8 @@ public class User extends RealmObject {
...
@@ -60,4 +62,8 @@ public class User extends RealmObject {
public
void
setEmails
(
RealmList
<
Email
>
emails
)
{
public
void
setEmails
(
RealmList
<
Email
>
emails
)
{
this
.
emails
=
emails
;
this
.
emails
=
emails
;
}
}
public
static
RealmQuery
<
User
>
queryCurrentUser
(
Realm
realm
)
{
return
realm
.
where
(
User
.
class
).
isNotEmpty
(
"emails"
);
}
}
}
app/src/main/java/chat/rocket/android/service/RocketChatWebSocketThread.java
View file @
760fe05b
...
@@ -13,9 +13,10 @@ import chat.rocket.android.model.ServerConfig;
...
@@ -13,9 +13,10 @@ import chat.rocket.android.model.ServerConfig;
import
chat.rocket.android.model.internal.Session
;
import
chat.rocket.android.model.internal.Session
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.realm_helper.RealmStore
;
import
chat.rocket.android.realm_helper.RealmStore
;
import
chat.rocket.android.service.ddp.ActiveUsersSubscriber
;
import
chat.rocket.android.service.ddp.base.ActiveUsersSubscriber
;
import
chat.rocket.android.service.ddp.LoginServiceConfigurationSubscriber
;
import
chat.rocket.android.service.ddp.base.LoginServiceConfigurationSubscriber
;
import
chat.rocket.android.service.ddp.UserDataSubscriber
;
import
chat.rocket.android.service.ddp.base.UserDataSubscriber
;
import
chat.rocket.android.service.observer.CurrentUserObserver
;
import
chat.rocket.android.service.observer.GetUsersOfRoomsProcedureObserver
;
import
chat.rocket.android.service.observer.GetUsersOfRoomsProcedureObserver
;
import
chat.rocket.android.service.observer.LoadMessageProcedureObserver
;
import
chat.rocket.android.service.observer.LoadMessageProcedureObserver
;
import
chat.rocket.android.service.observer.MethodCallObserver
;
import
chat.rocket.android.service.observer.MethodCallObserver
;
...
@@ -43,7 +44,8 @@ public class RocketChatWebSocketThread extends HandlerThread {
...
@@ -43,7 +44,8 @@ public class RocketChatWebSocketThread extends HandlerThread {
SessionObserver
.
class
,
SessionObserver
.
class
,
LoadMessageProcedureObserver
.
class
,
LoadMessageProcedureObserver
.
class
,
GetUsersOfRoomsProcedureObserver
.
class
,
GetUsersOfRoomsProcedureObserver
.
class
,
NewMessageObserver
.
class
NewMessageObserver
.
class
,
CurrentUserObserver
.
class
};
};
private
final
Context
appContext
;
private
final
Context
appContext
;
private
final
String
serverConfigId
;
private
final
String
serverConfigId
;
...
...
app/src/main/java/chat/rocket/android/service/ddp/AbstractDDPDocEventSubscriber.java
View file @
760fe05b
...
@@ -2,20 +2,21 @@ package chat.rocket.android.service.ddp;
...
@@ -2,20 +2,21 @@ package chat.rocket.android.service.ddp;
import
android.content.Context
;
import
android.content.Context
;
import
android.text.TextUtils
;
import
android.text.TextUtils
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.helper.LogcatIfError
;
import
chat.rocket.android.helper.LogcatIfError
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.service.Registerable
;
import
chat.rocket.android.service.Registerable
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android_ddp.DDPSubscription
;
import
chat.rocket.android_ddp.DDPSubscription
;
import
io.realm.Realm
;
import
io.realm.Realm
;
import
io.realm.RealmObject
;
import
io.realm.RealmObject
;
import
java.util.Iterator
;
import
java.util.Iterator
;
import
org.json.JSONArray
;
import
org.json.JSONException
;
import
org.json.JSONException
;
import
org.json.JSONObject
;
import
org.json.JSONObject
;
import
rx.Subscription
;
import
rx.Subscription
;
import
timber.log.Timber
;
import
timber.log.Timber
;
abstract
class
AbstractDDPDocEventSubscriber
implements
Registerable
{
public
abstract
class
AbstractDDPDocEventSubscriber
implements
Registerable
{
protected
final
Context
context
;
protected
final
Context
context
;
protected
final
RealmHelper
realmHelper
;
protected
final
RealmHelper
realmHelper
;
protected
final
DDPClientWraper
ddpClient
;
protected
final
DDPClientWraper
ddpClient
;
...
@@ -31,16 +32,33 @@ abstract class AbstractDDPDocEventSubscriber implements Registerable {
...
@@ -31,16 +32,33 @@ abstract class AbstractDDPDocEventSubscriber implements Registerable {
protected
abstract
String
getSubscriptionName
();
protected
abstract
String
getSubscriptionName
();
protected
abstract
String
getSubscriptionCallbackName
();
protected
abstract
JSONArray
getSubscriptionParams
()
throws
JSONException
;
protected
boolean
shouldTruncateTableOnInitialize
()
{
return
false
;
}
protected
abstract
boolean
isTarget
(
String
callbackName
);
protected
abstract
Class
<?
extends
RealmObject
>
getModelClass
();
protected
abstract
Class
<?
extends
RealmObject
>
getModelClass
();
protected
JSONObject
customizeFieldJson
(
JSONObject
json
)
{
protected
JSONObject
customizeFieldJson
(
JSONObject
json
)
throws
JSONException
{
return
json
;
return
json
;
}
}
@Override
public
void
register
()
{
protected
void
onRegister
()
{}
ddpClient
.
subscribe
(
getSubscriptionName
(),
null
).
onSuccess
(
task
->
{
protected
void
onUnregister
()
{}
@Override
public
final
void
register
()
{
JSONArray
params
=
null
;
try
{
params
=
getSubscriptionParams
();
}
catch
(
JSONException
exception
)
{
// just ignore.
}
ddpClient
.
subscribe
(
getSubscriptionName
(),
params
).
onSuccess
(
task
->
{
subscriptionId
=
task
.
getResult
().
id
;
subscriptionId
=
task
.
getResult
().
id
;
return
null
;
return
null
;
}).
continueWith
(
task
->
{
}).
continueWith
(
task
->
{
...
@@ -50,20 +68,25 @@ abstract class AbstractDDPDocEventSubscriber implements Registerable {
...
@@ -50,20 +68,25 @@ abstract class AbstractDDPDocEventSubscriber implements Registerable {
return
null
;
return
null
;
});
});
if
(
shouldTruncateTableOnInitialize
())
{
realmHelper
.
executeTransaction
(
realm
->
{
realmHelper
.
executeTransaction
(
realm
->
{
realm
.
delete
(
getModelClass
());
realm
.
delete
(
getModelClass
());
return
null
;
return
null
;
}).
onSuccess
(
task
->
{
}).
onSuccess
(
task
->
{
registerSubscriptionCallback
();
rxSubscription
=
subscribe
();
return
null
;
return
null
;
}).
continueWith
(
new
LogcatIfError
());
}).
continueWith
(
new
LogcatIfError
());
}
else
{
rxSubscription
=
subscribe
();
}
onRegister
();
}
}
pr
ivate
void
registerSubscriptionCallback
()
{
pr
otected
Subscription
subscribe
()
{
r
xSubscription
=
ddpClient
.
getSubscriptionCallback
()
r
eturn
ddpClient
.
getSubscriptionCallback
()
.
filter
(
event
->
event
instanceof
DDPSubscription
.
DocEvent
)
.
filter
(
event
->
event
instanceof
DDPSubscription
.
DocEvent
)
.
cast
(
DDPSubscription
.
DocEvent
.
class
)
.
cast
(
DDPSubscription
.
DocEvent
.
class
)
.
filter
(
event
->
getSubscriptionCallbackName
().
equals
(
event
.
collection
))
.
filter
(
event
->
isTarget
(
event
.
collection
))
.
subscribe
(
docEvent
->
{
.
subscribe
(
docEvent
->
{
try
{
try
{
if
(
docEvent
instanceof
DDPSubscription
.
Added
.
Before
)
{
if
(
docEvent
instanceof
DDPSubscription
.
Added
.
Before
)
{
...
@@ -139,7 +162,8 @@ abstract class AbstractDDPDocEventSubscriber implements Registerable {
...
@@ -139,7 +162,8 @@ abstract class AbstractDDPDocEventSubscriber implements Registerable {
}
}
}
}
@Override
public
void
unregister
()
{
@Override
public
final
void
unregister
()
{
onUnregister
();
if
(
rxSubscription
!=
null
)
{
if
(
rxSubscription
!=
null
)
{
rxSubscription
.
unsubscribe
();
rxSubscription
.
unsubscribe
();
}
}
...
...
app/src/main/java/chat/rocket/android/service/ddp/base/AbstractBaseSubscriber.java
0 → 100644
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
ddp
.
base
;
import
android.content.Context
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.service.ddp.AbstractDDPDocEventSubscriber
;
import
org.json.JSONArray
;
abstract
class
AbstractBaseSubscriber
extends
AbstractDDPDocEventSubscriber
{
protected
AbstractBaseSubscriber
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
)
{
super
(
context
,
realmHelper
,
ddpClient
);
}
@Override
protected
final
JSONArray
getSubscriptionParams
()
{
return
null
;
}
@Override
protected
final
boolean
shouldTruncateTableOnInitialize
()
{
return
true
;
}
protected
abstract
String
getSubscriptionCallbackName
();
@Override
protected
final
boolean
isTarget
(
String
callbackName
)
{
return
getSubscriptionCallbackName
().
equals
(
callbackName
);
}
}
app/src/main/java/chat/rocket/android/service/ddp/ActiveUsersSubscriber.java
→
app/src/main/java/chat/rocket/android/service/ddp/
base/
ActiveUsersSubscriber.java
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
ddp
;
package
chat
.
rocket
.
android
.
service
.
ddp
.
base
;
import
android.content.Context
;
import
android.content.Context
;
import
chat.rocket.android.model.ddp.User
;
import
chat.rocket.android.model.ddp.User
;
...
@@ -9,7 +9,7 @@ import io.realm.RealmObject;
...
@@ -9,7 +9,7 @@ import io.realm.RealmObject;
/**
/**
* "activeUsers" subscriber.
* "activeUsers" subscriber.
*/
*/
public
class
ActiveUsersSubscriber
extends
Abstract
DDPDocEvent
Subscriber
{
public
class
ActiveUsersSubscriber
extends
Abstract
Base
Subscriber
{
public
ActiveUsersSubscriber
(
Context
context
,
RealmHelper
realmHelper
,
public
ActiveUsersSubscriber
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
)
{
DDPClientWraper
ddpClient
)
{
super
(
context
,
realmHelper
,
ddpClient
);
super
(
context
,
realmHelper
,
ddpClient
);
...
...
app/src/main/java/chat/rocket/android/service/ddp/LoginServiceConfigurationSubscriber.java
→
app/src/main/java/chat/rocket/android/service/ddp/
base/
LoginServiceConfigurationSubscriber.java
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
ddp
;
package
chat
.
rocket
.
android
.
service
.
ddp
.
base
;
import
android.content.Context
;
import
android.content.Context
;
import
chat.rocket.android.model.ddp.MeteorLoginServiceConfiguration
;
import
chat.rocket.android.model.ddp.MeteorLoginServiceConfiguration
;
...
@@ -9,7 +9,7 @@ import io.realm.RealmObject;
...
@@ -9,7 +9,7 @@ import io.realm.RealmObject;
/**
/**
* meteor.loginServiceConfiguration subscriber
* meteor.loginServiceConfiguration subscriber
*/
*/
public
class
LoginServiceConfigurationSubscriber
extends
Abstract
DDPDocEvent
Subscriber
{
public
class
LoginServiceConfigurationSubscriber
extends
Abstract
Base
Subscriber
{
public
LoginServiceConfigurationSubscriber
(
Context
context
,
RealmHelper
realmHelper
,
public
LoginServiceConfigurationSubscriber
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
)
{
DDPClientWraper
ddpClient
)
{
super
(
context
,
realmHelper
,
ddpClient
);
super
(
context
,
realmHelper
,
ddpClient
);
...
...
app/src/main/java/chat/rocket/android/service/ddp/UserDataSubscriber.java
→
app/src/main/java/chat/rocket/android/service/ddp/
base/
UserDataSubscriber.java
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
ddp
;
package
chat
.
rocket
.
android
.
service
.
ddp
.
base
;
import
android.content.Context
;
import
android.content.Context
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.api.DDPClientWraper
;
...
@@ -9,7 +9,7 @@ import io.realm.RealmObject;
...
@@ -9,7 +9,7 @@ import io.realm.RealmObject;
/**
/**
* "userData" subscriber.
* "userData" subscriber.
*/
*/
public
class
UserDataSubscriber
extends
Abstract
DDPDocEvent
Subscriber
{
public
class
UserDataSubscriber
extends
Abstract
Base
Subscriber
{
public
UserDataSubscriber
(
Context
context
,
RealmHelper
realmHelper
,
public
UserDataSubscriber
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
)
{
DDPClientWraper
ddpClient
)
{
super
(
context
,
realmHelper
,
ddpClient
);
super
(
context
,
realmHelper
,
ddpClient
);
...
...
app/src/main/java/chat/rocket/android/service/ddp/stream/AbstractStreamNotifyEventSubscriber.java
0 → 100644
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
ddp
.
stream
;
import
android.content.Context
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.helper.LogcatIfError
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.service.ddp.AbstractDDPDocEventSubscriber
;
import
chat.rocket.android_ddp.DDPSubscription
;
import
org.json.JSONArray
;
import
org.json.JSONObject
;
import
timber.log.Timber
;
abstract
class
AbstractStreamNotifyEventSubscriber
extends
AbstractDDPDocEventSubscriber
{
protected
AbstractStreamNotifyEventSubscriber
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
)
{
super
(
context
,
realmHelper
,
ddpClient
);
}
@Override
protected
final
boolean
shouldTruncateTableOnInitialize
()
{
return
false
;
}
@Override
protected
final
boolean
isTarget
(
String
callbackName
)
{
return
getSubscriptionName
().
equals
(
callbackName
);
}
protected
abstract
String
getPrimaryKeyForModel
();
@Override
protected
void
onDocumentChanged
(
DDPSubscription
.
Changed
docEvent
)
{
try
{
JSONArray
args
=
docEvent
.
fields
.
getJSONArray
(
"args"
);
String
msg
=
args
.
length
()
>
0
?
args
.
getString
(
0
)
:
null
;
JSONObject
target
=
args
.
getJSONObject
(
args
.
length
()
-
1
);
if
(
"removed"
.
equals
(
msg
))
{
realmHelper
.
executeTransaction
(
realm
->
realm
.
where
(
getModelClass
())
.
equalTo
(
getPrimaryKeyForModel
(),
target
.
getString
(
getPrimaryKeyForModel
()))
.
findAll
().
deleteAllFromRealm
()
).
continueWith
(
new
LogcatIfError
());
}
else
{
//inserted, updated
realmHelper
.
executeTransaction
(
realm
->
realm
.
createOrUpdateObjectFromJson
(
getModelClass
(),
customizeFieldJson
(
target
))
).
continueWith
(
new
LogcatIfError
());
}
}
catch
(
Exception
exception
)
{
Timber
.
w
(
exception
,
"failed to save stream-notify event."
);
}
}
}
app/src/main/java/chat/rocket/android/service/ddp/stream/StreamNotifyUserSubscriptionsChanged.java
0 → 100644
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
ddp
.
stream
;
import
android.content.Context
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.model.ddp.RoomSubscription
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
io.realm.RealmObject
;
import
org.json.JSONArray
;
import
org.json.JSONException
;
public
class
StreamNotifyUserSubscriptionsChanged
extends
AbstractStreamNotifyEventSubscriber
{
private
final
String
userId
;
public
StreamNotifyUserSubscriptionsChanged
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
,
String
userId
)
{
super
(
context
,
realmHelper
,
ddpClient
);
this
.
userId
=
userId
;
}
@Override
protected
String
getSubscriptionName
()
{
return
"stream-notify-user"
;
}
@Override
protected
JSONArray
getSubscriptionParams
()
throws
JSONException
{
return
new
JSONArray
()
.
put
(
userId
+
"/subscriptions-changed"
)
.
put
(
false
);
}
@Override
protected
Class
<?
extends
RealmObject
>
getModelClass
()
{
return
RoomSubscription
.
class
;
}
@Override
protected
String
getPrimaryKeyForModel
()
{
return
"rid"
;
}
}
app/src/main/java/chat/rocket/android/service/ddp/stream/StreamRoomMessage.java
0 → 100644
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
ddp
.
stream
;
import
android.content.Context
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.model.ddp.Message
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
io.realm.RealmObject
;
import
org.json.JSONArray
;
import
org.json.JSONException
;
import
org.json.JSONObject
;
/**
* stream-room-message subscriber.
*/
public
class
StreamRoomMessage
extends
AbstractStreamNotifyEventSubscriber
{
private
String
roomId
;
public
StreamRoomMessage
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
,
String
roomId
)
{
super
(
context
,
realmHelper
,
ddpClient
);
this
.
roomId
=
roomId
;
}
@Override
protected
String
getSubscriptionName
()
{
return
"stream-room-messages"
;
}
@Override
protected
JSONArray
getSubscriptionParams
()
throws
JSONException
{
return
new
JSONArray
()
.
put
(
roomId
)
.
put
(
false
);
}
@Override
protected
Class
<?
extends
RealmObject
>
getModelClass
()
{
return
Message
.
class
;
}
@Override
protected
String
getPrimaryKeyForModel
()
{
return
"_id"
;
}
@Override
protected
JSONObject
customizeFieldJson
(
JSONObject
json
)
throws
JSONException
{
return
Message
.
customizeJson
(
super
.
customizeFieldJson
(
json
));
}
}
app/src/main/java/chat/rocket/android/service/internal/AbstractRocketChatCacheObserver.java
0 → 100644
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
internal
;
import
android.content.Context
;
import
android.content.SharedPreferences
;
import
chat.rocket.android.RocketChatCache
;
import
chat.rocket.android.helper.TextUtils
;
import
chat.rocket.android.model.ddp.RoomSubscription
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.service.Registerable
;
public
abstract
class
AbstractRocketChatCacheObserver
implements
Registerable
{
private
final
Context
context
;
private
final
RealmHelper
realmHelper
;
private
String
roomId
;
protected
AbstractRocketChatCacheObserver
(
Context
context
,
RealmHelper
realmHelper
)
{
this
.
context
=
context
;
this
.
realmHelper
=
realmHelper
;
}
private
void
updateRoomIdWith
(
SharedPreferences
prefs
)
{
String
roomId
=
prefs
.
getString
(
RocketChatCache
.
KEY_SELECTED_ROOM_ID
,
null
);
if
(!
TextUtils
.
isEmpty
(
roomId
))
{
RoomSubscription
room
=
realmHelper
.
executeTransactionForRead
(
realm
->
realm
.
where
(
RoomSubscription
.
class
).
equalTo
(
"rid"
,
roomId
).
findFirst
());
if
(
room
!=
null
)
{
if
(
this
.
roomId
==
null
||
!
this
.
roomId
.
equals
(
roomId
))
{
this
.
roomId
=
roomId
;
onRoomIdUpdated
(
roomId
);
}
return
;
}
}
if
(
this
.
roomId
!=
null
)
{
this
.
roomId
=
null
;
onRoomIdUpdated
(
null
);
}
}
protected
abstract
void
onRoomIdUpdated
(
String
roomId
);
private
SharedPreferences
.
OnSharedPreferenceChangeListener
listener
=
(
prefs
,
key
)
->
{
if
(
RocketChatCache
.
KEY_SELECTED_ROOM_ID
.
equals
(
key
))
{
updateRoomIdWith
(
prefs
);
}
};
@Override
public
final
void
register
()
{
SharedPreferences
prefs
=
RocketChatCache
.
get
(
context
);
prefs
.
registerOnSharedPreferenceChangeListener
(
listener
);
updateRoomIdWith
(
prefs
);
}
@Override
public
final
void
unregister
()
{
RocketChatCache
.
get
(
context
).
unregisterOnSharedPreferenceChangeListener
(
listener
);
}
}
app/src/main/java/chat/rocket/android/service/internal/StreamRoomMessageManager.java
0 → 100644
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
internal
;
import
android.content.Context
;
import
android.os.Handler
;
import
android.os.Looper
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.service.Registerable
;
import
chat.rocket.android.service.ddp.stream.StreamRoomMessage
;
/**
* wrapper for managing stream-notify-message depending on RocketChatCache.
*/
public
class
StreamRoomMessageManager
implements
Registerable
{
private
StreamRoomMessage
streamRoomMessage
;
private
final
Context
context
;
private
final
RealmHelper
realmHelper
;
private
final
DDPClientWraper
ddpClient
;
private
final
AbstractRocketChatCacheObserver
cacheObserver
;
private
final
Handler
handler
;
public
StreamRoomMessageManager
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
)
{
this
.
context
=
context
;
this
.
realmHelper
=
realmHelper
;
this
.
ddpClient
=
ddpClient
;
cacheObserver
=
new
AbstractRocketChatCacheObserver
(
context
,
realmHelper
)
{
@Override
protected
void
onRoomIdUpdated
(
String
roomId
)
{
unregisterStreamNotifyMessageIfNeeded
();
registerStreamNotifyMessage
(
roomId
);
}
};
handler
=
new
Handler
(
Looper
.
myLooper
());
}
private
void
registerStreamNotifyMessage
(
String
roomId
)
{
streamRoomMessage
=
new
StreamRoomMessage
(
context
,
realmHelper
,
ddpClient
,
roomId
);
handler
.
post
(()
->
{
streamRoomMessage
.
register
();
});
}
private
void
unregisterStreamNotifyMessageIfNeeded
()
{
if
(
streamRoomMessage
!=
null
)
{
handler
.
post
(()
->
{
streamRoomMessage
.
unregister
();
});
streamRoomMessage
=
null
;
}
}
@Override
public
void
register
()
{
cacheObserver
.
register
();
}
@Override
public
void
unregister
()
{
unregisterStreamNotifyMessageIfNeeded
();
cacheObserver
.
unregister
();
}
}
app/src/main/java/chat/rocket/android/service/observer/CurrentUserObserver.java
0 → 100644
View file @
760fe05b
package
chat
.
rocket
.
android
.
service
.
observer
;
import
android.content.Context
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.api.MethodCallHelper
;
import
chat.rocket.android.model.ddp.User
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.service.Registerable
;
import
chat.rocket.android.service.ddp.stream.StreamNotifyUserSubscriptionsChanged
;
import
hugo.weaving.DebugLog
;
import
io.realm.Realm
;
import
io.realm.RealmResults
;
import
java.util.ArrayList
;
import
java.util.List
;
/**
* observe the user with emails.
*/
public
class
CurrentUserObserver
extends
AbstractModelObserver
<
User
>
{
private
boolean
currentUserExists
;
private
final
MethodCallHelper
methodCall
;
private
ArrayList
<
Registerable
>
listeners
;
public
CurrentUserObserver
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
)
{
super
(
context
,
realmHelper
,
ddpClient
);
methodCall
=
new
MethodCallHelper
(
realmHelper
,
ddpClient
);
currentUserExists
=
false
;
}
@Override
public
RealmResults
<
User
>
queryItems
(
Realm
realm
)
{
return
User
.
queryCurrentUser
(
realm
).
findAll
();
}
@Override
public
void
onUpdateResults
(
List
<
User
>
results
)
{
boolean
exists
=
!
results
.
isEmpty
();
if
(
currentUserExists
!=
exists
)
{
if
(
exists
)
{
onLogin
(
results
.
get
(
0
));
}
else
{
onLogout
();
}
currentUserExists
=
exists
;
}
}
@DebugLog
private
void
onLogin
(
User
user
)
{
if
(
listeners
!=
null
)
{
onLogout
();
}
listeners
=
new
ArrayList
<>();
final
String
userId
=
user
.
get_id
();
// get and observe Room subscriptions.
methodCall
.
getRoomSubscriptions
().
onSuccess
(
task
->
{
Registerable
listener
=
new
StreamNotifyUserSubscriptionsChanged
(
context
,
realmHelper
,
ddpClient
,
userId
);
listener
.
register
();
listeners
.
add
(
listener
);
return
null
;
});
}
@DebugLog
private
void
onLogout
()
{
if
(
listeners
!=
null
)
{
for
(
Registerable
listener
:
listeners
)
{
listener
.
unregister
();
}
}
listeners
=
null
;
}
}
app/src/main/java/chat/rocket/android/service/observer/SessionObserver.java
View file @
760fe05b
...
@@ -2,12 +2,13 @@ package chat.rocket.android.service.observer;
...
@@ -2,12 +2,13 @@ package chat.rocket.android.service.observer;
import
android.content.Context
;
import
android.content.Context
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.api.DDPClientWraper
;
import
chat.rocket.android.api.MethodCallHelper
;
import
chat.rocket.android.helper.LogcatIfError
;
import
chat.rocket.android.helper.LogcatIfError
;
import
chat.rocket.android.model.internal.GetUsersOfRoomsProcedure
;
import
chat.rocket.android.model.internal.LoadMessageProcedure
;
import
chat.rocket.android.model.internal.LoadMessageProcedure
;
import
chat.rocket.android.model.internal.MethodCall
;
import
chat.rocket.android.model.internal.MethodCall
;
import
chat.rocket.android.model.internal.Session
;
import
chat.rocket.android.model.internal.Session
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.realm_helper.RealmHelper
;
import
chat.rocket.android.service.internal.StreamRoomMessageManager
;
import
hugo.weaving.DebugLog
;
import
hugo.weaving.DebugLog
;
import
io.realm.Realm
;
import
io.realm.Realm
;
import
io.realm.RealmResults
;
import
io.realm.RealmResults
;
...
@@ -17,16 +18,18 @@ import java.util.List;
...
@@ -17,16 +18,18 @@ import java.util.List;
* Observes user is logged into server.
* Observes user is logged into server.
*/
*/
public
class
SessionObserver
extends
AbstractModelObserver
<
Session
>
{
public
class
SessionObserver
extends
AbstractModelObserver
<
Session
>
{
private
final
MethodCallHelper
methodCall
;
private
int
count
;
private
int
count
;
private
final
StreamRoomMessageManager
streamNotifyMessage
;
/**
/**
* constructor.
* constructor.
*/
*/
public
SessionObserver
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
)
{
public
SessionObserver
(
Context
context
,
RealmHelper
realmHelper
,
DDPClientWraper
ddpClient
)
{
super
(
context
,
realmHelper
,
ddpClient
);
super
(
context
,
realmHelper
,
ddpClient
);
methodCall
=
new
MethodCallHelper
(
realmHelper
,
ddpClient
);
count
=
0
;
count
=
0
;
streamNotifyMessage
=
new
StreamRoomMessageManager
(
context
,
realmHelper
,
ddpClient
);
}
}
@Override
public
RealmResults
<
Session
>
queryItems
(
Realm
realm
)
{
@Override
public
RealmResults
<
Session
>
queryItems
(
Realm
realm
)
{
...
@@ -57,15 +60,17 @@ public class SessionObserver extends AbstractModelObserver<Session> {
...
@@ -57,15 +60,17 @@ public class SessionObserver extends AbstractModelObserver<Session> {
}
}
@DebugLog
private
void
onLogin
()
{
@DebugLog
private
void
onLogin
()
{
methodCall
.
getRooms
().
continueWith
(
new
LogcatIfError
());
streamNotifyMessage
.
register
();
}
}
@DebugLog
private
void
onLogout
()
{
@DebugLog
private
void
onLogout
()
{
streamNotifyMessage
.
unregister
();
realmHelper
.
executeTransaction
(
realm
->
{
realmHelper
.
executeTransaction
(
realm
->
{
// remove all tables. ONLY INTERNAL TABLES!.
// remove all tables. ONLY INTERNAL TABLES!.
realm
.
delete
(
MethodCall
.
class
);
realm
.
delete
(
MethodCall
.
class
);
realm
.
delete
(
LoadMessageProcedure
.
class
);
realm
.
delete
(
LoadMessageProcedure
.
class
);
realm
.
delete
(
GetUsersOfRoomsProcedure
.
class
);
return
null
;
return
null
;
}).
continueWith
(
new
LogcatIfError
());
}).
continueWith
(
new
LogcatIfError
());
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment