diff options
| author | Syndamia <kamen.d.mladenov@protonmail.com> | 2021-05-06 18:18:47 +0300 |
|---|---|---|
| committer | Syndamia <kamen.d.mladenov@protonmail.com> | 2021-05-06 18:18:47 +0300 |
| commit | 6fedb4158836e6bf8d0e6190bc8fd36f188ac60d (patch) | |
| tree | 008b43c7b07b5a76430d163b0bf30f9b50726aa5 /ExamTemplate/Web | |
| parent | 628307b05165bb8c1faf82f3e9ab0c0053832e48 (diff) | |
| download | it-kariera-exam-template-6fedb4158836e6bf8d0e6190bc8fd36f188ac60d.tar it-kariera-exam-template-6fedb4158836e6bf8d0e6190bc8fd36f188ac60d.tar.gz it-kariera-exam-template-6fedb4158836e6bf8d0e6190bc8fd36f188ac60d.zip | |
Added gitignore and initial project generation
Diffstat (limited to 'ExamTemplate/Web')
| -rw-r--r-- | ExamTemplate/Web/Controllers/HomeController.cs | 37 | ||||
| -rw-r--r-- | ExamTemplate/Web/Models/ErrorViewModel.cs | 11 | ||||
| -rw-r--r-- | ExamTemplate/Web/Program.cs | 26 | ||||
| -rw-r--r-- | ExamTemplate/Web/Properties/launchSettings.json | 27 | ||||
| -rw-r--r-- | ExamTemplate/Web/Startup.cs | 57 | ||||
| -rw-r--r-- | ExamTemplate/Web/Views/Home/Index.cshtml | 8 | ||||
| -rw-r--r-- | ExamTemplate/Web/Views/Home/Privacy.cshtml | 6 | ||||
| -rw-r--r-- | ExamTemplate/Web/Views/Shared/Error.cshtml | 25 | ||||
| -rw-r--r-- | ExamTemplate/Web/Views/Shared/_Layout.cshtml | 48 | ||||
| -rw-r--r-- | ExamTemplate/Web/Views/Shared/_ValidationScriptsPartial.cshtml | 2 | ||||
| -rw-r--r-- | ExamTemplate/Web/Views/_ViewImports.cshtml | 3 | ||||
| -rw-r--r-- | ExamTemplate/Web/Views/_ViewStart.cshtml | 3 | ||||
| -rw-r--r-- | ExamTemplate/Web/Web.csproj | 12 | ||||
| -rw-r--r-- | ExamTemplate/Web/appsettings.Development.json | 9 | ||||
| -rw-r--r-- | ExamTemplate/Web/appsettings.json | 10 |
15 files changed, 284 insertions, 0 deletions
diff --git a/ExamTemplate/Web/Controllers/HomeController.cs b/ExamTemplate/Web/Controllers/HomeController.cs new file mode 100644 index 0000000..3c5b6ec --- /dev/null +++ b/ExamTemplate/Web/Controllers/HomeController.cs @@ -0,0 +1,37 @@ +using System;
+using System.Collections.Generic;
+using System.Diagnostics;
+using System.Linq;
+using System.Threading.Tasks;
+using Microsoft.AspNetCore.Mvc;
+using Microsoft.Extensions.Logging;
+using Web.Models;
+
+namespace Web.Controllers
+{
+ public class HomeController : Controller
+ {
+ private readonly ILogger<HomeController> _logger;
+
+ public HomeController(ILogger<HomeController> logger)
+ {
+ _logger = logger;
+ }
+
+ public IActionResult Index()
+ {
+ return View();
+ }
+
+ public IActionResult Privacy()
+ {
+ return View();
+ }
+
+ [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
+ public IActionResult Error()
+ {
+ return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
+ }
+ }
+}
diff --git a/ExamTemplate/Web/Models/ErrorViewModel.cs b/ExamTemplate/Web/Models/ErrorViewModel.cs new file mode 100644 index 0000000..f603890 --- /dev/null +++ b/ExamTemplate/Web/Models/ErrorViewModel.cs @@ -0,0 +1,11 @@ +using System;
+
+namespace Web.Models
+{
+ public class ErrorViewModel
+ {
+ public string RequestId { get; set; }
+
+ public bool ShowRequestId => !string.IsNullOrEmpty(RequestId);
+ }
+}
diff --git a/ExamTemplate/Web/Program.cs b/ExamTemplate/Web/Program.cs new file mode 100644 index 0000000..fb68b7f --- /dev/null +++ b/ExamTemplate/Web/Program.cs @@ -0,0 +1,26 @@ +using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Threading.Tasks;
+using Microsoft.AspNetCore.Hosting;
+using Microsoft.Extensions.Configuration;
+using Microsoft.Extensions.Hosting;
+using Microsoft.Extensions.Logging;
+
+namespace Web
+{
+ public class Program
+ {
+ public static void Main(string[] args)
+ {
+ CreateHostBuilder(args).Build().Run();
+ }
+
+ public static IHostBuilder CreateHostBuilder(string[] args) =>
+ Host.CreateDefaultBuilder(args)
+ .ConfigureWebHostDefaults(webBuilder =>
+ {
+ webBuilder.UseStartup<Startup>();
+ });
+ }
+}
diff --git a/ExamTemplate/Web/Properties/launchSettings.json b/ExamTemplate/Web/Properties/launchSettings.json new file mode 100644 index 0000000..9bcdafd --- /dev/null +++ b/ExamTemplate/Web/Properties/launchSettings.json @@ -0,0 +1,27 @@ +{
+ "iisSettings": {
+ "windowsAuthentication": false,
+ "anonymousAuthentication": true,
+ "iisExpress": {
+ "applicationUrl": "http://localhost:36205",
+ "sslPort": 44322
+ }
+ },
+ "profiles": {
+ "IIS Express": {
+ "commandName": "IISExpress",
+ "launchBrowser": true,
+ "environmentVariables": {
+ "ASPNETCORE_ENVIRONMENT": "Development"
+ }
+ },
+ "Web": {
+ "commandName": "Project",
+ "launchBrowser": true,
+ "applicationUrl": "https://localhost:5001;http://localhost:5000",
+ "environmentVariables": {
+ "ASPNETCORE_ENVIRONMENT": "Development"
+ }
+ }
+ }
+}
diff --git a/ExamTemplate/Web/Startup.cs b/ExamTemplate/Web/Startup.cs new file mode 100644 index 0000000..51a6797 --- /dev/null +++ b/ExamTemplate/Web/Startup.cs @@ -0,0 +1,57 @@ +using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Threading.Tasks;
+using Microsoft.AspNetCore.Builder;
+using Microsoft.AspNetCore.Hosting;
+using Microsoft.AspNetCore.HttpsPolicy;
+using Microsoft.Extensions.Configuration;
+using Microsoft.Extensions.DependencyInjection;
+using Microsoft.Extensions.Hosting;
+
+namespace Web
+{
+ public class Startup
+ {
+ public Startup(IConfiguration configuration)
+ {
+ Configuration = configuration;
+ }
+
+ public IConfiguration Configuration { get; }
+
+ // This method gets called by the runtime. Use this method to add services to the container.
+ public void ConfigureServices(IServiceCollection services)
+ {
+ services.AddControllersWithViews();
+ }
+
+ // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
+ public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
+ {
+ if (env.IsDevelopment())
+ {
+ app.UseDeveloperExceptionPage();
+ }
+ else
+ {
+ app.UseExceptionHandler("/Home/Error");
+ // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
+ app.UseHsts();
+ }
+ app.UseHttpsRedirection();
+ app.UseStaticFiles();
+
+ app.UseRouting();
+
+ app.UseAuthorization();
+
+ app.UseEndpoints(endpoints =>
+ {
+ endpoints.MapControllerRoute(
+ name: "default",
+ pattern: "{controller=Home}/{action=Index}/{id?}");
+ });
+ }
+ }
+}
diff --git a/ExamTemplate/Web/Views/Home/Index.cshtml b/ExamTemplate/Web/Views/Home/Index.cshtml new file mode 100644 index 0000000..1fcf97d --- /dev/null +++ b/ExamTemplate/Web/Views/Home/Index.cshtml @@ -0,0 +1,8 @@ +@{
+ ViewData["Title"] = "Home Page";
+}
+
+<div class="text-center">
+ <h1 class="display-4">Welcome</h1>
+ <p>Learn about <a href="https://docs.microsoft.com/aspnet/core">building Web apps with ASP.NET Core</a>.</p>
+</div>
diff --git a/ExamTemplate/Web/Views/Home/Privacy.cshtml b/ExamTemplate/Web/Views/Home/Privacy.cshtml new file mode 100644 index 0000000..a850e76 --- /dev/null +++ b/ExamTemplate/Web/Views/Home/Privacy.cshtml @@ -0,0 +1,6 @@ +@{
+ ViewData["Title"] = "Privacy Policy";
+}
+<h1>@ViewData["Title"]</h1>
+
+<p>Use this page to detail your site's privacy policy.</p>
diff --git a/ExamTemplate/Web/Views/Shared/Error.cshtml b/ExamTemplate/Web/Views/Shared/Error.cshtml new file mode 100644 index 0000000..08a315d --- /dev/null +++ b/ExamTemplate/Web/Views/Shared/Error.cshtml @@ -0,0 +1,25 @@ +@model ErrorViewModel
+@{
+ ViewData["Title"] = "Error";
+}
+
+<h1 class="text-danger">Error.</h1>
+<h2 class="text-danger">An error occurred while processing your request.</h2>
+
+@if (Model.ShowRequestId)
+{
+ <p>
+ <strong>Request ID:</strong> <code>@Model.RequestId</code>
+ </p>
+}
+
+<h3>Development Mode</h3>
+<p>
+ Swapping to <strong>Development</strong> environment will display more detailed information about the error that occurred.
+</p>
+<p>
+ <strong>The Development environment shouldn't be enabled for deployed applications.</strong>
+ It can result in displaying sensitive information from exceptions to end users.
+ For local debugging, enable the <strong>Development</strong> environment by setting the <strong>ASPNETCORE_ENVIRONMENT</strong> environment variable to <strong>Development</strong>
+ and restarting the app.
+</p>
diff --git a/ExamTemplate/Web/Views/Shared/_Layout.cshtml b/ExamTemplate/Web/Views/Shared/_Layout.cshtml new file mode 100644 index 0000000..b94d4ee --- /dev/null +++ b/ExamTemplate/Web/Views/Shared/_Layout.cshtml @@ -0,0 +1,48 @@ +<!DOCTYPE html>
+<html lang="en">
+<head>
+ <meta charset="utf-8" />
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+ <title>@ViewData["Title"] - Web</title>
+ <link rel="stylesheet" href="~/lib/bootstrap/dist/css/bootstrap.min.css" />
+ <link rel="stylesheet" href="~/css/site.css" />
+</head>
+<body>
+ <header>
+ <nav class="navbar navbar-expand-sm navbar-toggleable-sm navbar-light bg-white border-bottom box-shadow mb-3">
+ <div class="container">
+ <a class="navbar-brand" asp-area="" asp-controller="Home" asp-action="Index">Web</a>
+ <button class="navbar-toggler" type="button" data-toggle="collapse" data-target=".navbar-collapse" aria-controls="navbarSupportedContent"
+ aria-expanded="false" aria-label="Toggle navigation">
+ <span class="navbar-toggler-icon"></span>
+ </button>
+ <div class="navbar-collapse collapse d-sm-inline-flex flex-sm-row-reverse">
+ <ul class="navbar-nav flex-grow-1">
+ <li class="nav-item">
+ <a class="nav-link text-dark" asp-area="" asp-controller="Home" asp-action="Index">Home</a>
+ </li>
+ <li class="nav-item">
+ <a class="nav-link text-dark" asp-area="" asp-controller="Home" asp-action="Privacy">Privacy</a>
+ </li>
+ </ul>
+ </div>
+ </div>
+ </nav>
+ </header>
+ <div class="container">
+ <main role="main" class="pb-3">
+ @RenderBody()
+ </main>
+ </div>
+
+ <footer class="border-top footer text-muted">
+ <div class="container">
+ © 2021 - Web - <a asp-area="" asp-controller="Home" asp-action="Privacy">Privacy</a>
+ </div>
+ </footer>
+ <script src="~/lib/jquery/dist/jquery.min.js"></script>
+ <script src="~/lib/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
+ <script src="~/js/site.js" asp-append-version="true"></script>
+ @RenderSection("Scripts", required: false)
+</body>
+</html>
diff --git a/ExamTemplate/Web/Views/Shared/_ValidationScriptsPartial.cshtml b/ExamTemplate/Web/Views/Shared/_ValidationScriptsPartial.cshtml new file mode 100644 index 0000000..9b7b0de --- /dev/null +++ b/ExamTemplate/Web/Views/Shared/_ValidationScriptsPartial.cshtml @@ -0,0 +1,2 @@ +<script src="~/lib/jquery-validation/dist/jquery.validate.min.js"></script>
+<script src="~/lib/jquery-validation-unobtrusive/jquery.validate.unobtrusive.min.js"></script>
diff --git a/ExamTemplate/Web/Views/_ViewImports.cshtml b/ExamTemplate/Web/Views/_ViewImports.cshtml new file mode 100644 index 0000000..bf79573 --- /dev/null +++ b/ExamTemplate/Web/Views/_ViewImports.cshtml @@ -0,0 +1,3 @@ +@using Web
+@using Web.Models
+@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers
diff --git a/ExamTemplate/Web/Views/_ViewStart.cshtml b/ExamTemplate/Web/Views/_ViewStart.cshtml new file mode 100644 index 0000000..66b5da2 --- /dev/null +++ b/ExamTemplate/Web/Views/_ViewStart.cshtml @@ -0,0 +1,3 @@ +@{
+ Layout = "_Layout";
+}
diff --git a/ExamTemplate/Web/Web.csproj b/ExamTemplate/Web/Web.csproj new file mode 100644 index 0000000..3c3737c --- /dev/null +++ b/ExamTemplate/Web/Web.csproj @@ -0,0 +1,12 @@ +<Project Sdk="Microsoft.NET.Sdk.Web">
+
+ <ItemGroup> + <ProjectReference Include="..\Services\Services.csproj" /> + <ProjectReference Include="..\Common\Common.csproj" /> + </ItemGroup>
+
+ <PropertyGroup>
+ <TargetFramework>netcoreapp5.0</TargetFramework>
+ </PropertyGroup>
+
+</Project>
diff --git a/ExamTemplate/Web/appsettings.Development.json b/ExamTemplate/Web/appsettings.Development.json new file mode 100644 index 0000000..dba68eb --- /dev/null +++ b/ExamTemplate/Web/appsettings.Development.json @@ -0,0 +1,9 @@ +{ + "Logging": { + "LogLevel": { + "Default": "Information",
+ "Microsoft": "Warning",
+ "Microsoft.Hosting.Lifetime": "Information"
+ } + } +} diff --git a/ExamTemplate/Web/appsettings.json b/ExamTemplate/Web/appsettings.json new file mode 100644 index 0000000..81ff877 --- /dev/null +++ b/ExamTemplate/Web/appsettings.json @@ -0,0 +1,10 @@ +{
+ "Logging": {
+ "LogLevel": {
+ "Default": "Information",
+ "Microsoft": "Warning",
+ "Microsoft.Hosting.Lifetime": "Information"
+ }
+ },
+ "AllowedHosts": "*"
+}
|
