加入換日新增資料
This commit is contained in:
parent
c6973a3618
commit
493ff96673
@ -1,10 +1,17 @@
|
|||||||
package com.ray650128.pcredive
|
package com.ray650128.pcredive
|
||||||
|
|
||||||
|
import com.ray650128.pcredive.database.model.MemberRecord
|
||||||
|
import com.ray650128.pcredive.database.model.Record
|
||||||
|
import com.ray650128.pcredive.database.service.MemberRecordService
|
||||||
|
import com.ray650128.pcredive.database.service.MemberService
|
||||||
import io.ktor.server.application.*
|
import io.ktor.server.application.*
|
||||||
import com.ray650128.pcredive.plugins.*
|
import com.ray650128.pcredive.plugins.*
|
||||||
|
import java.util.*
|
||||||
|
|
||||||
fun main(args: Array<String>): Unit =
|
fun main(args: Array<String>) {
|
||||||
|
startTimer()
|
||||||
io.ktor.server.netty.EngineMain.main(args)
|
io.ktor.server.netty.EngineMain.main(args)
|
||||||
|
}
|
||||||
|
|
||||||
@Suppress("unused") // application.conf references the main function. This annotation prevents the IDE from marking it as unused.
|
@Suppress("unused") // application.conf references the main function. This annotation prevents the IDE from marking it as unused.
|
||||||
fun Application.module() {
|
fun Application.module() {
|
||||||
@ -13,3 +20,37 @@ fun Application.module() {
|
|||||||
configureMemberRouting()
|
configureMemberRouting()
|
||||||
configureMemberRecordRouting()
|
configureMemberRecordRouting()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun startTimer() {
|
||||||
|
val date = Date()
|
||||||
|
val timer = Timer()
|
||||||
|
timer.schedule(object : TimerTask() {
|
||||||
|
override fun run() {
|
||||||
|
val c = Calendar.getInstance()
|
||||||
|
val hour = c[Calendar.HOUR_OF_DAY]
|
||||||
|
val minute = c[Calendar.MINUTE]
|
||||||
|
val second = c[Calendar.SECOND]
|
||||||
|
val day = c[Calendar.DAY_OF_MONTH]
|
||||||
|
val lastDay = c.getActualMaximum(Calendar.DAY_OF_MONTH)
|
||||||
|
//println("Time: $day, ${String.format("%2d:%2d:%2d", hour, minute, second)}")
|
||||||
|
if ((day in (lastDay - 5)..lastDay) && (hour == 5 && minute == 0 && second == 0)) {
|
||||||
|
val members = MemberService.findAll(false)
|
||||||
|
members.forEach { member ->
|
||||||
|
MemberRecordService.create(
|
||||||
|
MemberRecord(
|
||||||
|
memberId = member._id,
|
||||||
|
record1 = Record(""),
|
||||||
|
record1c = Record(""),
|
||||||
|
record2 = Record(""),
|
||||||
|
record2c = Record(""),
|
||||||
|
record3 = Record(""),
|
||||||
|
record3c = Record(""),
|
||||||
|
createdAt = System.currentTimeMillis(),
|
||||||
|
updatedAt = System.currentTimeMillis()
|
||||||
|
)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, date, 1000L)
|
||||||
|
}
|
||||||
@ -9,12 +9,12 @@ import org.litote.kmongo.newId
|
|||||||
data class MemberRecord(
|
data class MemberRecord(
|
||||||
@Contextual var _id: Id<MemberRecord> = newId(),
|
@Contextual var _id: Id<MemberRecord> = newId(),
|
||||||
@Contextual var memberId: Id<Member>? = null,
|
@Contextual var memberId: Id<Member>? = null,
|
||||||
var record1: Record = Record("未出"),
|
var record1: Record = Record(""),
|
||||||
var record1c: Record = Record("未出"),
|
var record1c: Record = Record(""),
|
||||||
var record2: Record = Record("未出"),
|
var record2: Record = Record(""),
|
||||||
var record2c: Record = Record("未出"),
|
var record2c: Record = Record(""),
|
||||||
var record3: Record = Record("未出"),
|
var record3: Record = Record(""),
|
||||||
var record3c: Record = Record("未出"),
|
var record3c: Record = Record(""),
|
||||||
var createdAt: Long? = null,
|
var createdAt: Long? = null,
|
||||||
var updatedAt: Long? = null
|
var updatedAt: Long? = null
|
||||||
)
|
)
|
||||||
|
|||||||
@ -135,7 +135,7 @@ fun getData(year: Int, month: Int, day: Int): List<RecordData> {
|
|||||||
val records = ArrayList<RecordData>()
|
val records = ArrayList<RecordData>()
|
||||||
val memberList = MemberService.findAll()
|
val memberList = MemberService.findAll()
|
||||||
memberList.forEach { member ->
|
memberList.forEach { member ->
|
||||||
if (member.createAt!! < startTime && !member.leave) {
|
if ((member.createAt!! < startTime || member.createAt!! > endTime) && !member.leave) {
|
||||||
records.add(
|
records.add(
|
||||||
RecordData(member = member, null)
|
RecordData(member = member, null)
|
||||||
)
|
)
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user