Toggle navigation
Toggle navigation
This project
Loading...
Sign in
송용우
/
oss-Jaksimsamil
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Pipelines
Graphs
Issues
0
Merge Requests
0
Wiki
Snippets
Network
Create a new issue
Builds
Commits
Issue Boards
Authored by
송용우
2020-08-25 16:35:59 +0900
Browse Files
Options
Browse Files
Download
Plain Diff
Committed by
GitHub
2020-08-25 16:35:59 +0900
Commit
e2fcb1ac3411c348d541096a4ffbc433943806fd
e2fcb1ac
2 parents
42919eb6
d7addc74
Merge pull request #15 from FacerAin/feature/database
Feature/database
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
60 additions
and
2 deletions
jaksimsamil-server/src/models/group.js
jaksimsamil-server/src/models/participation.js
jaksimsamil-server/src/models/problem.js
jaksimsamil-server/src/models/session.js
jaksimsamil-server/src/models/user.js
jaksimsamil-server/src/models/group.js
View file @
e2fcb1a
...
...
@@ -8,5 +8,18 @@ const GroupSchema = new Schema({
collection
:
'group'
});
GroupSchema
.
methods
.
addGroupMemeber
=
function
(
user
){
this
.
members
.
push
(
user
.
_id
);
return
this
.
save
();
}
GroupSchema
.
methods
.
getMembers
=
function
(){
return
this
.
members
;
}
GroupSchema
.
methods
.
serialize
=
function
(){
return
this
.
toJSON
();
}
const
Group
=
mongoose
.
model
(
'Group'
,
GroupSchema
);
module
.
exports
=
Group
;
\ No newline at end of file
...
...
jaksimsamil-server/src/models/participation.js
View file @
e2fcb1a
...
...
@@ -2,12 +2,32 @@ const mongoose = require("mongoose");
const
{
Schema
}
=
mongoose
;
const
SelectedProblemSchema
=
new
Schema
({
problemNum
:
{
type
:
Number
,
required
:
true
},
isSolved
:
{
type
:
Boolean
,
default
:
false
},
},{
_id
:
false
});
const
ParticipationSchema
=
new
Schema
({
sessionId
:
{
type
:
Schema
.
Types
.
ObjectId
,
ref
:
'Session'
},
groupId
:
{
type
:
Schema
.
Types
.
ObjectId
,
ref
:
'Group'
}
groupId
:
{
type
:
Schema
.
Types
.
ObjectId
,
ref
:
'Group'
},
problems
:
[{
type
:
SelectedProblemSchema
}]
},{
collection
:
'particiaption'
});
ParticipationSchema
.
statics
.
findBySessionId
=
function
(
session
){
return
this
.
find
({
sessionId
:
session
.
_id
});
}
ParticipationSchema
.
statics
.
findByGroupId
=
function
(
group
){
return
this
.
find
({
groupId
:
group
.
_id
});
}
ParticipationSchema
.
methods
.
addProblem
=
function
(
problem
){
this
.
problems
.
push
({
problemNum
:
problem
.
problemNum
,
isSolved
:
problem
.
isSolved
});
}
const
Participation
=
mongoose
.
model
(
'Participation'
,
ParticipationSchema
);
module
.
exports
=
Participation
;
\ No newline at end of file
...
...
jaksimsamil-server/src/models/problem.js
View file @
e2fcb1a
...
...
@@ -9,7 +9,7 @@ const ProblemSchema=new Schema({
sumbitNum
:
{
type
:
Number
,
required
:
true
},
correctNum
:
{
type
:
Number
,
required
:
true
},
count
:
{
type
:
Number
},
category
:
{
type
:[
String
]}
category
:
[{
type
:
String
}],
},{
collection
:
'problem'
});
...
...
jaksimsamil-server/src/models/session.js
View file @
e2fcb1a
...
...
@@ -11,5 +11,25 @@ const SessionSchema = new Schema({
collection
:
'session'
});
SessionSchema
.
statics
.
findByChallengeId
=
function
(
challenge
){
return
this
.
find
({
challengeId
:
challenge
.
_id
});
}
SessionSchema
.
methods
.
getSessionStartDate
=
function
(){
return
this
.
sessionStartDate
;
}
SessionSchema
.
methods
.
getSessionEndDate
=
function
(){
return
this
.
sessionEndDate
;
}
SessionSchema
.
methods
.
getIsOpen
=
function
(){
return
this
.
isOpen
;
}
SessionSchema
.
methods
.
serialize
=
function
(){
return
this
.
toJSON
();
}
const
Session
=
mongoose
.
model
(
'Session'
,
SessionSchema
);
module
.
exports
=
Session
;
\ No newline at end of file
...
...
jaksimsamil-server/src/models/user.js
View file @
e2fcb1a
...
...
@@ -21,6 +21,11 @@ UserSchema.statics.findByUsername = function (username) {
return
this
.
findOne
({
username
});
};
UserSchema
.
methods
.
addFriend
=
function
(
friend
){
this
.
friendList
.
push
(
friend
.
_id
);
return
this
.
save
();
}
UserSchema
.
methods
.
setPassword
=
async
function
(
password
)
{
const
hash
=
await
bcrypt
.
hash
(
password
,
10
);
this
.
hashedPassword
=
hash
;
...
...
Please
register
or
login
to post a comment