Merge pull request #1 from CESARDELATORRE/glennc
some initial dockerfiles and catalog work. Proof of concept more than…
This commit is contained in:
		
						commit
						e60e65ab0d
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -250,3 +250,4 @@ paket-files/ | |||||||
| # JetBrains Rider | # JetBrains Rider | ||||||
| .idea/ | .idea/ | ||||||
| *.sln.iml | *.sln.iml | ||||||
|  | pub/ | ||||||
|  | |||||||
							
								
								
									
										7
									
								
								NuGet.config
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								NuGet.config
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <configuration> | ||||||
|  |   <packageSources> | ||||||
|  |     <add key="AspNetCore" value="https://dotnet.myget.org/F/aspnetcore-dev/api/v3/index.json" /> | ||||||
|  |     <add key="NuGet" value="https://api.nuget.org/v3/index.json" /> | ||||||
|  |   </packageSources> | ||||||
|  | </configuration> | ||||||
							
								
								
									
										8
									
								
								build.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										8
									
								
								build.sh
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,8 @@ | |||||||
|  | #!/bin/sh | ||||||
|  | #dotnet restore | ||||||
|  | rm -rf ./pub | ||||||
|  | dotnet publish "$(pwd)/src/Services/Catalog/Catalog.API/project.json" -o "$(pwd)/pub/catalog" | ||||||
|  | dotnet publish "$(pwd)/src/Web/Microsoft.eShopOnContainers.WebMVC/project.json" -o "$(pwd)/pub/webMVC" | ||||||
|  | 
 | ||||||
|  | docker build -t eshop/web "$(pwd)/pub/webMVC" | ||||||
|  | docker build -t eshop/catalog.api "$(pwd)/pub/catalog" | ||||||
							
								
								
									
										21
									
								
								docker-compose.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								docker-compose.yml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | |||||||
|  | version: '2' | ||||||
|  | 
 | ||||||
|  | services: | ||||||
|  |   webmvc: | ||||||
|  |     image: eshop/web | ||||||
|  |     environment: | ||||||
|  |       - CatalogUrl=http://catalog.api | ||||||
|  |     ports: | ||||||
|  |       - "80:80" | ||||||
|  |     depends_on: | ||||||
|  |       - catalog.api | ||||||
|  |   catalog.api: | ||||||
|  |     image: eshop/catalog.api | ||||||
|  |     environment: | ||||||
|  |       - ConnectionString=Server=catalogdata;Port=5432;Database=postgres;username=postgres | ||||||
|  |     expose: | ||||||
|  |       - "80" | ||||||
|  |     depends_on: | ||||||
|  |       - catalogdata | ||||||
|  |   catalogdata: | ||||||
|  |     image: glennc/eshopdata | ||||||
| @ -7,7 +7,9 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "src", "src", "{932D8224-11F | |||||||
| EndProject | EndProject | ||||||
| Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{3AF739CD-81D8-428D-A08A-0A58372DEBF6}" | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{3AF739CD-81D8-428D-A08A-0A58372DEBF6}" | ||||||
| 	ProjectSection(SolutionItems) = preProject | 	ProjectSection(SolutionItems) = preProject | ||||||
|  | 		docker-compose.yml = docker-compose.yml | ||||||
| 		global.json = global.json | 		global.json = global.json | ||||||
|  | 		NuGet.config = NuGet.config | ||||||
| 	EndProjectSection | 	EndProjectSection | ||||||
| EndProject | EndProject | ||||||
| Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Services", "Services", "{91CF7717-08AB-4E65-B10E-0B426F01E2E8}" | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Services", "Services", "{91CF7717-08AB-4E65-B10E-0B426F01E2E8}" | ||||||
|  | |||||||
| @ -0,0 +1,73 @@ | |||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Threading.Tasks; | ||||||
|  | using Microsoft.AspNetCore.Mvc; | ||||||
|  | using Microsoft.eShopOnContainers.Services.Catalog.API.Model; | ||||||
|  | 
 | ||||||
