forked from PluralFlux/PluralFlux
* adding typescript packages for typeORM * add typeORM initial files * updating package scripts * updating compose.yaml to have an exposed port for the postgres * modifying setup for typeORM * update database stuff and and package.json to help generate migrations * made models and migrations in typeORM * delete unneeded database.js * made database pattern ignored by jest * remove sequelize * separate member repo from member helper * not sure why i made everything numbers in the model but it's fixed now * edited package.json script * remove unused index.ts * adjusted files to reference repository correctly and appdatasource * made appdatasource export as named * removed start-db script * added init to appdatasource in bot.js * migrations finally! * new migration matching model names I want * updating tests * removing testpathignore patterns since it seems to be unecessary? * adjusting migrations to match current schema * removed reference to secrets file * delete old migration * Revert "delete old migration" This reverts commit db1efa39a7a80d8976878856250ccaac6a753ab2. * Revert "adjusting migrations to match current schema" This reverts commit ef89a83f6a2ef0643d6ace0a3fcf9c40f4bc6dd6. * just deleted system creation since it's got nothing in it anyway * renamed memberRepository to memberRepo for consistency * added await back to parseMemberCommand call to memberArgumentHandler * changed call to memberHelper.getMembersByAuthor to memberRepo * renamed repo updateMemberValue to updateMemberField * removed throw references in repo docstrings * remove unneeded subscriber directory ref * changed createdAt and updatedAt columns to be auto-generated made member table have timezone * changed casing of isInitialized in mock for bot.js * removed % from ILike query so that it doesn't match substrings/wildcard * renamed some stray updateMemberValue in mocks -> updateMemberField --------- Co-authored-by: Aster Fialla <asterfialla@gmail.com>
81 lines
2.5 KiB
JavaScript
81 lines
2.5 KiB
JavaScript
const Member = require("../../database/entity/Member");
|
|
const { AppDataSource } = require("../../database/data-source");
|
|
const {ILike} = require("typeorm");
|
|
const members = AppDataSource.getRepository(Member.Member)
|
|
|
|
const memberRepo = {};
|
|
/**
|
|
* Gets a member based on the author and proxy tag.
|
|
*
|
|
* @async
|
|
* @param {string} authorId - The author of the message.
|
|
* @param {string} memberName - The member's name.
|
|
* @returns {Promise<Member | null>} The member object or null if not found.
|
|
*/
|
|
memberRepo.getMemberByName = async function (authorId, memberName) {
|
|
return await members.findOne({where: {userid: authorId, name: ILike(memberName)}});
|
|
}
|
|
|
|
/**
|
|
* Gets all members belonging to the author.
|
|
*
|
|
* @async
|
|
* @param {string} authorId - The author of the message
|
|
* @returns {Promise<Member[]>} The member object array.
|
|
*/
|
|
memberRepo.getMembersByAuthor = async function (authorId) {
|
|
return await members.findBy({userid: authorId});
|
|
}
|
|
|
|
/**
|
|
* Removes a member.
|
|
*
|
|
* @async
|
|
* @param {string} authorId - The author of the message
|
|
* @param {string} memberName - The name of the member to remove
|
|
* @returns {Promise<number>} Number of results removed.
|
|
*/
|
|
memberRepo.removeMember = async function (authorId, memberName) {
|
|
const deleted = await members.delete({
|
|
where: {
|
|
name: ILike(memberName),
|
|
userid: authorId
|
|
}
|
|
})
|
|
return deleted.affected;
|
|
}
|
|
|
|
/**
|
|
* Adds a member with full details.
|
|
*
|
|
* @async
|
|
* @param {{name: string, userid: string, displayname: (string|null), proxy: (string|null), propic: (string|null)}} createObj - Object with parameters in it
|
|
* @returns {Promise<Member>} A successful inserted object.
|
|
*/
|
|
memberRepo.createMember = async function (createObj) {
|
|
return members.insert({
|
|
name: createObj.name, userid: createObj.authorId, displayname: createObj.displayName, proxy: createObj.proxy, propic: createObj.propic
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Updates one fields for a member in the database.
|
|
*
|
|
* @async
|
|
* @param {string} authorId - The author of the message
|
|
* @param {string} memberName - The member to update
|
|
* @param {string} columnName - The column name to update.
|
|
* @param {string} value - The value to update to.
|
|
* @returns {Promise<number>} A successful update.
|
|
*/
|
|
memberRepo.updateMemberField = async function (authorId, memberName, columnName, value) {
|
|
const updated = await members.update({[columnName]: value}, {
|
|
where: {
|
|
name: ILike(memberName),
|
|
userid: authorId
|
|
}
|
|
})
|
|
return updated.affected;
|
|
}
|
|
|
|
module.exports.memberRepo = memberRepo; |