-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
6db55ac
commit 52513e3
Showing
2 changed files
with
140 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,138 @@ | ||
import { EducationModel, type EducationType } from "../models/education.model"; | ||
import { HttpError, HttpStatus, checkMongooseErrors } from "../utils/errors"; | ||
import { checkDuplicateItemName } from "../utils/checkDuplicates"; | ||
|
||
export const createEducation = async (educationFields: EducationType) => { | ||
try { | ||
if (await checkDuplicateItemName(educationFields.itemName)) { | ||
throw new HttpError(HttpStatus.BAD_REQUEST, "Duplicate item name"); | ||
} | ||
|
||
const newEducation = new EducationModel(educationFields); | ||
await newEducation.save(); | ||
return newEducation; | ||
} catch (err: unknown) { | ||
if (err instanceof HttpError) { | ||
throw err; | ||
} | ||
|
||
checkMongooseErrors(err); | ||
|
||
throw new HttpError( | ||
HttpStatus.INTERNAL_SERVER_ERROR, | ||
"Education creation failed", | ||
{ cause: err }, | ||
); | ||
} | ||
}; | ||
|
||
export const getAllEducation = async (user: string) => { | ||
try { | ||
const education = await EducationModel.find({ user: user }); | ||
return education; | ||
} catch (err: unknown) { | ||
//rethrow any errors as HttpErrors | ||
if (err instanceof HttpError) { | ||
throw err; | ||
} | ||
//checks if mongoose threw and will rethrow with appropriate status code and message | ||
checkMongooseErrors(err); | ||
|
||
throw new HttpError( | ||
HttpStatus.INTERNAL_SERVER_ERROR, | ||
"Education retrieval failed", | ||
{ cause: err }, | ||
); | ||
} | ||
}; | ||
|
||
export const getActivityById = async (user: string, educationId: string) => { | ||
try { | ||
const education = await EducationModel.findOne({ | ||
user: user, | ||
_id: educationId, | ||
}); | ||
return education; | ||
} catch (err: unknown) { | ||
//rethrow any errors as HttpErrors | ||
if (err instanceof HttpError) { | ||
throw err; | ||
} | ||
//checks if mongoose threw and will rethrow with appropriate status code and message | ||
checkMongooseErrors(err); | ||
|
||
throw new HttpError( | ||
HttpStatus.INTERNAL_SERVER_ERROR, | ||
"Education retrieval failed", | ||
{ cause: err }, | ||
); | ||
} | ||
}; | ||
|
||
export const updateEducation = async ( | ||
user: string, | ||
educationId: string, | ||
educationFields: EducationType, | ||
) => { | ||
try { | ||
if (!educationId) { | ||
throw new HttpError( | ||
HttpStatus.BAD_REQUEST, | ||
"Missing education ID for update", | ||
); | ||
} | ||
|
||
if (await checkDuplicateItemName(educationFields.itemName)) { | ||
throw new HttpError(HttpStatus.BAD_REQUEST, "Duplicate item name"); | ||
} | ||
|
||
const updatedActivity = await EducationModel.findOneAndUpdate( | ||
{ _id: educationId, user: user }, // Query to match the document by _id and user | ||
{ $set: educationFields }, // Update operation | ||
{ new: true, runValidators: true }, // Options: return the updated document and run schema validators | ||
); | ||
return updatedActivity; | ||
} catch (err: unknown) { | ||
//rethrow any errors as HttpErrors | ||
if (err instanceof HttpError) { | ||
throw err; | ||
} | ||
//checks if mongoose threw and will rethrow with appropriate status code and message | ||
checkMongooseErrors(err); | ||
|
||
throw new HttpError( | ||
HttpStatus.INTERNAL_SERVER_ERROR, | ||
"Education update failed", | ||
{ cause: err }, | ||
); | ||
} | ||
}; | ||
|
||
export const deleteEducation = async (user: string, educationId: string) => { | ||
try { | ||
const deletedEducation = await EducationModel.findOneAndDelete({ | ||
_id: educationId, | ||
user: user, | ||
}); | ||
if (!deletedEducation) { | ||
throw new HttpError( | ||
HttpStatus.NOT_FOUND, | ||
"Education not found or already deleted", | ||
); | ||
} | ||
return { message: "Education deleted successfully" }; | ||
} catch (err: unknown) { | ||
//rethrow any errors as HttpErrors | ||
if (err instanceof HttpError) { | ||
throw err; | ||
} | ||
//checks if mongoose threw and will rethrow with appropriate status code and message | ||
checkMongooseErrors(err); | ||
|
||
throw new HttpError( | ||
HttpStatus.INTERNAL_SERVER_ERROR, | ||
"Education deletion failed", | ||
{ cause: err }, | ||
); | ||
} | ||
}; |