I have a Mongoose schema that looks like:
const gameSchema = new Schema({
    matchNumber: {
        type: Number,
        required: [true, 'A match must have a number!'],
        unique: true
    },
    red: {
        s1: {
            type: ObjectId,
            ref: 'Match'
        },
        s2: {
            type: ObjectId,
            ref: 'Match'
        },
        s3: {
            type: ObjectId,
            ref: 'Match'
        }
    }
});
And I'm trying to update the document with a Match via Express. On a POST request to  :matchNumber/:alliance/:seed/:teamNumber/match, I do the following:
import * as flatten from 'flat';
let match = req.body;
const game = await Game.findOneAndUpdate(
    { matchNumber },
    flatten({ [alliance]: { [seed]: match._id } }),
    { new: true }
);
When I make the POST request, I get the following error:
CastError: Cast to ObjectId failed for value "ObjectID" at path "red.s1"
I should mention I am using TypeScirpt and this was semi working before but I was encountering the issues mentioned here, whose solution caused what I am now experiencing.
