Compare commits
	
		
			17 Commits
		
	
	
		
			main
			...
			0002358-en
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| a633d1aac6 | |||
| 3585ec9ad6 | |||
| 5ae17aa8a8 | |||
| dfa518383a | |||
| 3f8ecb0370 | |||
| 71443ff6f3 | |||
| 57597c3d94 | |||
| 28a9ec86af | |||
| ea4edcdcee | |||
| 311d1fbd3b | |||
| dc29e2c6b1 | |||
| e0d64f91d1 | |||
| af2b7cea6d | |||
| 488cab4ac7 | |||
| 8e417f02f2 | |||
| 728eca6dd6 | |||
| e3fc1f73b7 | 
| @ -1,5 +1,5 @@ | |||||||
| plugins { | plugins { | ||||||
|     id("org.gradle.toolchains.foojay-resolver-convention") version "0.5.0" |     id("org.gradle.toolchains.foojay-resolver-convention") version "0.5.0" | ||||||
| } | } | ||||||
| rootProject.name = "Backend_API" | rootProject.name = "Backend_API_DSU" | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,15 +1,19 @@ | |||||||
| package eu.maiora.db | package eu.maiora.db | ||||||
| 
 | 
 | ||||||
| import com.fasterxml.jackson.databind.deser.impl.CreatorCandidate.Param | import eu.maiora.model.* | ||||||
| import eu.maiora.model.Accounts |  | ||||||
| import eu.maiora.model.Parametri |  | ||||||
| import kotlinx.coroutines.Dispatchers | import kotlinx.coroutines.Dispatchers | ||||||
| import org.jetbrains.exposed.dao.IntEntity | import org.jetbrains.exposed.dao.IntEntity | ||||||
| import org.jetbrains.exposed.dao.IntEntityClass | import org.jetbrains.exposed.dao.IntEntityClass | ||||||
|  | import org.jetbrains.exposed.dao.LongEntity | ||||||
|  | import org.jetbrains.exposed.dao.LongEntityClass | ||||||
| import org.jetbrains.exposed.dao.id.EntityID | import org.jetbrains.exposed.dao.id.EntityID | ||||||
| import org.jetbrains.exposed.dao.id.IdTable | import org.jetbrains.exposed.dao.id.IdTable | ||||||
| import org.jetbrains.exposed.sql.Transaction | import org.jetbrains.exposed.sql.Transaction | ||||||
|  | import org.jetbrains.exposed.sql.javatime.datetime | ||||||
| import org.jetbrains.exposed.sql.transactions.experimental.newSuspendedTransaction | import org.jetbrains.exposed.sql.transactions.experimental.newSuspendedTransaction | ||||||
|  | import java.time.format.DateTimeFormatter | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| object AccountsTable : IdTable<Int>("accounts"){ | object AccountsTable : IdTable<Int>("accounts"){ | ||||||
|     override val id = integer("id").entityId() |     override val id = integer("id").entityId() | ||||||
| @ -27,6 +31,43 @@ object ParametriTable : IdTable<Int>("parametri"){ | |||||||
|     override val primaryKey = PrimaryKey(id) |     override val primaryKey = PrimaryKey(id) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | object TessereTable : IdTable<Long>("view_tessere_api"){ | ||||||
|  |     override val id = long("id").entityId() | ||||||
|  |     val idUtente = long("id_utente") | ||||||
|  |     val codiceFiscale = varchar("codice_fiscale", 255) | ||||||
|  |     val numero = varchar("numero", 255) | ||||||
|  |     val saldo = double("saldo") | ||||||
|  |     val punti = integer("punti") | ||||||
|  | 
 | ||||||
|  |     override val primaryKey = PrimaryKey(id) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | object MovimentiTable : IdTable<Long>("view_movimenti_api"){ | ||||||
|  |     override val id = long("id").entityId() | ||||||
|  |     val idTessera = long("id_tessera") | ||||||
|  |     val numero = varchar("numero_tessera", 255) | ||||||
|  |     val operazione = varchar("operazione", 255) | ||||||
|  |     val dataMovimento = datetime("data_movimento") | ||||||
|  |     val transazione = varchar("transazione", 255) | ||||||
|  |     val dispositivo = varchar("dispositivo", 255) | ||||||
|  |     val riferimento= varchar("riferimento", 255) | ||||||
|  |     val saldoPre = double("saldo_pre") | ||||||
|  |     val importo = double("importo") | ||||||
|  |     val saldoPost = double("saldo_post") | ||||||
|  |     val puntiPre = integer("punti_pre") | ||||||
|  |     val punti = integer("punti") | ||||||
|  |     val puntiPost = integer("punti_post") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | object ComposizioniTable : IdTable<Long>("view_composizioni"){ | ||||||
|  |     override val id = long("id").entityId() | ||||||
|  |     val idVassoio = long("id_vassoio") | ||||||
|  |     val vassoio = varchar("vassoio", 255) | ||||||
|  |     val idCategoria = long("id_categoria") | ||||||
|  |     val categoria = varchar("categoria", 255) | ||||||
|  |     val quantita = integer("quantita") | ||||||
|  | } | ||||||
|  | 
 | ||||||
| class AccountsDAO(id: EntityID<Int>) :IntEntity(id) { | class AccountsDAO(id: EntityID<Int>) :IntEntity(id) { | ||||||
|     companion object : IntEntityClass<AccountsDAO>(AccountsTable) |     companion object : IntEntityClass<AccountsDAO>(AccountsTable) | ||||||
| 
 | 
 | ||||||
| @ -41,6 +82,44 @@ class ParametriDAO(id: EntityID<Int>) :IntEntity(id) { | |||||||
|     var valore by ParametriTable.valore |     var valore by ParametriTable.valore | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | class TessereDao(id: EntityID<Long>) :LongEntity(id) { | ||||||
|  |     companion object : LongEntityClass<TessereDao>(TessereTable) | ||||||
|  | 
 | ||||||
|  |     var idUtente by TessereTable.idUtente | ||||||
|  |     var codiceFiscale by TessereTable.codiceFiscale | ||||||
|  |     var numero by TessereTable.numero | ||||||
|  |     var saldo by TessereTable.saldo | ||||||
|  |     var punti by TessereTable.punti | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | class MovimentiDao(id: EntityID<Long>) :LongEntity(id) { | ||||||
|  |     companion object : LongEntityClass<MovimentiDao>(MovimentiTable) | ||||||
|  | 
 | ||||||
|  |     var idTessera by MovimentiTable.idTessera | ||||||
|  |     var numero by MovimentiTable.numero | ||||||
|  |     var operazione by MovimentiTable.operazione | ||||||
|  |     var dataMovimento by MovimentiTable.dataMovimento | ||||||
|  |     var transazione by MovimentiTable.transazione | ||||||
|  |     var dispositivo by MovimentiTable.dispositivo | ||||||
|  |     var riferimento by MovimentiTable.riferimento | ||||||
|  |     var saldoPre by MovimentiTable.saldoPre | ||||||
|  |     var importo by MovimentiTable.importo | ||||||
|  |     var saldoPost by MovimentiTable.saldoPost | ||||||
|  |     var puntiPre by MovimentiTable.puntiPre | ||||||
|  |     var punti by MovimentiTable.punti | ||||||
|  |     var puntiPost by MovimentiTable.puntiPost | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | class ComposizioniDao(id: EntityID<Long>) :LongEntity(id){ | ||||||
|  |     companion object : LongEntityClass<ComposizioniDao>(ComposizioniTable) | ||||||
|  | 
 | ||||||
|  |     var idVassoio by ComposizioniTable.idVassoio | ||||||
|  |     var vassoio by ComposizioniTable.vassoio | ||||||
|  |     var idCategoria by ComposizioniTable.idCategoria | ||||||
|  |     var categoria by ComposizioniTable.categoria | ||||||
|  |     var quantita by ComposizioniTable.quantita | ||||||
|  | } | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| fun accountsDaoToModel(dao: AccountsDAO) = Accounts( | fun accountsDaoToModel(dao: AccountsDAO) = Accounts( | ||||||
|     dao.id.value, |     dao.id.value, | ||||||
| @ -54,6 +133,49 @@ fun parametriDaoToModel(dao: ParametriDAO) = Parametri( | |||||||
|     dao.valore |     dao.valore | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | fun tessereDaoToModel(dao: TessereDao) = Tessere( | ||||||
|  |     dao.id.value, | ||||||
|  |     dao.idUtente, | ||||||
|  |     dao.codiceFiscale, | ||||||
|  |     dao.numero, | ||||||
|  |     dao.saldo, | ||||||
|  |     dao.punti | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | fun movimentiDaoToModel(dao: MovimentiDao) :Movimenti{ | ||||||
|  |     val formatter = DateTimeFormatter.ofPattern("ddMMyyyy HH:mm") | ||||||
|  |     val formattedDate = dao.dataMovimento.format(formatter) | ||||||
|  | 
 | ||||||
|  |     return Movimenti( | ||||||
|  |         dao.id.value, | ||||||
|  |         dao.idTessera, | ||||||
|  |         dao.numero, | ||||||
|  |         dao.operazione, | ||||||
|  |         formattedDate, | ||||||
|  |         dao.transazione, | ||||||
|  |         dao.dispositivo, | ||||||
|  |         dao.riferimento, | ||||||
|  |         dao.saldoPre, | ||||||
|  |         dao.importo, | ||||||
|  |         dao.saldoPost, | ||||||
|  |         dao.puntiPre, | ||||||
|  |         dao.punti, | ||||||
|  |         dao.puntiPost | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | fun composizioniDaoToModel(dao: ComposizioniDao) =Composizioni( | ||||||
|  |     dao.id.value, | ||||||
|  |     dao.idVassoio, | ||||||
|  |     dao.vassoio, | ||||||
|  |     dao.idCategoria, | ||||||
|  |     dao.categoria, | ||||||
|  |     dao.quantita | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| suspend fun <T> suspendTransaction(block: Transaction.() -> T): T = | suspend fun <T> suspendTransaction(block: Transaction.() -> T): T = | ||||||
|     newSuspendedTransaction(Dispatchers.IO, statement = block) |     newSuspendedTransaction(Dispatchers.IO, statement = block) | ||||||
							
								
								
									
										13
									
								
								src/main/kotlin/eu/maiora/model/Composizioni.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								src/main/kotlin/eu/maiora/model/Composizioni.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | import kotlinx.serialization.Serializable | ||||||
|  | 
 | ||||||
|  | @Serializable | ||||||
|  | data class Composizioni( | ||||||
|  |     val id: Long, | ||||||
|  |     val idVassoio : Long, | ||||||
|  |     val vassoio : String, | ||||||
|  |     val idCategoria : Long, | ||||||
|  |     val categoria : String, | ||||||
|  |     val quantita : Int | ||||||
|  | ) | ||||||
| @ -0,0 +1,5 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | interface ComposizioniRepository { | ||||||
|  |     suspend fun listaComposizioni(): List<Composizioni> | ||||||
|  | } | ||||||
| @ -0,0 +1,14 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | import eu.maiora.db.* | ||||||
|  | import org.jetbrains.exposed.sql.SortOrder | ||||||
|  | 
 | ||||||
|  | class ComposizioniRepositoryImpl : ComposizioniRepository { | ||||||
|  |     override suspend fun listaComposizioni(): List<Composizioni> = suspendTransaction { | ||||||
|  |         // Cerca la lista di composizioni | ||||||
|  |         ComposizioniDao.all() | ||||||
|  |             .toList() | ||||||
|  |             .map { composizioniDaoToModel(it) } // Converte il DAO in un oggetto Composizioni | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										22
									
								
								src/main/kotlin/eu/maiora/model/Movimenti.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								src/main/kotlin/eu/maiora/model/Movimenti.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | import kotlinx.serialization.Serializable | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | @Serializable | ||||||
|  | data class Movimenti( | ||||||
|  |     val id: Long, | ||||||
|  |     val idTessera: Long, | ||||||
|  |     val numero: String, | ||||||
|  |     val operazione: String, | ||||||
|  |     val dataMovimento: String, | ||||||
|  |     val transazione: String, | ||||||
|  |     val dispositivo: String, | ||||||
|  |     val riferimento: String, | ||||||
|  |     val saldoPre: Double, | ||||||
|  |     val importo: Double, | ||||||
|  |     val saldoPost: Double, | ||||||
|  |     val puntiPre: Int, | ||||||
|  |     val punti: Int, | ||||||
|  |     val puntiPost: Int | ||||||
|  | ) | ||||||
							
								
								
									
										5
									
								
								src/main/kotlin/eu/maiora/model/MovimentiRepository.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/main/kotlin/eu/maiora/model/MovimentiRepository.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | interface MovimentiRepository { | ||||||
|  |     suspend fun movimentiByIdTessera(idTessera : Long): List<Movimenti>? | ||||||
|  | } | ||||||
							
								
								
									
										15
									
								
								src/main/kotlin/eu/maiora/model/MovimentiRepositoryImpl.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/main/kotlin/eu/maiora/model/MovimentiRepositoryImpl.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,15 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | import eu.maiora.db.* | ||||||
|  | import org.jetbrains.exposed.sql.SortOrder | ||||||
|  | 
 | ||||||
|  | class MovimentiRepositoryImpl : MovimentiRepository { | ||||||
|  |     override suspend fun movimentiByIdTessera(idTessera : Long): List<Movimenti> = suspendTransaction { | ||||||
|  |         // Cerca la lista di movimenti | ||||||
|  |         MovimentiDao.find { MovimentiTable.idTessera eq idTessera } | ||||||
|  |             .orderBy(MovimentiTable.dataMovimento to SortOrder.DESC) | ||||||
|  |             .toList() // Restituisce la lista dei movimenti | ||||||
|  |             .map { movimentiDaoToModel(it) } // Converte il DAO in un oggetto Movimenti | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										13
									
								
								src/main/kotlin/eu/maiora/model/Tessere.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								src/main/kotlin/eu/maiora/model/Tessere.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | import kotlinx.serialization.Serializable | ||||||
|  | 
 | ||||||
|  | @Serializable | ||||||
|  | data class Tessere( | ||||||
|  |     val id: Long, | ||||||
|  |     val idUtente : Long, | ||||||
|  |     val codiceFiscale : String, | ||||||
|  |     val numero : String, | ||||||
|  |     val saldo : Double, | ||||||
|  |     val punti : Int | ||||||
|  | ) | ||||||
							
								
								
									
										5
									
								
								src/main/kotlin/eu/maiora/model/TessereRepository.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/main/kotlin/eu/maiora/model/TessereRepository.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | interface TessereRepository { | ||||||
|  |     suspend fun tesseraByCodiceFiscale(cf : String): Tessere? | ||||||
|  | } | ||||||
							
								
								
									
										13
									
								
								src/main/kotlin/eu/maiora/model/TessereRepositoryImpl.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								src/main/kotlin/eu/maiora/model/TessereRepositoryImpl.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | import eu.maiora.db.* | ||||||
|  | 
 | ||||||
|  | class TessereRepositoryImpl : TessereRepository { | ||||||
|  |     override suspend fun tesseraByCodiceFiscale(cf: String): Tessere? = suspendTransaction { | ||||||
|  |         // Cerca tessere in base al codice fiscale | ||||||
|  |         TessereDao.find { TessereTable.codiceFiscale eq cf } | ||||||
|  |             .singleOrNull() // Restituisce un singolo risultato o null se non trovato | ||||||
|  |             ?.let { tessereDaoToModel(it) } // Converte il DAO in un oggetto Tessere | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										12
									
								
								src/main/kotlin/eu/maiora/model/ValorePasti.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/main/kotlin/eu/maiora/model/ValorePasti.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | import kotlinx.serialization.Serializable | ||||||
|  | 
 | ||||||
|  | @Serializable | ||||||
|  | data class ValorePasti( | ||||||
|  |     val idTessera : Long, | ||||||
|  |     val idVassoio : Long, | ||||||
|  |     val data : String, | ||||||
|  |     val prezzo : Double, | ||||||
|  |     val punti : Int | ||||||
|  | ) | ||||||
							
								
								
									
										5
									
								
								src/main/kotlin/eu/maiora/model/ValorePastiRepository.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/main/kotlin/eu/maiora/model/ValorePastiRepository.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | interface ValorePastiRepository { | ||||||
|  |     suspend fun valorePastoByTessVassData(idTessera : String, idVassoio : String, data : String): String | ||||||
|  | } | ||||||
							
								
								
									
										31
									
								
								src/main/kotlin/eu/maiora/model/ValorePastiRepositoryImpl.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								src/main/kotlin/eu/maiora/model/ValorePastiRepositoryImpl.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,31 @@ | |||||||
|  | package eu.maiora.model | ||||||
|  | 
 | ||||||
|  | import eu.maiora.db.* | ||||||
|  | import org.jetbrains.exposed.sql.LongColumnType | ||||||
|  | import org.jetbrains.exposed.sql.SqlExpressionBuilder | ||||||
|  | import org.jetbrains.exposed.sql.VarCharColumnType | ||||||
|  | 
 | ||||||
|  | class ValorePastiRepositoryImpl : ValorePastiRepository { | ||||||
|  |     override suspend fun  valorePastoByTessVassData(idTessera : String, idVassoio : String, data : String): String = suspendTransaction { | ||||||
|  |         // Cerca valore del pasto e punti in base alla tessera, al vassoio e al giorno | ||||||
|  | 
 | ||||||
|  |         val result = exec("SELECT SIR.trova_tariffa(?, ?, ?) FROM dual", | ||||||
|  |             listOf( | ||||||
|  |                 Pair(LongColumnType(), idTessera), | ||||||
|  |                 Pair(LongColumnType(), idVassoio), | ||||||
|  |                 Pair(VarCharColumnType(), data) | ||||||
|  |             )){ rs -> | ||||||
|  |             var resultString: String? = null | ||||||
|  |             // Processiamo il ResultSet restituito dalla query | ||||||
|  |             if (rs.next()) { | ||||||
|  |                 resultString = rs.getString(1)  // Leggiamo il primo risultato | ||||||
|  |             } | ||||||
|  |             resultString | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         result ?: "Nessun risultato" | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,7 +1,11 @@ | |||||||
| package eu.maiora.plugins | package eu.maiora.plugins | ||||||
| 
 | 
 | ||||||
| import eu.maiora.model.AccountsRepositoryImpl | import eu.maiora.model.* | ||||||
| import eu.maiora.routes.auth | import eu.maiora.routes.auth | ||||||
|  | import eu.maiora.routes.composizioni | ||||||
|  | import eu.maiora.routes.movimenti | ||||||
|  | import eu.maiora.routes.tessere | ||||||
|  | import eu.maiora.routes.valorePasti | ||||||
| import io.ktor.server.application.* | import io.ktor.server.application.* | ||||||
| import io.ktor.server.response.* | import io.ktor.server.response.* | ||||||
| import io.ktor.server.routing.* | import io.ktor.server.routing.* | ||||||
| @ -13,5 +17,9 @@ fun Application.configureRouting() { | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         auth(AccountsRepositoryImpl()) |         auth(AccountsRepositoryImpl()) | ||||||
|  |         tessere(TessereRepositoryImpl()) | ||||||
|  |         movimenti(MovimentiRepositoryImpl()) | ||||||
|  |         composizioni(ComposizioniRepositoryImpl()) | ||||||
|  |         valorePasti(ValorePastiRepositoryImpl()) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										20
									
								
								src/main/kotlin/eu/maiora/routes/Composizioni.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								src/main/kotlin/eu/maiora/routes/Composizioni.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,20 @@ | |||||||
|  | package eu.maiora.routes | ||||||
|  | 
 | ||||||
|  | import eu.maiora.model.ComposizioniRepositoryImpl | ||||||
|  | import io.ktor.server.application.* | ||||||
|  | import io.ktor.server.auth.* | ||||||
|  | import io.ktor.server.response.* | ||||||
|  | import io.ktor.server.routing.* | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | fun Route.composizioni(composizioniRepository: ComposizioniRepositoryImpl){ | ||||||
|  |     route("/api/composizioni"){ | ||||||
|  |         authenticate("auth-jwt") { | ||||||
|  |             get(){ | ||||||
|  |                 val listaComposizioni = composizioniRepository.listaComposizioni() | ||||||
|  |                 call.respond(listaComposizioni) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										36
									
								
								src/main/kotlin/eu/maiora/routes/Movimenti.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								src/main/kotlin/eu/maiora/routes/Movimenti.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,36 @@ | |||||||
|  | package eu.maiora.routes | ||||||
|  | 
 | ||||||
|  | import eu.maiora.model.MovimentiRepositoryImpl | ||||||
|  | import io.ktor.http.* | ||||||
|  | import io.ktor.server.application.* | ||||||
|  | import io.ktor.server.auth.* | ||||||
|  | import io.ktor.server.response.* | ||||||
|  | import io.ktor.server.routing.* | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | fun Route.movimenti(movimentiRepository: MovimentiRepositoryImpl){ | ||||||
|  |     route("/api/movimenti"){ | ||||||
|  |         authenticate("auth-jwt") { | ||||||
|  |             get("{idTessera}"){ | ||||||
|  |                 // Ottieni l'id della tessera dal percorso | ||||||
|  |                 val idTessera = call.parameters["idTessera"] | ||||||
|  | 
 | ||||||
|  |                 if (idTessera == null) { | ||||||
|  |                     call.respondText("ID tessera non valido", status = HttpStatusCode.BadRequest) | ||||||
|  |                     return@get | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 // Cerca la tessera per codice fiscale | ||||||
|  |                 val listaMovimenti = movimentiRepository.movimentiByIdTessera(idTessera.toLong()) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |                 if (listaMovimenti != null) { | ||||||
|  |                     call.respond(listaMovimenti) | ||||||
|  |                 } else { | ||||||
|  |                     call.respondText("Movimenti non trovati", status = HttpStatusCode.NotFound) | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										35
									
								
								src/main/kotlin/eu/maiora/routes/Tessere.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								src/main/kotlin/eu/maiora/routes/Tessere.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,35 @@ | |||||||
|  | package eu.maiora.routes | ||||||
|  | 
 | ||||||
|  | import eu.maiora.model.TessereRepositoryImpl | ||||||
|  | import io.ktor.http.* | ||||||
|  | import io.ktor.server.application.* | ||||||
|  | import io.ktor.server.auth.* | ||||||
|  | import io.ktor.server.response.* | ||||||
|  | import io.ktor.server.routing.* | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | fun Route.tessere(tessereRepository: TessereRepositoryImpl){ | ||||||
|  |     route("/api/tessere"){ | ||||||
|  |         authenticate("auth-jwt") { | ||||||
|  |             get("{cf}"){ | ||||||
|  |                 // Ottieni il codice fiscale dal percorso | ||||||
|  |                 val cf = call.parameters["cf"] | ||||||
|  | 
 | ||||||
|  |                 if (cf == null) { | ||||||
|  |                     call.respondText("Codice fiscale non valido", status = HttpStatusCode.BadRequest) | ||||||
|  |                     return@get | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 // Cerca la tessera per codice fiscale | ||||||
|  |                 val tessera = tessereRepository.tesseraByCodiceFiscale(cf) | ||||||
|  | 
 | ||||||
|  |                 if (tessera != null) { | ||||||
|  |                     call.respond(tessera) | ||||||
|  |                 } else { | ||||||
|  |                     call.respondText("Tessera non trovata", status = HttpStatusCode.NotFound) | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										50
									
								
								src/main/kotlin/eu/maiora/routes/ValorePasti.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								src/main/kotlin/eu/maiora/routes/ValorePasti.kt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,50 @@ | |||||||
|  | package eu.maiora.routes | ||||||
|  | 
 | ||||||
|  | import eu.maiora.model.TessereRepositoryImpl | ||||||
|  | import eu.maiora.model.ValorePasti | ||||||
|  | import eu.maiora.model.ValorePastiRepository | ||||||
|  | import io.ktor.http.* | ||||||
|  | import io.ktor.server.application.* | ||||||
|  | import io.ktor.server.auth.* | ||||||
|  | import io.ktor.server.response.* | ||||||
|  | import io.ktor.server.routing.* | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | fun Route.valorePasti(valorePastiRepository: ValorePastiRepository){ | ||||||
|  |     route("/api/valorePasti"){ | ||||||
|  |         authenticate("auth-jwt") { | ||||||
|  |             get(){ | ||||||
|  |                 // Ottieni i parametri dal percorso | ||||||
|  |                 val idTessera = call.parameters["idTessera"] | ||||||
|  |                 val idVassoio = call.parameters["idVassoio"] | ||||||
|  |                 val data = call.parameters["data"] | ||||||
|  | 
 | ||||||
|  |                 if (idTessera == null) { | ||||||
|  |                     call.respondText("ID tessera non valido", status = HttpStatusCode.BadRequest) | ||||||
|  |                     return@get | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 if (idVassoio == null) { | ||||||
|  |                     call.respondText("ID vassoio non valido", status = HttpStatusCode.BadRequest) | ||||||
|  |                     return@get | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 if (data == null) { | ||||||
|  |                     call.respondText("data non valida", status = HttpStatusCode.BadRequest) | ||||||
|  |                     return@get | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 // Cerca la tessera per codice fiscale | ||||||
|  |                 val valorePasto = valorePastiRepository.valorePastoByTessVassData(idTessera, idVassoio, data) | ||||||
|  | 
 | ||||||
|  |                 val prezzo = valorePasto.split("#").get(0) | ||||||
|  |                 val punti = valorePasto.split("#").get(1) | ||||||
|  |                 call.respond( ValorePasti(idTessera.toLong(), | ||||||
|  |                                           idVassoio.toLong(), data, | ||||||
|  |                                           prezzo.replace(',', '.').toDouble(), | ||||||
|  |                                           punti.toInt())) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user