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!