Spaces:
Running
Running
Commit
·
a07d469
1
Parent(s):
b944c8a
DB mapping issue + new endpoint for random quote
Browse files- DbContext/QuoteDbContext.cs +4 -0
- Program.cs +15 -0
DbContext/QuoteDbContext.cs
CHANGED
|
@@ -2,6 +2,7 @@ using Microsoft.EntityFrameworkCore;
|
|
| 2 |
using System;
|
| 3 |
using System.Collections.Generic;
|
| 4 |
using System.ComponentModel.DataAnnotations;
|
|
|
|
| 5 |
|
| 6 |
public class QuoteDbContext : DbContext
|
| 7 |
{
|
|
@@ -50,6 +51,7 @@ public class Quote
|
|
| 50 |
|
| 51 |
[Required]
|
| 52 |
[MaxLength(1000)]
|
|
|
|
| 53 |
public string QuoteText { get; set; } // Indexed and unique column
|
| 54 |
|
| 55 |
[MaxLength(255)]
|
|
@@ -71,7 +73,9 @@ public class Quote
|
|
| 71 |
public string? Language { get; set; } // Nullable column
|
| 72 |
|
| 73 |
[MaxLength(50)]
|
|
|
|
| 74 |
public string? OriginalLanguage { get; set; } // Nullable column
|
| 75 |
|
|
|
|
| 76 |
public DateTime DateCreated { get; set; } = DateTime.Now; // Default to current datetime
|
| 77 |
}
|
|
|
|
| 2 |
using System;
|
| 3 |
using System.Collections.Generic;
|
| 4 |
using System.ComponentModel.DataAnnotations;
|
| 5 |
+
using System.ComponentModel.DataAnnotations.Schema;
|
| 6 |
|
| 7 |
public class QuoteDbContext : DbContext
|
| 8 |
{
|
|
|
|
| 51 |
|
| 52 |
[Required]
|
| 53 |
[MaxLength(1000)]
|
| 54 |
+
[Column("quote")]
|
| 55 |
public string QuoteText { get; set; } // Indexed and unique column
|
| 56 |
|
| 57 |
[MaxLength(255)]
|
|
|
|
| 73 |
public string? Language { get; set; } // Nullable column
|
| 74 |
|
| 75 |
[MaxLength(50)]
|
| 76 |
+
[Column("original_language")]
|
| 77 |
public string? OriginalLanguage { get; set; } // Nullable column
|
| 78 |
|
| 79 |
+
[Column("created_at")]
|
| 80 |
public DateTime DateCreated { get; set; } = DateTime.Now; // Default to current datetime
|
| 81 |
}
|
Program.cs
CHANGED
|
@@ -77,6 +77,21 @@ app.MapDelete("/quotes/{id}", async (int id, QuoteDbContext db) =>
|
|
| 77 |
return Results.NoContent();
|
| 78 |
});
|
| 79 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 80 |
// Search quotes by author, categories, book, or quoteText with pagination
|
| 81 |
app.MapGet("/quotes/search", async (string search, QuoteDbContext db, int pageNumber = 1, int pageSize = 10) =>
|
| 82 |
{
|
|
|
|
| 77 |
return Results.NoContent();
|
| 78 |
});
|
| 79 |
|
| 80 |
+
// Random quote endpoint
|
| 81 |
+
app.MapGet("/quotes/random", async (QuoteDbContext db) =>
|
| 82 |
+
{
|
| 83 |
+
var quoteCount = await db.Quotes.CountAsync();
|
| 84 |
+
if (quoteCount == 0)
|
| 85 |
+
return Results.NotFound("No quotes available.");
|
| 86 |
+
|
| 87 |
+
var random = new Random();
|
| 88 |
+
var randomIndex = random.Next(quoteCount);
|
| 89 |
+
|
| 90 |
+
var randomQuote = await db.Quotes.Skip(randomIndex).Take(1).FirstOrDefaultAsync();
|
| 91 |
+
|
| 92 |
+
return randomQuote != null ? Results.Ok(randomQuote) : Results.NotFound("No quote found.");
|
| 93 |
+
});
|
| 94 |
+
|
| 95 |
// Search quotes by author, categories, book, or quoteText with pagination
|
| 96 |
app.MapGet("/quotes/search", async (string search, QuoteDbContext db, int pageNumber = 1, int pageSize = 10) =>
|
| 97 |
{
|