Android (React) App - Can't Change Avatar

Description

I am able to upload/change avatars from the web client.

However, when I try to upload a new avatar from the Android (react) client, I get a white box popup that says: “There was an error while changing avatar!”

I am using Filesystem storage method, and am able to send photos just fine to channels. I’ve tweaked every avatar setting that I can find, with no change.

One other thing I’ll note is that even though I found an issue marked ‘fixed’ about this, when I did upload an avatar via web client, I had to manually clear the cache in my android app to get them to show.

Server Setup Information

  • Version of Rocket.Chat Server: 3.0.12
  • Operating System: Linux
  • Deployment Method: Docker
  • Number of Running Instances: 1
  • DB Replicaset Oplog:
  • NodeJS Version: v12.14.0
  • MongoDB Version: mmapv1
  • Proxy: Nginx
  • Firewalls involved: ufw

Any additional Information

I20200415-19:08:00.517(0) server.js:204 SyncedCron ➔ info Starting "Generate download files for user data". 

I20200415-19:08:00.521(0) server.js:204 SyncedCron ➔ info Finished "Generate download files for user data". 

I20200415-19:10:00.535(0) server.js:204 SyncedCron ➔ info Starting "Generate download files for user data". 

I20200415-19:10:00.539(0) server.js:204 SyncedCron ➔ info Finished "Generate download files for user data". 

