codecombat/scripts/mongodb/updateCourses.js

79 lines
2.4 KiB
JavaScript
Raw Normal View History

2015-08-29 10:15:35 -04:00
// Update course data
// Usage:
// mongo <address>:<port>/<database> <script file> -u <username> -p <password>
// NOTE: uses name as unique identifier, so changing the name will insert a new course
// NOTE: pricePerSeat in USD cents
2015-08-29 10:15:35 -04:00
2015-09-10 13:37:32 -04:00
var courses =
2015-08-29 10:15:35 -04:00
[
{
name: "Introduction to Computer Science",
slug: "introduction-to-computer-science",
campaignID: ObjectId("55b29efd1cd6abe8ce07db0d"),
description: "Learn basic syntax, while loops, and the CodeCombat environment.",
2015-09-10 13:37:32 -04:00
duration: NumberInt(1),
free: true,
2015-08-29 10:15:35 -04:00
screenshot: "/images/pages/courses/101_info.png"
},
{
name: "Computer Science 2",
slug: "computer-science-2",
campaignID: ObjectId("562f88e84df18473073c74e2"),
description: "Introduce Arguments, Variables, If Statements, and Arithmetic.",
2015-09-10 13:37:32 -04:00
duration: NumberInt(5),
free: false,
screenshot: "/images/pages/courses/102_info.png"
},
{
name: "Computer Science 3",
slug: "computer-science-3",
campaignID: ObjectId("56462ac4410c528505e1160a"),
description: "Introduces arithmetic, counters, advanced while loops, break, continue, arrays.",
2015-09-10 13:37:32 -04:00
duration: NumberInt(5),
free: false,
screenshot: "/images/pages/courses/103_info.png"
},
{
name: "Computer Science 4",
slug: "computer-science-4",
campaignID: ObjectId("56462c1133f1478605ebd018"),
description: "Introduces object literals, for loops, function definitions, drawing, and modulo.",
duration: NumberInt(5),
free: false,
screenshot: "/images/pages/courses/104_info.png"
},
{
name: "Computer Science 5",
slug: "computer-science-5",
campaignID: ObjectId("568ad069a6584820004437f2"),
description: "Introduces function parameters, function return values and algorithms.",
duration: NumberInt(5),
free: false,
screenshot: "/images/pages/courses/105_info.png"
2015-08-29 10:15:35 -04:00
}
];
print("Finding course concepts..");
for (var i = 0; i < courses.length; i++) {
var concepts = {};
var cursor = db.campaigns.find({_id: courses[i].campaignID}, {'levels': 1});
if (cursor.hasNext()) {
var doc = cursor.next();
for (var levelID in doc.levels) {
for (var j = 0; j < doc.levels[levelID].concepts.length; j++) {
concepts[doc.levels[levelID].concepts[j]] = true;
}
}
}
courses[i].concepts = Object.keys(concepts);
}
print("Updating courses..");
2015-09-10 13:37:32 -04:00
for (var i = 0; i < courses.length; i++) {
db.courses.update({name: courses[i].name}, courses[i], {upsert: true});
2015-08-29 10:15:35 -04:00
}
print("Done.");