We follow a similar approach to D7404. We break apart sqlUpdates into avatarUpdate and nonAvatarUpdates which we handle with separate queries.
We handle nonAvatarUpdates with nonAvatarUpdateQuery, which is largely unchanged from the existing query. I just added some newlines so the formatting was more symmetrical with the newly introduced avatarUpdateQuery.
We introduce avatarUpdateQuery in order to handle updating of avatars. Just as in D7404, we wrap all of the operations in a transaction to ensure that all of these changes occur atomically and we aren't left with a broken state (eg avatar that points to nonexistent upload).
High level overview of avatarUpdateQuery:
- We begin transaction.
- We set container to NULL for any uploads which previously had their container set to request.threadID. container-less uploads will be swept up by a cron job at a later time.
- We set container to request.threadID for the target avatarUploadID specified in the UpdateUserAvatarRequest.
- We set avatar to whatever is in avatarUpdate. If avatarUploadID is NOT NULL, we additionally check that the upload specified in the UpdateUserAvatarRequest exists AND was uploaded by the viewer AND has container set to request.threadID AND that thread field is NULL.
- We commit the transaction.