feat(server): partial implementation of BuildLog API filter

pull/206/head
Jef Roosens 2022-05-19 22:43:38 +02:00 committed by Chewing_Bever
parent 596da100b6
commit 31e903ebeb
Signed by: Jef Roosens
GPG Key ID: B75D4F293C7052DB
3 changed files with 47 additions and 4 deletions

View File

@ -10,6 +10,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Added
* Database migrations
* Query parameters for GitRepo API to filter responses
* Respective CLI flags for new GitRepo API parameters
### Changed
* Refactor of main types into `models` module
## [0.3.0-alpha.2](https://git.rustybever.be/vieter/vieter/src/tag/0.3.0-alpha.2)

View File

@ -1,13 +1,37 @@
module db
import models { BuildLog }
import models { BuildLog, BuildLogFilter }
import time
// get_build_logs returns all BuildLog's in the database.
pub fn (db &VieterDb) get_build_logs() []BuildLog {
res := sql db.conn {
select from BuildLog order by id
pub fn (db &VieterDb) get_build_logs(filter BuildLogFilter) []BuildLog {
mut where_parts := []string{}
if filter.repo != 0 {
where_parts << 'repo_id == $filter.repo'
}
if filter.before != time.Time{} {
where_parts << 'start_time < $filter.before.unix_time()'
}
if filter.after != time.Time{} {
where_parts << 'start_time < $filter.after.unix_time()'
}
where_str := if where_parts.len > 0 {
' where ' + where_parts.map('($it)').join(' and ')
} else {
''
}
query := 'select from BuildLog' + where_str
res := db.conn.exec(query)
/* res := sql db.conn { */
/* select from BuildLog where filter.repo == 0 || repo_id == filter.repo order by id */
/* } */
return res
}

View File

@ -26,3 +26,16 @@ pub fn (bl &BuildLog) str() string {
return str
}
[params]
pub struct BuildLogFilter {
pub mut:
limit u64 = 25
offset u64
repo int
before time.Time
after time.Time
exit_codes_whitelist []u8
exit_codes_blacklist []u8
arch string
}