I20200415-19:10:19.771(0) UserPresence:online {   id: 'nzFLBkZWGwtgi5HLs',   clientAddress: null,   httpHeaders: {     'x-real-ip': '<redacted>,     host: <redacted>,     'user-agent': 'RC Mobile; android 10; v4.6.1 (999999999)'   },   userId: 'BdNZQ7ZXxgrSD9GZc' } 

I20200415-19:10:19.774(0) server.js:204 Meteor ➔ method UserPresence:online -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:20.065(0) server.js:204 API ➔ debug GET: /api/v1/subscriptions.get?updatedSince=2020-04-15T19%3A02%3A29.715Z 

I20200415-19:10:20.069(0) server.js:204 API ➔ debug GET: /api/v1/rooms.get?updatedSince=2020-04-15T19%3A02%3A29.715Z 

I20200415-19:10:20.072(0) subscriptions/get {   id: 'tmz8EsR3DaHTp8QjF',   clientAddress: undefined,   httpHeaders: undefined,   userId: 'BdNZQ7ZXxgrSD9GZc' } 

I20200415-19:10:20.076(0) server.js:204 Meteor ➔ method subscriptions/get -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:20.078(0) rooms/get {   id: 'DeFnGPzo4nMckCAnC',   clientAddress: undefined,   httpHeaders: undefined,   userId: 'BdNZQ7ZXxgrSD9GZc' } 

I20200415-19:10:20.084(0) server.js:204 Meteor ➔ method rooms/get -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:20.095(0) server.js:204 API ➔ debug Success {   statusCode: 200,   body: { update: [ [Object] ], remove: [], success: true } } 

I20200415-19:10:20.102(0) server.js:204 API ➔ debug Success { statusCode: 200, body: { update: [], remove: [], success: true } } 

I20200415-19:10:22.147(0) getAvatarSuggestion {   id: 'nzFLBkZWGwtgi5HLs',   clientAddress: null,   httpHeaders: {     'x-real-ip': <redacted>,     host: <redacted>,     'user-agent': 'RC Mobile; android 10; v4.6.1 (999999999)'   },   userId: '<redacted> } 

I20200415-19:10:22.150(0) server.js:204 Meteor ➔ method getAvatarSuggestion -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:23.465(0) UserPresence:away {   id: 'nzFLBkZWGwtgi5HLs',   clientAddress: null,   httpHeaders: {     'x-real-ip':<redacted>',     host: <redacted>,     'user-agent': 'RC Mobile; android 10; v4.6.1 (999999999)'   },   userId: <redacted> } 

I20200415-19:10:23.467(0) server.js:204 Meteor ➔ method UserPresence:away -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:29.554(0) UserPresence:online {   id: 'nzFLBkZWGwtgi5HLs',   clientAddress: null,   httpHeaders: {     'x-real-ip': <redacted>     host:<redacted>,     'user-agent': 'RC Mobile; android 10; v4.6.1 (999999999)'   },   userId:<redacted> } 

I20200415-19:10:29.556(0) server.js:204 Meteor ➔ method UserPresence:online -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:29.597(0) server.js:204 API ➔ debug GET: /api/v1/subscriptions.get?updatedSince=2020-04-15T19%3A10%3A17.724Z 

I20200415-19:10:29.611(0) subscriptions/get {   id: '923iroB5zWZTKSenc',   clientAddress: undefined,   httpHeaders: undefined,   userId: '<redacted> } 

I20200415-19:10:29.617(0) server.js:204 Meteor ➔ method subscriptions/get -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:29.632(0) server.js:204 API ➔ debug Success { statusCode: 200, body: { update: [], remove: [], success: true } } 

I20200415-19:10:29.640(0) UserPresence:away {   id:<redacted>,   clientAddress: null,   httpHeaders: {     'x-real-ip': '174.221.15.87',     host: <redacted>,     'user-agent': 'RC Mobile; android 10; v4.6.1 (999999999)'   },   userId: <redacted> } 

I20200415-19:10:29.651(0) server.js:204 Meteor ➔ method UserPresence:away -> userId: <redacted>, arguments: [{}] 

I20200415-19:10:29.704(0) server.js:204 API ➔ debug GET: /api/v1/rooms.get?updatedSince=2020-04-15T19%3A10%3A17.724Z 

I20200415-19:10:29.715(0) rooms/get {   id: 'YmuLvzA4PwzHYQknH',   clientAddress: undefined,   httpHeaders: undefined,   userId:<redacted> } 

I20200415-19:10:29.724(0) server.js:204 Meteor ➔ method rooms/get -> userId: <redacted>, arguments: [{}] 

I20200415-19:10:29.746(0) server.js:204 API ➔ debug Success { statusCode: 200, body: { update: [], remove: [], success: true } } 

I20200415-19:10:31.576(0) UserPresence:online {   id: 'nzFLBkZWGwtgi5HLs',   clientAddress: null,   httpHeaders: {     'x-real-ip': <redacted>,     host: <redacted>',     'user-agent': 'RC Mobile; android 10; v4.6.1 (999999999)'   },   userId:<redacted> } 

I20200415-19:10:31.583(0) server.js:204 Meteor ➔ method UserPresence:online -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:31.609(0) server.js:204 API ➔ debug GET: /api/v1/rooms.get?updatedSince=2020-04-15T19%3A10%3A17.724Z 

I20200415-19:10:31.617(0) rooms/get {   id: 'N5Lh3dJYRfJ2XDjjm',   clientAddress: undefined,   httpHeaders: undefined,   userId: 'BdNZQ7ZXxgrSD9GZc' } 

I20200415-19:10:31.620(0) server.js:204 Meteor ➔ method rooms/get -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:31.632(0) server.js:204 API ➔ debug Success { statusCode: 200, body: { update: [], remove: [], success: true } } 

I20200415-19:10:31.644(0) server.js:204 API ➔ debug GET: /api/v1/subscriptions.get?updatedSince=2020-04-15T19%3A10%3A17.724Z 

I20200415-19:10:31.646(0) subscriptions/get {   id: 'NpssZWaoDvTcvg73q',   clientAddress: undefined,   httpHeaders: undefined,   userId: 'BdNZQ7ZXxgrSD9GZc' } 

I20200415-19:10:31.649(0) server.js:204 Meteor ➔ method subscriptions/get -> userId: BdNZQ7ZXxgrSD9GZc, arguments: [{}] 

I20200415-19:10:31.660(0) server.js:204 API ➔ debug Success { statusCode: 200, body: { update: [], remove: [], success: true } } 

I20200415-19:10:38.404(0) setAvatarFromService {   id: 'nzFLBkZWGwtgi5HLs',   clientAddress: null,   httpHeaders: {     'x-real-ip':<redacted>,     host: <redacted>,     'user-agent': 'RC Mobile; android 10; v4.6.1 (999999999)'   },   userId: 'BdNZQ7ZXxgrSD9GZc' } 

I20200415-19:10:38.407(0) server.js:204 Meteor ➔ method setAvatarFromService -> userId: BdNZQ7ZXxgrSD9GZc, arguments: ["","","upload",{}] 

I20200415-19:10:38.418(0) Exception while invoking method 'setAvatarFromService' errorClass [Error]: Match error: Failed Match.OneOf, Match.Maybe or Match.Optional validation     at check (packages/check/match.js:36:17)     at MethodInvocation.setAvatarFromService (server/methods/setAvatarFromService.js:15:3)     at MethodInvocation.methodsMap.<computed> (app/lib/server/lib/debug.js:67:34)     at maybeAuditArgumentChecks (packages/ddp-server/livedata_server.js:1771:12)     at packages/ddp-server/livedata_server.js:719:19     at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12)     at packages/ddp-server/livedata_server.js:717:46     at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12)     at packages/ddp-server/livedata_server.js:715:46     at new Promise (<anonymous>)     at Session.method (packages/ddp-server/livedata_server.js:689:23)     at packages/ddp-server/livedata_server.js:559:43 {   message: 'Match error: Failed Match.OneOf, Match.Maybe or Match.Optional validation',   path: '',   sanitizedError: errorClass [Error]: Match failed [400]       at errorClass.<anonymous> (packages/check/match.js:91:27)       at new errorClass (packages/meteor.js:655:17)       at check (packages/check/match.js:36:17)       at MethodInvocation.setAvatarFromService (server/methods/setAvatarFromService.js:15:3)       at MethodInvocation.methodsMap.<computed> (app/lib/server/lib/debug.js:67:34)       at maybeAuditArgumentChecks (packages/ddp-server/livedata_server.js:1771:12)       at packages/ddp-server/livedata_server.js:719:19       at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12)       at packages/ddp-server/livedata_server.js:717:46       at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12)       at packages/ddp-server/livedata_server.js:715:46       at new Promise (<anonymous>)       at Session.method (packages/ddp-server/livedata_server.js:689:23)       at packages/ddp-server/livedata_server.js:559:43 {     isClientSafe: true,     error: 400,     reason: 'Match failed',     details: undefined,     message: 'Match failed [400]',     errorType: 'Meteor.Error'   },   errorType: 'Match.Error' } 

I20200415-19:10:38.419(0) Sanitized and reported to the client as: errorClass [Error]: Match failed [400]     at errorClass.<anonymous> (packages/check/match.js:91:27)     at new errorClass (packages/meteor.js:655:17)     at check (packages/check/match.js:36:17)     at MethodInvocation.setAvatarFromService (server/methods/setAvatarFromService.js:15:3)     at MethodInvocation.methodsMap.<computed> (app/lib/server/lib/debug.js:67:34)     at maybeAuditArgumentChecks (packages/ddp-server/livedata_server.js:1771:12)     at packages/ddp-server/livedata_server.js:719:19     at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12)     at packages/ddp-server/livedata_server.js:717:46     at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12)     at packages/ddp-server/livedata_server.js:715:46     at new Promise (<anonymous>)     at Session.method (packages/ddp-server/livedata_server.js:689:23)     at packages/ddp-server/livedata_server.js:559:43 {   isClientSafe: true,   error: 400,   reason: 'Match failed',   details: undefined,   message: 'Match failed [400]',   errorType: 'Meteor.Error' } 

I20200415-19:10:38.420(0) undefined undefined

Thanks for any help you guys can offer!

3 Likes

Same Problem here.
Avatar can be changed via web client, but not in the Android App.

To get them to show in the App i have to log off and on again (or clear the Appchache).

Version of Rocket.Chat Server: 3.0.12
OS: Linux
NodeJS Version: v12.14.0
MongoDB Version: 4.0.17
Proxy: Apache 2.4

Android-App Version: 4.6.4.2118

Exception while invoking method 'setAvatarFromService' errorClass [Error]: Match error: Failed Match.OneOf, Match.Maybe or Match.Optional validation at check (packages/check/match.js:36:17) at MethodInvocation.setAvatarFromService (server/methods/setAvatarFromService.js:15:3) at MethodInvocation.methodsMap.<computed> (app/lib/server/lib/debug.js:67:34) at maybeAuditArgumentChecks (packages/ddp-server/livedata_server.js:1771:12) at packages/ddp-server/livedata_server.js:719:19 at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12) at packages/ddp-server/livedata_server.js:717:46 at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12) at packages/ddp-server/livedata_server.js:715:46 at new Promise (<anonymous>) at Session.method (packages/ddp-server/livedata_server.js:689:23) at packages/ddp-server/livedata_server.js:559:43 { message: 'Match error: Failed Match.OneOf, Match.Maybe or Match.Optional validation', path: '', sanitizedError: errorClass [Error]: Match failed [400] at errorClass.<anonymous> (packages/check/match.js:91:27) at new errorClass (packages/meteor.js:655:17) at check (packages/check/match.js:36:17) at MethodInvocation.setAvatarFromService (server/methods/setAvatarFromService.js:15:3) at MethodInvocation.methodsMap.<computed> (app/lib/server/lib/debug.js:67:34) at maybeAuditArgumentChecks (packages/ddp-server/livedata_server.js:1771:12) at packages/ddp-server/livedata_server.js:719:19 at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12) at packages/ddp-server/livedata_server.js:717:46 at Meteor.EnvironmentVariable.EVp.withValue (packages/meteor.js:1234:12) at packages/ddp-server/livedata_server.js:715:46 at new Promise (<anonymous>) at Session.method (packages/ddp-server/livedata_server.js:689:23) at packages/ddp-server/livedata_server.js:559:43 { isClientSafe: true, error: 400, reason: 'Match failed', details: undefined, message: 'Match failed [400]', errorType: 'Meteor.Error' }, errorType: 'Match.Error' }

