Sebbene la risposta menzionata da @prasad_ sembri funzionare, $unwind ha da Mongodb 3.2 l'opzione includeArrayIndex che lo rende più facile da ottenere:
db.collection.aggregate([
{
$group: {
_id: null,
data: {
$push: "$$ROOT"
}
}
},
{
$unwind: {
path: "$data",
includeArrayIndex: "counter",
}
},
{
$replaceRoot: {
newRoot: {
$mergeObjects: [
"$data",
{
counter: {
$add: [
"$counter",
1
]
}
}
]
}
}
}
])
L'ultima fase è qui solo per rimodellare i tuoi documenti e aggiungere 1 a ciascun contatore, poiché è basato su 0 (basato sull'indice dell'array)
Puoi provarlo qui.