|  | namespace Microsoft.eShopOnContainers.Services.Catalog.API.Controllers | ||||||
|  | { | ||||||
|  |     [Route("/")] | ||||||
|  |     public class CatalogController : ControllerBase | ||||||
|  |     { | ||||||
|  |         private CatalogContext _context; | ||||||
|  | 
 | ||||||
|  |         public CatalogController(CatalogContext context) | ||||||
|  |         { | ||||||
|  |             _context = context; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // GET api/values | ||||||
|  |         [HttpGet] | ||||||
|  |         public IEnumerable<CatalogItem> Get() | ||||||
|  |         { | ||||||
|  |             return _context.CatalogItems.ToList(); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // GET api/values/5 | ||||||
|  |         [HttpGet("{id}")] | ||||||
|  |         public IActionResult Get(Guid id) | ||||||
|  |         { | ||||||
|  |             var item = _context.CatalogItems.FirstOrDefault(x=> x.Id == id); | ||||||
|  | 
 | ||||||
|  |             if(item == null) | ||||||
|  |             { | ||||||
|  |                 return NotFound(); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return new OkObjectResult(item); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // POST api/values | ||||||
|  |         [HttpPost] | ||||||
|  |         public IActionResult Post([FromBody]CatalogItem item) | ||||||
|  |         { | ||||||
|  |             try | ||||||
|  |             { | ||||||
|  |                 _context.CatalogItems.Add(item); | ||||||
|  |                 _context.SaveChanges(); | ||||||
|  |                 return Ok(); | ||||||
|  |             } | ||||||
|  |             catch | ||||||
|  |             { | ||||||
|  |                 return StatusCode(500, "Unable to add new catalog item"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // PUT api/values/5 | ||||||
|  |         [HttpPut("{id}")] | ||||||
|  |         public IActionResult Put(int id, [FromBody]CatalogItem item) | ||||||
|  |         { | ||||||
|  |             _context.CatalogItems.Update(item); | ||||||
|  |             _context.SaveChanges(); | ||||||
|  |             return Ok(); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // DELETE api/values/5 | ||||||
|  |         [HttpDelete("{id}")] | ||||||
|  |         public IActionResult Delete(Guid id) | ||||||
|  |         { | ||||||
|  |             return Ok(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,44 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
| using Microsoft.AspNetCore.Mvc; |  | ||||||
| 
 |  | ||||||
| namespace Microsoft.eShopOnContainers.Services.Catalog.API.Controllers |  | ||||||
| { |  | ||||||
|     [Route("api/[controller]")]
 |  | ||||||
|     public class ValuesController : Controller |  | ||||||
|     { |  | ||||||
|         // GET api/values |  | ||||||
|         [HttpGet] |  | ||||||
|         public IEnumerable<string> Get() |  | ||||||
|         { |  | ||||||
|             return new string[] { "value1", "value2" }; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // GET api/values/5 |  | ||||||
|         [HttpGet("{id}")] |  | ||||||
|         public string Get(int id) |  | ||||||
|         { |  | ||||||
|             return "value"; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // POST api/values |  | ||||||
|         [HttpPost] |  | ||||||
|         public void Post([FromBody]string value) |  | ||||||
|         { |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // PUT api/values/5 |  | ||||||
|         [HttpPut("{id}")] |  | ||||||
|         public void Put(int id, [FromBody]string value) |  | ||||||
|         { |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // DELETE api/values/5 |  | ||||||
|         [HttpDelete("{id}")] |  | ||||||
|         public void Delete(int id) |  | ||||||
|         { |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
							
								
								
									
										5
									
								
								src/Services/Catalog/Catalog.API/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/Services/Catalog/Catalog.API/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | |||||||
|  | FROM microsoft/aspnetcore | ||||||
|  | WORKDIR /app | ||||||
|  | EXPOSE 80 | ||||||
|  | ADD . /app | ||||||
|  | ENTRYPOINT dotnet Catalog.API.dll | ||||||
							
								
								
									
										23
									
								
								src/Services/Catalog/Catalog.API/Model/CatalogContext.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								src/Services/Catalog/Catalog.API/Model/CatalogContext.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using Npgsql.EntityFrameworkCore.PostgreSQL; | ||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Threading.Tasks; | ||||||
|  | 
 | ||||||
|  | namespace Microsoft.eShopOnContainers.Services.Catalog.API.Model | ||||||
|  | { | ||||||
|  |     public class CatalogContext : DbContext | ||||||
|  |     { | ||||||
|  |         public CatalogContext(DbContextOptions options): base(options) | ||||||
|  |         { | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public DbSet<CatalogItem> CatalogItems { get; set; } | ||||||
|  | 
 | ||||||
|  |         protected override void OnModelCreating(ModelBuilder builder) | ||||||
|  |         { | ||||||
|  |             builder.HasPostgresExtension("uuid-ossp"); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										20
									
								
								src/Services/Catalog/Catalog.API/Model/CatalogItem.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								src/Services/Catalog/Catalog.API/Model/CatalogItem.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,20 @@ | |||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Threading.Tasks; | ||||||
|  | 
 | ||||||
|  | namespace Microsoft.eShopOnContainers.Services.Catalog.API.Model | ||||||
|  | { | ||||||
|  |     public class CatalogItem | ||||||
|  |     { | ||||||
|  |         public CatalogItem() | ||||||
|  |         { | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public Guid Id { get; set; } | ||||||
|  |         public string Name { get; set; } | ||||||
|  |         public string Description { get; set; } | ||||||
|  |         public decimal Price { get; set; } | ||||||
|  |         public int ImageCount { get; set; } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -15,7 +15,6 @@ namespace Microsoft.eShopOnContainers.Services.Catalog.API | |||||||
|             var host = new WebHostBuilder() |             var host = new WebHostBuilder() | ||||||
|                 .UseKestrel() |                 .UseKestrel() | ||||||
|                 .UseContentRoot(Directory.GetCurrentDirectory()) |                 .UseContentRoot(Directory.GetCurrentDirectory()) | ||||||
|                 .UseIISIntegration() |  | ||||||
|                 .UseStartup<Startup>() |                 .UseStartup<Startup>() | ||||||
|                 .Build(); |                 .Build(); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,187 +0,0 @@ | |||||||
| <!DOCTYPE html> |  | ||||||
| <html lang="en"> |  | ||||||
| <head> |  | ||||||
|     <meta charset="utf-8" /> |  | ||||||
|     <title>Welcome to ASP.NET Core</title> |  | ||||||
|     <style> |  | ||||||
|         html { |  | ||||||
|             background: #f1f1f1; |  | ||||||
|             height: 100%; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         body { |  | ||||||
|             background: #fff; |  | ||||||
|             color: #505050; |  | ||||||
|             font: 14px 'Segoe UI', tahoma, arial, helvetica, sans-serif; |  | ||||||
|             margin: 1%; |  | ||||||
|             min-height: 95.5%; |  | ||||||
|             border: 1px solid silver; |  | ||||||
|             position: relative; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         #header { |  | ||||||
|             padding: 0; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|             #header h1 { |  | ||||||
|                 font-size: 44px; |  | ||||||
|                 font-weight: normal; |  | ||||||
|                 margin: 0; |  | ||||||
|                 padding: 10px 30px 10px 30px; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             #header span { |  | ||||||
|                 margin: 0; |  | ||||||
|                 padding: 0 30px; |  | ||||||
|                 display: block; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             #header p { |  | ||||||
|                 font-size: 20px; |  | ||||||
|                 color: #fff; |  | ||||||
|                 background: #007acc; |  | ||||||
|                 padding: 0 30px; |  | ||||||
|                 line-height: 50px; |  | ||||||
|                 margin-top: 25px; |  | ||||||
| 
 |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|                 #header p a { |  | ||||||
|                     color: #fff; |  | ||||||
|                     text-decoration: underline; |  | ||||||
|                     font-weight: bold; |  | ||||||
|                     padding-right: 35px; |  | ||||||
|                     background: no-repeat right bottom url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABcAAAAWCAMAAAAcqPc3AAAANlBMVEUAAAAAeswfitI9mthXp91us+KCvuaTx+mjz+2x1u+83PLH4vTR5/ba7Pjj8Pns9fv1+v3////wy3dWAAAAAXRSTlMAQObYZgAAAHxJREFUeNp9kVcSwCAIRMHUYoH7XzaxOxJ9P8oyQ1uIqNPwh3s2aLmIM2YtqrLcQIeQEylhuCeUOlhgve5yoBCfWmlnlgkN4H8ykbpaE7gR03AbUHiwoOxUH9Xp+ubd41p1HF3mBPrfC87BHeTdaB3ceeKL9HGpcvX9zu6+DdMWT9KQPvYAAAAASUVORK5CYII=); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|         #main { |  | ||||||
|             padding: 5px 30px; |  | ||||||
|             clear: both; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         .section { |  | ||||||
|             width: 21.7%; |  | ||||||
|             float: left; |  | ||||||
|             margin: 0 0 0 4%; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|             .section h2 { |  | ||||||
|                 font-size: 13px; |  | ||||||
|                 text-transform: uppercase; |  | ||||||
|                 margin: 0; |  | ||||||
|                 border-bottom: 1px solid silver; |  | ||||||
|                 padding-bottom: 12px; |  | ||||||
|                 margin-bottom: 8px; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             .section.first { |  | ||||||
|                 margin-left: 0; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|                 .section.first h2 { |  | ||||||
|                     font-size: 24px; |  | ||||||
|                     text-transform: none; |  | ||||||
|                     margin-bottom: 25px; |  | ||||||
|                     border: none; |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 .section.first li { |  | ||||||
|                     border-top: 1px solid silver; |  | ||||||
|                     padding: 8px 0; |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|             .section.last { |  | ||||||
|                 margin-right: 0; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|         ul { |  | ||||||
|             list-style: none; |  | ||||||
|             padding: 0; |  | ||||||
|             margin: 0; |  | ||||||
|             line-height: 20px; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         li { |  | ||||||
|             padding: 4px 0; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         a { |  | ||||||
|             color: #267cb2; |  | ||||||
|             text-decoration: none; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|             a:hover { |  | ||||||
|                 text-decoration: underline; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|         #footer { |  | ||||||
|             clear: both; |  | ||||||
|             padding-top: 50px; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|             #footer p { |  | ||||||
|                 position: absolute; |  | ||||||
|                 bottom: 10px; |  | ||||||
|             } |  | ||||||
|     </style> |  | ||||||
| </head> |  | ||||||
| <body> |  | ||||||
| 
 |  | ||||||
|     <div id="header"> |  | ||||||
|         <h1>Welcome to ASP.NET Core</h1> |  | ||||||
|         <span> |  | ||||||
|             We've made some big updates in this release, so it’s <b>important</b> that you spend |  | ||||||
|             a few minutes to learn what’s new. |  | ||||||
|         </span> |  | ||||||
|         <p>You've created a new ASP.NET Core project. <a href="http://go.microsoft.com/fwlink/?LinkId=518016">Learn what's new</a></p> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|     <div id="main"> |  | ||||||
|         <div class="section first"> |  | ||||||
|             <h2>This application consists of:</h2> |  | ||||||
|             <ul> |  | ||||||
|                 <li>Sample pages using ASP.NET Core MVC</li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=518004">Bower</a> for managing client-side libraries</li> |  | ||||||
|                 <li>Theming using <a href="http://go.microsoft.com/fwlink/?LinkID=398939">Bootstrap</a></li> |  | ||||||
|             </ul> |  | ||||||
|         </div> |  | ||||||
|         <div class="section"> |  | ||||||
|             <h2>How to</h2> |  | ||||||
|             <ul> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=398600">Add a Controller and View</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=699562">Add an appsetting in config and access it in app.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699315">Manage User Secrets using Secret Manager.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699316">Use logging to log a message.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699317">Add packages using NuGet.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699318">Add client packages using Bower.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699319">Target development, staging or production environment.</a></li> |  | ||||||
|             </ul> |  | ||||||
|         </div> |  | ||||||
|         <div class="section"> |  | ||||||
|             <h2>Overview</h2> |  | ||||||
|             <ul> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=518008">Conceptual overview of what is ASP.NET Core</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699320">Fundamentals of ASP.NET Core such as Startup and middleware.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=398602">Working with Data</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=398603">Security</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=699321">Client side development</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=699322">Develop on different platforms</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=699323">Read more on the documentation site</a></li> |  | ||||||
|             </ul> |  | ||||||
|         </div> |  | ||||||
|         <div class="section last"> |  | ||||||
|             <h2>Run & Deploy</h2> |  | ||||||
|             <ul> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=517851">Run your app</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=517853">Run tools such as EF migrations and more</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=398609">Publish to Microsoft Azure Web Apps</a></li> |  | ||||||
|             </ul> |  | ||||||
|         </div> |  | ||||||
| 
 |  | ||||||
|         <div id="footer"> |  | ||||||
|             <p>We would love to hear your <a href="http://go.microsoft.com/fwlink/?LinkId=518015">feedback</a></p> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
| </body> |  | ||||||
| </html> |  | ||||||
| @ -10,8 +10,6 @@ | |||||||
|   "profiles": { |   "profiles": { | ||||||
|     "IIS Express": { |     "IIS Express": { | ||||||
|       "commandName": "IISExpress", |       "commandName": "IISExpress", | ||||||
|       "launchBrowser": true, |  | ||||||
|       "launchUrl": "api/values", |  | ||||||
|       "environmentVariables": { |       "environmentVariables": { | ||||||
|         "ASPNETCORE_ENVIRONMENT": "Development" |         "ASPNETCORE_ENVIRONMENT": "Development" | ||||||
|       } |       } | ||||||
| @ -23,6 +21,10 @@ | |||||||
|       "environmentVariables": { |       "environmentVariables": { | ||||||
|         "ASPNETCORE_ENVIRONMENT": "Development" |         "ASPNETCORE_ENVIRONMENT": "Development" | ||||||
|       } |       } | ||||||
|  |     }, | ||||||
|  |     "Docker": { | ||||||
|  |       "launchBrowser": true, | ||||||
|  |       "launchUrl": "http://localhost:{ServicePort}/api/values" | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -7,6 +7,8 @@ using Microsoft.AspNetCore.Hosting; | |||||||
| using Microsoft.Extensions.Configuration; | using Microsoft.Extensions.Configuration; | ||||||
| using Microsoft.Extensions.DependencyInjection; | using Microsoft.Extensions.DependencyInjection; | ||||||
| using Microsoft.Extensions.Logging; | using Microsoft.Extensions.Logging; | ||||||
|  | using Microsoft.eShopOnContainers.Services.Catalog.API.Model; | ||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
| 
 | 
 | ||||||
| namespace Microsoft.eShopOnContainers.Services.Catalog.API | namespace Microsoft.eShopOnContainers.Services.Catalog.API | ||||||
| { | { | ||||||
| @ -16,8 +18,7 @@ namespace Microsoft.eShopOnContainers.Services.Catalog.API | |||||||
|         { |         { | ||||||
|             var builder = new ConfigurationBuilder() |             var builder = new ConfigurationBuilder() | ||||||
|                 .SetBasePath(env.ContentRootPath) |                 .SetBasePath(env.ContentRootPath) | ||||||
|                 .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true) |                 .AddJsonFile("settings.json") | ||||||
|                 .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true) |  | ||||||
|                 .AddEnvironmentVariables(); |                 .AddEnvironmentVariables(); | ||||||
|             Configuration = builder.Build(); |             Configuration = builder.Build(); | ||||||
|         } |         } | ||||||
| @ -27,8 +28,13 @@ namespace Microsoft.eShopOnContainers.Services.Catalog.API | |||||||
|         // This method gets called by the runtime. Use this method to add services to the container. |         // This method gets called by the runtime. Use this method to add services to the container. | ||||||
|         public void ConfigureServices(IServiceCollection services) |         public void ConfigureServices(IServiceCollection services) | ||||||
|         { |         { | ||||||
|  |             services.AddDbContext<CatalogContext>(c => { | ||||||
|  |                 c.UseNpgsql(Configuration["ConnectionString"]); | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|             // Add framework services. |             // Add framework services. | ||||||
|             services.AddMvc(); |             services.AddMvcCore() | ||||||
|  |                     .AddJsonFormatters(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. |         // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. | ||||||
|  | |||||||
| @ -1,25 +1,21 @@ | |||||||
| { | { | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "Microsoft.NETCore.App": { |     "Microsoft.NETCore.App": { | ||||||
|       "version": "1.0.0", |       "version": "1.0.0", | ||||||
|       "type": "platform" |       "type": "platform" | ||||||
|     }, |     }, | ||||||
|     "Microsoft.AspNetCore.Mvc": "1.0.0", |     "Microsoft.AspNetCore.Mvc": "1.0.0", | ||||||
|     "Microsoft.AspNetCore.Server.IISIntegration": "1.0.0", |  | ||||||
|     "Microsoft.AspNetCore.Server.Kestrel": "1.0.0", |     "Microsoft.AspNetCore.Server.Kestrel": "1.0.0", | ||||||
|  |     "Microsoft.EntityFrameworkCore": "1.0.0", | ||||||
|     "Microsoft.Extensions.Configuration.EnvironmentVariables": "1.0.0", |     "Microsoft.Extensions.Configuration.EnvironmentVariables": "1.0.0", | ||||||
|     "Microsoft.Extensions.Configuration.FileExtensions": "1.0.0", |  | ||||||
|     "Microsoft.Extensions.Configuration.Json": "1.0.0", |     "Microsoft.Extensions.Configuration.Json": "1.0.0", | ||||||
|     "Microsoft.Extensions.Logging": "1.0.0", |     "Microsoft.Extensions.Logging": "1.0.0", | ||||||
|     "Microsoft.Extensions.Logging.Console": "1.0.0", |     "Microsoft.Extensions.Logging.Console": "1.0.0", | ||||||
|     "Microsoft.Extensions.Logging.Debug": "1.0.0", |     "Microsoft.Extensions.Logging.Debug": "1.0.0", | ||||||
|     "Microsoft.Extensions.Options.ConfigurationExtensions": "1.0.0" |     "Microsoft.Extensions.Options.ConfigurationExtensions": "1.0.0", | ||||||
|  |     "Npgsql.EntityFrameworkCore.PostgreSQL": "1.0.1" | ||||||
|   }, |   }, | ||||||
| 
 |   "tools": {}, | ||||||
|   "tools": { |  | ||||||
|     "Microsoft.AspNetCore.Server.IISIntegration.Tools": "1.0.0-preview2-final" |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   "frameworks": { |   "frameworks": { | ||||||
|     "netcoreapp1.0": { |     "netcoreapp1.0": { | ||||||
|       "imports": [ |       "imports": [ | ||||||
| @ -28,29 +24,26 @@ | |||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   "buildOptions": { |   "buildOptions": { | ||||||
|     "emitEntryPoint": true, |     "emitEntryPoint": true, | ||||||
|     "preserveCompilationContext": true |     "preserveCompilationContext": true, | ||||||
|  |     "debugType": "portable" | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   "runtimeOptions": { |   "runtimeOptions": { | ||||||
|     "configProperties": { |     "configProperties": { | ||||||
|       "System.GC.Server": true |       "System.GC.Server": true | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   "publishOptions": { |   "publishOptions": { | ||||||
|     "include": [ |     "include": [ | ||||||
|       "wwwroot", |       "wwwroot", | ||||||
|       "Views", |       "Views", | ||||||
|       "Areas/**/Views", |       "Areas/**/Views", | ||||||
|       "appsettings.json", |       "settings.json", | ||||||
|       "web.config" |       "web.config", | ||||||
|  |       "project.json", | ||||||
|  |       "Dockerfile" | ||||||
|     ] |     ] | ||||||
|   }, |   }, | ||||||
| 
 |   "scripts": {} | ||||||
|   "scripts": { | } | ||||||
|     "postpublish": [ "dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" ] |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @ -1,4 +1,5 @@ | |||||||
| { | { | ||||||
|  |   "ConnectionString": "Server=127.0.0.1;Port=5432;Database=postgres;username=postgres", | ||||||
|   "Logging": { |   "Logging": { | ||||||
|     "IncludeScopes": false, |     "IncludeScopes": false, | ||||||
|     "LogLevel": { |     "LogLevel": { | ||||||
| @ -1,14 +1,9 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <configuration> | <configuration> | ||||||
| 
 |  | ||||||
|   <!-- |  | ||||||
|     Configure your application settings in appsettings.json. Learn more at http://go.microsoft.com/fwlink/?LinkId=786380 |  | ||||||
|   --> |  | ||||||
| 
 |  | ||||||
|   <system.webServer> |   <system.webServer> | ||||||
|     <handlers> |     <handlers> | ||||||
|       <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified"/> |       <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified" /> | ||||||
|     </handlers> |     </handlers> | ||||||
|     <aspNetCore processPath="%LAUNCHER_PATH%" arguments="%LAUNCHER_ARGS%" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" forwardWindowsAuthToken="false"/> |     <aspNetCore processPath="%LAUNCHER_PATH%" arguments="%LAUNCHER_ARGS%" forwardWindowsAuthToken="false" stdoutLogEnabled="false" /> | ||||||
|   </system.webServer> |   </system.webServer> | ||||||
| </configuration> | </configuration> | ||||||
							
								
								
									
										32
									
								
								src/Web/Microsoft.eShopOnContainers.WebMVC/AppSettings.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/Web/Microsoft.eShopOnContainers.WebMVC/AppSettings.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,32 @@ | |||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Threading.Tasks; | ||||||
|  | 
 | ||||||
|  | namespace Microsoft.eShopOnContainers.WebMVC | ||||||
|  | { | ||||||
|  |     public class AppSettings | ||||||
|  |     { | ||||||
|  |         public Connectionstrings ConnectionStrings { get; set; } | ||||||
|  |         public string CatalogUrl { get; set; } | ||||||
|  |         public Logging Logging { get; set; } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public class Connectionstrings | ||||||
|  |     { | ||||||
|  |         public string DefaultConnection { get; set; } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public class Logging | ||||||
|  |     { | ||||||
|  |         public bool IncludeScopes { get; set; } | ||||||
|  |         public Loglevel LogLevel { get; set; } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public class Loglevel | ||||||
|  |     { | ||||||
|  |         public string Default { get; set; } | ||||||
|  |         public string System { get; set; } | ||||||
|  |         public string Microsoft { get; set; } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -2,15 +2,29 @@ | |||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Threading.Tasks; | using System.Threading.Tasks; | ||||||
|  | using System.Net.Http; | ||||||
| using Microsoft.AspNetCore.Mvc; | using Microsoft.AspNetCore.Mvc; | ||||||
|  | using Microsoft.eShopOnContainers.WebMVC.Models; | ||||||
|  | using Microsoft.Extensions.Options; | ||||||
|  | using Newtonsoft.Json; | ||||||
| 
 | 
 | ||||||
| namespace Microsoft.eShopOnContainers.WebMVC.Controllers | namespace Microsoft.eShopOnContainers.WebMVC.Controllers | ||||||
| { | { | ||||||
|     public class HomeController : Controller |     public class HomeController : Controller | ||||||
|     { |     { | ||||||
|         public IActionResult Index() |         private HttpClient _http; | ||||||
|  |         private AppSettings _settings; | ||||||
|  | 
 | ||||||
|  |         public HomeController(IOptions<AppSettings> options) | ||||||
|         { |         { | ||||||
|             return View(); |             _http = new HttpClient(); | ||||||
|  |             _settings = options.Value; | ||||||
|  |         } | ||||||
|  |         public async Task<IActionResult> Index() | ||||||
|  |         { | ||||||
|  |             var dataString = await _http.GetStringAsync(_settings.CatalogUrl); | ||||||
|  |             var items = JsonConvert.DeserializeObject<List<CatalogItem>>(dataString); | ||||||
|  |             return View(items); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public IActionResult About() |         public IActionResult About() | ||||||
|  | |||||||
							
								
								
									
										7
									
								
								src/Web/Microsoft.eShopOnContainers.WebMVC/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/Web/Microsoft.eShopOnContainers.WebMVC/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | |||||||
|  | FROM microsoft/dotnet:1.0.0-core | ||||||
|  | ARG source=. | ||||||
|  | WORKDIR /app | ||||||
|  | ENV ASPNETCORE_URLS http://*:80 | ||||||
|  | EXPOSE 80 | ||||||
|  | COPY $source . | ||||||
|  | ENTRYPOINT dotnet Microsoft.eShopOnContainers.WebMVC.dll | ||||||
| @ -0,0 +1,12 @@ | |||||||
|  | using System; | ||||||
|  | 
 | ||||||
|  | namespace Microsoft.eShopOnContainers.WebMVC.Models | ||||||
|  | { | ||||||
|  |     public class CatalogItem | ||||||
|  |     { | ||||||
|  |         public Guid Id { get; set; } | ||||||
|  |         public string Name { get; set; } | ||||||
|  |         public string Description { get; set; } | ||||||
|  |         public decimal Price { get; set; } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,187 +0,0 @@ | |||||||
| <!DOCTYPE html> |  | ||||||
| <html lang="en"> |  | ||||||
| <head> |  | ||||||
|     <meta charset="utf-8" /> |  | ||||||
|     <title>Welcome to ASP.NET Core</title> |  | ||||||
|     <style> |  | ||||||
|         html { |  | ||||||
|             background: #f1f1f1; |  | ||||||
|             height: 100%; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         body { |  | ||||||
|             background: #fff; |  | ||||||
|             color: #505050; |  | ||||||
|             font: 14px 'Segoe UI', tahoma, arial, helvetica, sans-serif; |  | ||||||
|             margin: 1%; |  | ||||||
|             min-height: 95.5%; |  | ||||||
|             border: 1px solid silver; |  | ||||||
|             position: relative; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         #header { |  | ||||||
|             padding: 0; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|             #header h1 { |  | ||||||
|                 font-size: 44px; |  | ||||||
|                 font-weight: normal; |  | ||||||
|                 margin: 0; |  | ||||||
|                 padding: 10px 30px 10px 30px; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             #header span { |  | ||||||
|                 margin: 0; |  | ||||||
|                 padding: 0 30px; |  | ||||||
|                 display: block; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             #header p { |  | ||||||
|                 font-size: 20px; |  | ||||||
|                 color: #fff; |  | ||||||
|                 background: #007acc; |  | ||||||
|                 padding: 0 30px; |  | ||||||
|                 line-height: 50px; |  | ||||||
|                 margin-top: 25px; |  | ||||||
| 
 |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|                 #header p a { |  | ||||||
|                     color: #fff; |  | ||||||
|                     text-decoration: underline; |  | ||||||
|                     font-weight: bold; |  | ||||||
|                     padding-right: 35px; |  | ||||||
|                     background: no-repeat right bottom url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABcAAAAWCAMAAAAcqPc3AAAANlBMVEUAAAAAeswfitI9mthXp91us+KCvuaTx+mjz+2x1u+83PLH4vTR5/ba7Pjj8Pns9fv1+v3////wy3dWAAAAAXRSTlMAQObYZgAAAHxJREFUeNp9kVcSwCAIRMHUYoH7XzaxOxJ9P8oyQ1uIqNPwh3s2aLmIM2YtqrLcQIeQEylhuCeUOlhgve5yoBCfWmlnlgkN4H8ykbpaE7gR03AbUHiwoOxUH9Xp+ubd41p1HF3mBPrfC87BHeTdaB3ceeKL9HGpcvX9zu6+DdMWT9KQPvYAAAAASUVORK5CYII=); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|         #main { |  | ||||||
|             padding: 5px 30px; |  | ||||||
|             clear: both; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         .section { |  | ||||||
|             width: 21.7%; |  | ||||||
|             float: left; |  | ||||||
|             margin: 0 0 0 4%; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|             .section h2 { |  | ||||||
|                 font-size: 13px; |  | ||||||
|                 text-transform: uppercase; |  | ||||||
|                 margin: 0; |  | ||||||
|                 border-bottom: 1px solid silver; |  | ||||||
|                 padding-bottom: 12px; |  | ||||||
|                 margin-bottom: 8px; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             .section.first { |  | ||||||
|                 margin-left: 0; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|                 .section.first h2 { |  | ||||||
|                     font-size: 24px; |  | ||||||
|                     text-transform: none; |  | ||||||
|                     margin-bottom: 25px; |  | ||||||
|                     border: none; |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 .section.first li { |  | ||||||
|                     border-top: 1px solid silver; |  | ||||||
|                     padding: 8px 0; |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|             .section.last { |  | ||||||
|                 margin-right: 0; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|         ul { |  | ||||||
|             list-style: none; |  | ||||||
|             padding: 0; |  | ||||||
|             margin: 0; |  | ||||||
|             line-height: 20px; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         li { |  | ||||||
|             padding: 4px 0; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         a { |  | ||||||
|             color: #267cb2; |  | ||||||
|             text-decoration: none; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|             a:hover { |  | ||||||
|                 text-decoration: underline; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|         #footer { |  | ||||||
|             clear: both; |  | ||||||
|             padding-top: 50px; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|             #footer p { |  | ||||||
|                 position: absolute; |  | ||||||
|                 bottom: 10px; |  | ||||||
|             } |  | ||||||
|     </style> |  | ||||||
| </head> |  | ||||||
| <body> |  | ||||||
| 
 |  | ||||||
|     <div id="header"> |  | ||||||
|         <h1>Welcome to ASP.NET Core</h1> |  | ||||||
|         <span> |  | ||||||
|             We've made some big updates in this release, so it’s <b>important</b> that you spend |  | ||||||
|             a few minutes to learn what’s new. |  | ||||||
|         </span> |  | ||||||
|         <p>You've created a new ASP.NET Core project. <a href="http://go.microsoft.com/fwlink/?LinkId=518016">Learn what's new</a></p> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|     <div id="main"> |  | ||||||
|         <div class="section first"> |  | ||||||
|             <h2>This application consists of:</h2> |  | ||||||
|             <ul> |  | ||||||
|                 <li>Sample pages using ASP.NET Core MVC</li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=518004">Bower</a> for managing client-side libraries</li> |  | ||||||
|                 <li>Theming using <a href="http://go.microsoft.com/fwlink/?LinkID=398939">Bootstrap</a></li> |  | ||||||
|             </ul> |  | ||||||
|         </div> |  | ||||||
|         <div class="section"> |  | ||||||
|             <h2>How to</h2> |  | ||||||
|             <ul> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=398600">Add a Controller and View</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=699562">Add an appsetting in config and access it in app.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699315">Manage User Secrets using Secret Manager.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699316">Use logging to log a message.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699317">Add packages using NuGet.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699318">Add client packages using Bower.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699319">Target development, staging or production environment.</a></li> |  | ||||||
|             </ul> |  | ||||||
|         </div> |  | ||||||
|         <div class="section"> |  | ||||||
|             <h2>Overview</h2> |  | ||||||
|             <ul> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=518008">Conceptual overview of what is ASP.NET Core</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=699320">Fundamentals of ASP.NET Core such as Startup and middleware.</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=398602">Working with Data</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkId=398603">Security</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=699321">Client side development</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=699322">Develop on different platforms</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=699323">Read more on the documentation site</a></li> |  | ||||||
|             </ul> |  | ||||||
|         </div> |  | ||||||
|         <div class="section last"> |  | ||||||
|             <h2>Run & Deploy</h2> |  | ||||||
|             <ul> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=517851">Run your app</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=517853">Run tools such as EF migrations and more</a></li> |  | ||||||
|                 <li><a href="http://go.microsoft.com/fwlink/?LinkID=398609">Publish to Microsoft Azure Web Apps</a></li> |  | ||||||
|             </ul> |  | ||||||
|         </div> |  | ||||||
| 
 |  | ||||||
|         <div id="footer"> |  | ||||||
|             <p>We would love to hear your <a href="http://go.microsoft.com/fwlink/?LinkId=518015">feedback</a></p> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
| </body> |  | ||||||
| </html> |  | ||||||
| @ -22,6 +22,10 @@ | |||||||
|       "environmentVariables": { |       "environmentVariables": { | ||||||
|         "ASPNETCORE_ENVIRONMENT": "Development" |         "ASPNETCORE_ENVIRONMENT": "Development" | ||||||
|       } |       } | ||||||
|  |     }, | ||||||
|  |     "Docker": { | ||||||
|  |       "launchBrowser": true, | ||||||
|  |       "launchUrl": "http://localhost:{ServicePort}" | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -52,6 +52,8 @@ namespace Microsoft.eShopOnContainers.WebMVC | |||||||
|             // Add application services. |             // Add application services. | ||||||
|             services.AddTransient<IEmailSender, AuthMessageSender>(); |             services.AddTransient<IEmailSender, AuthMessageSender>(); | ||||||
|             services.AddTransient<ISmsSender, AuthMessageSender>(); |             services.AddTransient<ISmsSender, AuthMessageSender>(); | ||||||
|  | 
 | ||||||
|  |             services.Configure<AppSettings>(Configuration); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. |         // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. | ||||||
|  | |||||||
| @ -1,109 +1,16 @@ | |||||||
| @{ | @{ | ||||||
|     ViewData["Title"] = "Home Page"; |     ViewData["Title"] = "Home Page"; | ||||||
|  |     @model IEnumerable<CatalogItem> | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| <div id="myCarousel" class="carousel slide" data-ride="carousel" data-interval="6000"> | @foreach (var catalogItem in Model) | ||||||
|     <ol class="carousel-indicators"> | { | ||||||
|         <li data-target="#myCarousel" data-slide-to="0" class="active"></li> |     <div class="panel panel-default"> | ||||||
|         <li data-target="#myCarousel" data-slide-to="1"></li> |         <div class="panel-heading"> | ||||||
|         <li data-target="#myCarousel" data-slide-to="2"></li> |             <h3 class="panel-title">@catalogItem.Name</h3> | ||||||
|         <li data-target="#myCarousel" data-slide-to="3"></li> |  | ||||||
|     </ol> |  | ||||||
|     <div class="carousel-inner" role="listbox"> |  | ||||||
|         <div class="item active"> |  | ||||||
|             <img src="~/images/banner1.svg" alt="ASP.NET" class="img-responsive" /> |  | ||||||
|             <div class="carousel-caption" role="option"> |  | ||||||
|                 <p> |  | ||||||
|                     Learn how to build ASP.NET apps that can run anywhere. |  | ||||||
|                     <a class="btn btn-default" href="http://go.microsoft.com/fwlink/?LinkID=525028&clcid=0x409"> |  | ||||||
|                         Learn More |  | ||||||
|                     </a> |  | ||||||
|                 </p> |  | ||||||
|             </div> |  | ||||||
|         </div> |         </div> | ||||||
|         <div class="item"> |         <div class="panel-body"> | ||||||
|             <img src="~/images/banner2.svg" alt="Visual Studio" class="img-responsive" /> |             @catalogItem.Description | ||||||
|             <div class="carousel-caption" role="option"> |  | ||||||
|                 <p> |  | ||||||
|                     There are powerful new features in Visual Studio for building modern web apps. |  | ||||||
|                     <a class="btn btn-default" href="http://go.microsoft.com/fwlink/?LinkID=525030&clcid=0x409"> |  | ||||||
|                         Learn More |  | ||||||
|                     </a> |  | ||||||
|                 </p> |  | ||||||
|             </div> |  | ||||||
|         </div> |  | ||||||
|         <div class="item"> |  | ||||||
|             <img src="~/images/banner3.svg" alt="Package Management" class="img-responsive" /> |  | ||||||
|             <div class="carousel-caption" role="option"> |  | ||||||
|                 <p> |  | ||||||
|                     Bring in libraries from NuGet, Bower, and npm, and automate tasks using Grunt or Gulp. |  | ||||||
|                     <a class="btn btn-default" href="http://go.microsoft.com/fwlink/?LinkID=525029&clcid=0x409"> |  | ||||||
|                         Learn More |  | ||||||
|                     </a> |  | ||||||
|                 </p> |  | ||||||
|             </div> |  | ||||||
|         </div> |  | ||||||
|         <div class="item"> |  | ||||||
|             <img src="~/images/banner4.svg" alt="Microsoft Azure" class="img-responsive" /> |  | ||||||
|             <div class="carousel-caption" role="option"> |  | ||||||
|                 <p> |  | ||||||
|                     Learn how Microsoft's Azure cloud platform allows you to build, deploy, and scale web apps. |  | ||||||
|                     <a class="btn btn-default" href="http://go.microsoft.com/fwlink/?LinkID=525027&clcid=0x409"> |  | ||||||
|                         Learn More |  | ||||||
|                     </a> |  | ||||||
|                 </p> |  | ||||||
|             </div> |  | ||||||
|         </div> |         </div> | ||||||
|     </div> |     </div> | ||||||
|     <a class="left carousel-control" href="#myCarousel" role="button" data-slide="prev"> | } | ||||||
|         <span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span> |  | ||||||
|         <span class="sr-only">Previous</span> |  | ||||||
|     </a> |  | ||||||
|     <a class="right carousel-control" href="#myCarousel" role="button" data-slide="next"> |  | ||||||
|         <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span> |  | ||||||
|         <span class="sr-only">Next</span> |  | ||||||
|     </a> |  | ||||||
| </div> |  | ||||||
| 
 |  | ||||||
| <div class="row"> |  | ||||||
|     <div class="col-md-3"> |  | ||||||
|         <h2>Application uses</h2> |  | ||||||
|         <ul> |  | ||||||
|             <li>Sample pages using ASP.NET Core MVC</li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=518004">Bower</a> for managing client-side libraries</li> |  | ||||||
|             <li>Theming using <a href="http://go.microsoft.com/fwlink/?LinkID=398939">Bootstrap</a></li> |  | ||||||
|         </ul> |  | ||||||
|     </div> |  | ||||||
|     <div class="col-md-3"> |  | ||||||
|         <h2>How to</h2> |  | ||||||
|         <ul> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkID=398600">Add a Controller and View</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkID=699562">Add an appsetting in config and access it in app.</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=699315">Manage User Secrets using Secret Manager.</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=699316">Use logging to log a message.</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=699317">Add packages using NuGet.</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=699318">Add client packages using Bower.</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=699319">Target development, staging or production environment.</a></li> |  | ||||||
|         </ul> |  | ||||||
|     </div> |  | ||||||
|     <div class="col-md-3"> |  | ||||||
|         <h2>Overview</h2> |  | ||||||
|         <ul> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=518008">Conceptual overview of what is ASP.NET Core</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=699320">Fundamentals of ASP.NET Core such as Startup and middleware.</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=398602">Working with Data</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkId=398603">Security</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkID=699321">Client side development</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkID=699322">Develop on different platforms</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkID=699323">Read more on the documentation site</a></li> |  | ||||||
|         </ul> |  | ||||||
|     </div> |  | ||||||
|     <div class="col-md-3"> |  | ||||||
|         <h2>Run & Deploy</h2> |  | ||||||
|         <ul> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkID=517851">Run your app</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkID=517853">Run tools such as EF migrations and more</a></li> |  | ||||||
|             <li><a href="http://go.microsoft.com/fwlink/?LinkID=398609">Publish to Microsoft Azure Web Apps</a></li> |  | ||||||
|         </ul> |  | ||||||
|     </div> |  | ||||||
| </div> |  | ||||||
| @ -3,4 +3,6 @@ | |||||||
| @using Microsoft.eShopOnContainers.WebMVC.Models.AccountViewModels | @using Microsoft.eShopOnContainers.WebMVC.Models.AccountViewModels | ||||||
| @using Microsoft.eShopOnContainers.WebMVC.Models.ManageViewModels | @using Microsoft.eShopOnContainers.WebMVC.Models.ManageViewModels | ||||||
| @using Microsoft.AspNetCore.Identity | @using Microsoft.AspNetCore.Identity | ||||||
|  | @using Microsoft.eShopOnContainers.WebMVC.Models | ||||||
|  | 
 | ||||||
| @addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers | @addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ | |||||||
|   "ConnectionStrings": { |   "ConnectionStrings": { | ||||||
|     "DefaultConnection": "Server=(localdb)\\mssqllocaldb;Database=aspnet-Microsoft.eShopOnContainers.WebMVC-946ae052-8305-4a99-965b-ec8636ddbae3;Trusted_Connection=True;MultipleActiveResultSets=true" |     "DefaultConnection": "Server=(localdb)\\mssqllocaldb;Database=aspnet-Microsoft.eShopOnContainers.WebMVC-946ae052-8305-4a99-965b-ec8636ddbae3;Trusted_Connection=True;MultipleActiveResultSets=true" | ||||||
|   }, |   }, | ||||||
|  |   "CatalogUrl": "http://localhost:2418/", | ||||||
|   "Logging": { |   "Logging": { | ||||||
|     "IncludeScopes": false, |     "IncludeScopes": false, | ||||||
|     "LogLevel": { |     "LogLevel": { | ||||||
|  | |||||||
| @ -0,0 +1,17 @@ | |||||||
|  | version: '2' | ||||||
|  | 
 | ||||||
|  | services: | ||||||
|  |   microsoft.eshoponcontainers.webmvc: | ||||||
|  |     build: | ||||||
|  |       args: | ||||||
|  |         source: obj/Docker/empty/ | ||||||
|  |     labels: | ||||||
|  |       - "com.microsoft.visualstudio.targetoperatingsystem=linux" | ||||||
|  |     environment: | ||||||
|  |       - ASPNETCORE_ENVIRONMENT=Development | ||||||
|  |       - DOTNET_USE_POLLING_FILE_WATCHER=1 | ||||||
|  |     volumes: | ||||||
|  |       - .:/app | ||||||
|  |       - ~/.nuget/packages:/root/.nuget/packages:ro | ||||||
|  |       - ~/clrdbg:/clrdbg:ro | ||||||
|  |     entrypoint: tail -f /dev/null | ||||||
| @ -0,0 +1,9 @@ | |||||||
|  | version: '2' | ||||||
|  | 
 | ||||||
|  | services: | ||||||
|  |   microsoft.eshoponcontainers.webmvc: | ||||||
|  |     labels: | ||||||
|  |       - "com.microsoft.visualstudio.targetoperatingsystem=linux" | ||||||
|  |     volumes: | ||||||
|  |       - ~/clrdbg:/clrdbg:ro | ||||||
|  |     entrypoint: tail -f /dev/null | ||||||
| @ -0,0 +1,10 @@ | |||||||
|  | version: '2' | ||||||
|  | 
 | ||||||
|  | services: | ||||||
|  |   microsoft.eshoponcontainers.webmvc: | ||||||
|  |     image: user/microsoft.eshoponcontainers.webmvc${TAG} | ||||||
|  |     build: | ||||||
|  |       context: . | ||||||
|  |       dockerfile: Dockerfile | ||||||
|  |     ports: | ||||||
|  |       - "80" | ||||||
| @ -1,6 +1,5 @@ | |||||||
| { | { | ||||||
|   "userSecretsId": "aspnet-Microsoft.eShopOnContainers.WebMVC-946ae052-8305-4a99-965b-ec8636ddbae3", |   "userSecretsId": "aspnet-Microsoft.eShopOnContainers.WebMVC-946ae052-8305-4a99-965b-ec8636ddbae3", | ||||||
| 
 |  | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "Microsoft.NETCore.App": { |     "Microsoft.NETCore.App": { | ||||||
|       "version": "1.0.0", |       "version": "1.0.0", | ||||||
| @ -40,7 +39,6 @@ | |||||||
|       "type": "build" |       "type": "build" | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   "tools": { |   "tools": { | ||||||
|     "BundlerMinifier.Core": "2.0.238", |     "BundlerMinifier.Core": "2.0.238", | ||||||
|     "Microsoft.AspNetCore.Razor.Tools": "1.0.0-preview2-final", |     "Microsoft.AspNetCore.Razor.Tools": "1.0.0-preview2-final", | ||||||
| @ -54,7 +52,6 @@ | |||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   "frameworks": { |   "frameworks": { | ||||||
|     "netcoreapp1.0": { |     "netcoreapp1.0": { | ||||||
|       "imports": [ |       "imports": [ | ||||||
| @ -63,30 +60,33 @@ | |||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   "buildOptions": { |   "buildOptions": { | ||||||
|     "emitEntryPoint": true, |     "emitEntryPoint": true, | ||||||
|     "preserveCompilationContext": true |     "preserveCompilationContext": true, | ||||||
|  |     "debugType": "portable" | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   "runtimeOptions": { |   "runtimeOptions": { | ||||||
|     "configProperties": { |     "configProperties": { | ||||||
|       "System.GC.Server": true |       "System.GC.Server": true | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   "publishOptions": { |   "publishOptions": { | ||||||
|     "include": [ |     "include": [ | ||||||
|       "wwwroot", |       "wwwroot", | ||||||
|       "Views", |       "Views", | ||||||
|       "Areas/**/Views", |       "Areas/**/Views", | ||||||
|       "appsettings.json", |       "appsettings.json", | ||||||
|       "web.config" |       "web.config", | ||||||
|  |       "Dockerfile" | ||||||
|     ] |     ] | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "prepublish": [ "bower install", "dotnet bundle" ], |     "prepublish": [ | ||||||
|     "postpublish": [ "dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" ] |       "bower install", | ||||||
|  |       "dotnet bundle" | ||||||
|  |     ], | ||||||
|  |     "postpublish": [ | ||||||
|  |       //"dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" | ||||||
|  |     ] | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -0,0 +1 @@ | |||||||
|  | // Write your Javascript code.
 | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user