3 Likes

I have the exact same log, be it from iOS or Android mobile app and same behaviour with the avatars loading on mobile apps, you need to clear the cache to have to load…

Only difference is that I am running the latest snap on Ubuntu.

So this doesn’t seem to be related to our installs/setups

2 Likes

The same problems. Pls. help !

  • Rocket Chat Version: 3.2.0-develop
  • NodeJS Version: 12.16.1 - x64
  • MongoDB Version: 4.0.18
  • MongoDB Engine: mmapv1
  • Platform: linux
  • Deployment Method: Docker

The same problem with the official server
https://open.rocket.chat
with the Rocket.Chat Experimental client from the Google Play Market

I have a idea that Server based on Meteor has some problems with headers like CORS, etc for mobile clients. For example in 2016 was https://github.com/meteor/meteor/issues/3469

I compared the logs of the upload avatar from the web browser and from the mobile application.
When generating a request from a mobile application, the Content-Type parameter is empty!

Adnroid APP with error
server.js:204 Meteor ➔ method setAvatarFromService -> userId: aW7eNTaqHETbp5YnK, arguments: [“< … >ge4zz9azoXIJxipERZZTvGaBlpSiy4hkZyOeP8DVj7ZcDja3/fIrN/1ch28VVe5l3H5jUgf//Z”,
“”,“upload”,{}]

Chrome Browser success:
server.js:204 Meteor ➔ method setAvatarFromService -> userId: aW7eNTaqHETbp5YnK, arguments: [“< … >ge4zz9azoXIJxipERZZTvGaBlpSiy4hkZyOeP8DVj7ZcDja3/fIrN/1ch28VVe5l3H5jUgf//Z”,
“image/jpeg”,“upload”]

What to do ?