Merge with dev
							
								
								
									
										148
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @ -1,57 +1,131 @@ | |||||||
| # Containerized eShop | # eShopOnContainers - Microservices Architecture and Containers based Reference Application | ||||||
| Sample reference containerized application, cross-platform and microservices architecture.  | Sample .NET Core reference application, powered by Microsoft, based on a simplified microservices architecture and Docker containers. It is cross-platform thanks to .NET Core services capable of running on Linux or Windows containers depending on your Docker host.  | ||||||
| Powered by Microsoft |  | ||||||
| 
 | 
 | ||||||
| <img src="img/eshop_cover.png"> | <img src="img/eshop_logo.png"> | ||||||
|  | <img src="img/eShopOnContainers_Architecture_Diagram.png"> | ||||||
| 
 | 
 | ||||||
| #Overview | ## Overview | ||||||
| In this repo you will fin samples that will help you to get introduced into <b>.net core</b>, microservices environment and <b>docker</b>. | In this repo you can find a sample reference application that will help you to understand how to implement a microservice architecture based application using <b>.NET Core</b> and <b>Docker</b>. | ||||||
|  | 
 | ||||||
|  | The example business domain or scenario is based on an eShop or eCommerce which is implemented as a multi-container application. Each container is a microservice deployment (like the basket-microservice, catalog-microservice, ordering-microservice and the  identity-microservice) which are developed using ASP.NET Core running on .NET Core so they can run either on Linux Containers and Windows Containers. | ||||||
|  | The screenshot below shows the VS Solution structure for those microservices/containers and client apps. | ||||||
|  | 
 | ||||||
|  | <img src="img/vs-solution-structure.png"> | ||||||
|  | 
 | ||||||
|  | Finally, those microservices are consumed by multiple client web and mobile apps, as described below. | ||||||
|  | 
 | ||||||
|  | <b>*MVC Application (ASP.NET Core)*</b>: Its an MVC 6 development where you can find interesting scenarios on how to consume HTTP-based microservices from C# running in the server side, as it is a typical ASP.NET Core MVC application.  | ||||||
|  | <img src="img/eshop-webmvc-app-screenshot.png"> | ||||||
|  | 
 | ||||||
|  | <b>*SPA (Single Page Application)*</b>: Developed with Angular.js 2, Typescript and ASP.NET Core MVC 6. This is another approach for client web applications to be used when you want to have a more modern behavior which is not having the typical browser round-trip on every action but behaving like a Single-Page-Application, more similar to a desktop app behavior. The consumption of the HTTP-based microservices is done from TypeScript/JavaScript, in this case.  | ||||||
|  | -  <<<<< TBD Image for SPA App >>>>> | ||||||
|  | 
 | ||||||
|  | <b>*Xamarin Mobile App (For iOS, Android and Windows/UWP)*</b>: It is a client mobile app supporting the most common OS platforms (iOS, Android and Windows/UWP). In this case, the consumption of the microservices is done from C# but running on the client devices, so out of the Docker Host. | ||||||
|  | 
 | ||||||
|  | <img src="img/xamarin-mobile-App.png"> | ||||||
|  | 
 | ||||||
|  | > ### Note on tested Docker Containers/Images | ||||||
|  | > The development and testing of this project was (as of Dec. 2016) done <b>only on Docker Linux containers</b> running in development machines with "Docker for Windows" and the default Hyper-V Linux VM (MobiLinuxVM) installed by "Docker for Windows".  | ||||||
|  | The <b>Windows Containers scenario has not been tested</b>, but the application should be able to run on Windows Containers, as well, as the .NET Core services have also been tested running on plain Windows (with no Docker). | ||||||
|  | The app was also partially tested on "Docker for Mac" using a development MacOS machine with .NET Core and VS Code installed. However, that is still a scenario using Linux containers running on the VM setup in the Mac by the "Docker for Windows" setup. | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| #Tools |  | ||||||
| #### Windows |  | ||||||
| <a href='https://github.com/docker/toolbox/releases/download/v1.12.3/DockerToolbox-1.12.3.exe'>Docker tools for windows</a> |  | ||||||
| 
 | 
 | ||||||
| ####Mac | ## Development Environment Setup | ||||||
| <a href='https://github.com/docker/toolbox/releases/download/v1.12.3/DockerToolbox-1.12.3.pkg'>Docker tools for Mac</a> | ### Requirements for Dec. 2016 version of eShopOnContainers | ||||||
| 
 | 
 | ||||||
| ##Set up Cpu and Memory | WINDOWS DEV MACHINE | ||||||
| In this demo we will run 3 instances of SQL Server, 6 asp.net core applications and 1 redis server it's important to set up properly the Cpu and Ram assigned to docker. This can be set, once installed docker in your device through the whale icon, right click, settings and in the Advanced option you will need to adjust the default to the new values shown in the image:  | - Visual Studio 2015 with latest Update | ||||||
|  | - .NET Core 1.0 (Including ASP.NET Core and VS Tooling) | ||||||
|  | - Bower and Gulp as global installs (See steps below) | ||||||
|  | - <a href='https://docs.docker.com/docker-for-windows/'>Docker for Windows</a> | ||||||
|  | 
 | ||||||
|  | MAC DEV MACHINE | ||||||
|  | - Visual Studio Code | ||||||
|  | - .NET Core 1.0 for Mac | ||||||
|  | - Bower and Gulp as global installs (See steps below) | ||||||
|  | - <a href='https://docs.docker.com/docker-for-mac/'>Docker for Mac</a> | ||||||
|  | 
 | ||||||
|  | ### Installing and configuring Docker in your development machine | ||||||
|  | 
 | ||||||
|  | #### Set needed assigned Memory and CPU to Docker | ||||||
|  | In this application (Mid-December 2016 version) we run 3 instances of SQL Server running as containers plus 6 ASP.NET Core apps/services and 1 Redis server all of them running as Docker containers. So it's important to set Docker up properly with enough memory RAM and CPU assigned to it or you will get difficult errors when starting the containers with "docker-compose up".  | ||||||
|  | Once Docker for Windows/Mac is installed in your machine, enter into its Settings and the Advanced menu option so you are able to adjust it to the new values (Memory: Around 7GB and CPU:4) as shown in the image. Usually you might need a 16GB or 12GB memory machine for this configuration. If you have a less powerful machine, you can try with a lower configuration and/or by not starting certain containers like the basket and Redis. But if you don't start all the containers, the application will not fully function properly, of course.  | ||||||
| 
 | 
 | ||||||
| <img src="img/docker_settings.png"> | <img src="img/docker_settings.png"> | ||||||
| 
 | 
 | ||||||
| #Demo | #### Bower and Gulp global installation | ||||||
| The demo scenario is based on a ecommerce shop, each service is a .net core web application (basket, catalog, ordering, identity) and this services are consumed by differents web and mobile applications. | Before generating the Docker images, and specifically when generating the web apps binaries with "dotnet publish" from the custom scripts (like when running the build-images.ps1 script from PowerShell or the build-images.sh from bash in a Mac), it needs to have access to the paths where you have installed Bower and Gulp. For that, the recommendation is to install Bower and Gulp with a global installation by running the following commands from command-line or bash: | ||||||
| 
 | 
 | ||||||
| MVC Application: Its an Mvc 6 development where you can find good samples about how to work with microservices in a MVC asp.net core application.  | `npm install -g bower`  | ||||||
| 
 | 
 | ||||||
| SPA Application: Developed with Angular2, Typescript and Mvc 6, is another different aproach in web on how to work in a Microservices oriented solution. | `npm install -g gulp` | ||||||
| 
 | 
 | ||||||
| Xamarin Application (Ios, Windows, Android): Its a client application that run in mobile devices (ios, android, windows) and you can find another example on how to build a microservices oriented application.  | Below you can see how those commands are run in Windows: | ||||||
| 
 | <img src="img/Bower_and_Gulp_setup.png"> | ||||||
| #Deploy goblal |  | ||||||
| In the global directory you will find the scripts needed to run and deploy the demo into your local docker infraestructure. The steps:  |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| - <a href='build-images.ps1'>build-images.ps1</a>  <b>Build .net applications and docker images</b>: This power shell script that you will find in the <u>root directory of the solution</u> is the responsible of building .net applications and package in a pub folder and use docker commands to build the images needed to run the previously packaged .net applications.  | ## Build, Ship, Run  | ||||||
|  | In the global directory you will find the scripts needed to build, deploy and run the application into your local Docker development machine. The steps are the following:  | ||||||
| 
 | 
 | ||||||
| - <b>Compose containers in your docker local VM</b>: Finally you have to open your favourite command tool <u>pointing to the root directory of the solution</u> where docker-compose.yml file is located and run the command  `docker-compose up` | ### Compile the .NET apps and Build the Docker images | ||||||
|  | - Open a PowerShell window in Windows, move to the root folder of your solution and run the <b>build-images.ps1</b> script file like in the following screenshot. | ||||||
|  | - This Power-Shell script that you will find in the <u>root directory of the solution</u> is responsible for building the .NET applications, copy the binaries in a pub folder and use Docker CLI commands to build the custom Docker images needed to run the containers. You can see how to run that PowerShell script in the screenshot below: | ||||||
|  | <img src="img/Generating_Docker_Images.png"> | ||||||
| 
 | 
 | ||||||
| #Run | - Once it finishes, you can check it out with Docker CLI if the images were generated correctly by typing in the PowerShell console the command: `docker images` | ||||||
| Once the deploy process of docker-compose finishes you have to be able to access the services in this urls from your machine: | <img src="img/list-of-images.png"> | ||||||
| - Web: http://localhost:5100 | Those Docker images are the ones you have available in your local image repository in your machine. | ||||||
|  | You might have additional images, but at least, you should see the following list of images which are 6 custom images starting with the prefix "eshop" which is the name of the image repo. The rest of the images that are not starting with "eshop" will probably be official base-images like the microsoft/aspnetcore or the SQL Server for Linux images. | ||||||
|  | 
 | ||||||
|  | ### Deploy containers into your Docker host | ||||||
|  | You can deploy Docker containers to a regularDocker host either by using the `docker run` command which need to be executed once per microservice, or by using the CLI tool `docker-compose up` which is very convenient for multi-container applications as it can spin-up all the multiple containers in your application with a single command. These are the steps: | ||||||
|  | - <b>Run your containers in your local host</b>: Open your favorite command tool (PowerShell od CommandLine in Windows / Bash in Mac) <u> and move to the root directory of the solution</u> where the docker-compose.yml file is located and run the command `docker-compose up`. When running "docker-compose up" you should see something similar to the following screenshot in the PowerShell command window, although it will much longer than that, also showing many internal SQL commands from the services when populating the first time the sample data. | ||||||
|  | `docker-compose up` | ||||||
|  | <img src="img/docker-compose-up-1.png"> | ||||||
|  | 
 | ||||||
|  | - Note that the first time you run any container (with docker run or docker-compose) it detects that it needs the base images we are using, like the SQL Server image and the Redis image, so it will pull or download those base images from the Internet, from the public repo at the Docker registry named DOCKER HUB, by pulling the "microsoft/mssql-server-linux" which is the base image for the SQL Server for Linux on containers, and the "library/redis" which is the base Redis image. Therefore, the first time you run docker-compose it might take a few minutes pulling those images before it spins up your custom containers. | ||||||
|  | The next time you run docker-compose up, since it'll have those base images already pulled/downloaded, it will just start the containers, like in the following screenshot: | ||||||
|  | <img src="img/docker-compose-up-2.png"> | ||||||
|  | 
 | ||||||
|  | - <b>Check out the containers running in your Docker host</b>:Once docker-compose up finishes after a few minutes, you will have that PowerShell showing the execution's output in a "wait state", so in order to ask to Docker about "how it went" and see what containers are running, you need to open a second PowerShell window and type "docker ps" so you'll see all the running containers, as shown in the following screenshot. | ||||||
|  | <img src="img/docker-ps-with-all-microservices.png">  | ||||||
|  | You can see the 6 custom containers running the microservices plus the 2 web applications. In adition you have the containers with the SQL databases and the Redis cache for the basket microservice data. | ||||||
|  | 
 | ||||||
|  | ### Test the application and the microservices | ||||||
|  | #### IMPORTANT: Modify your local "hosts" file by setting an IP related to the identity.service network name | ||||||
|  | - Due to the fact that when trying to authenticate against the STS (Security Token Service) container the browser is redirected to it from outside the docker host (your browser in your PC), it needs to have an IP reachable from outside the Docker Host. Therefore you need to add an entry like `10.0.75.1 identity.service` or `127.0.0.1 identity.service` to your <b>hosts</b> file in your local dev machine. | ||||||
|  | - If you don't want to hassle with it, just run the PowerShell script named `add-host-entry.ps1` from the solution root folder. | ||||||
|  | - If the STS were running in an external IP in a server, in the Internet or in any cloud like Azure, since that IP is reachable from anywhere, you wouldn't need to configure your hosts file. However, that IP would need to be updated into your docker-compose.yml file, in the identity.service URLs.  | ||||||
|  | #### Test the applications and microservices  | ||||||
|  | Once the deploy process of docker-compose finishes you should be able to access the services in the following URLs or connection string, from your dev machine: | ||||||
|  | - Web MVC: http://localhost:5100 | ||||||
| - Web Spa: http://localhost:5104 | - Web Spa: http://localhost:5104 | ||||||
| - Catalog service: http://localhost:5101 | - Catalog microservice: http://localhost:5101 | ||||||
| - Orders service: http://localhost:5102 | - Ordering microservice: http://localhost:5102 | ||||||
| - Basket service: http://localhost:5103 | - Basket microservice: http://localhost:5103 | ||||||
| - Identity service: http://localhost:5105 | - Identity microservice: http://localhost:5105 | ||||||
| - Orders data (SQL Server): Server=tcp:localhost,5432;Database=Microsoft.eShopOnContainers.Services.OrderingDb;User Id=sa;Password=Pass@word; | - Orders database (SQL Server): Server=tcp:localhost,5432;Database=Microsoft.eShopOnContainers.Services.OrderingDb;User Id=sa;Password=Pass@word; | ||||||
| - Catalog data (SQL Server): Server=tcp:localhost,5434;Database=CatalogDB;User Id=sa;Password=Pass@word | - Catalog database (SQL Server): Server=tcp:localhost,5434;Database=CatalogDB;User Id=sa;Password=Pass@word | ||||||
| - Identity data (SQL Server): Server=localhost,5433;Database=aspnet-Microsoft.eShopOnContainers;User Id=sa;Password=Pass@word | - ASP.NET Identity database (SQL Server): Server=localhost,5433;Database=aspnet-Microsoft.eShopOnContainers;User Id=sa;Password=Pass@word | ||||||
| - Basket data (Redis): listening in localhost:6379 | - Basket data (Redis): listening at localhost:6379 | ||||||
| 
 |  | ||||||
| #Deploy individiual services into docker |  | ||||||
| Under each project root you will find a readme.md file as this that describes how to run and deploy the service individually into a docker container. |  | ||||||
| 
 | 
 | ||||||
|  | #### Trying the WebMVC application with the DemoUser@microsoft.com user account | ||||||
|  | When you try the WebMVC application by using the url •Web MVC: http://localhost:5100, you'll be able to test the home page which is also the catalog page. But when trying to add any article to the basket you will get redirected to the login page which is handled by the STS microservice (Security Token Service). At this point, you could register your own user/customer or you can also use the a convenient default user/customer named DemoUser@microsoft.com so you don't need to register and it'll be faster. | ||||||
|  | The credentials are: | ||||||
|  | - User: demouser@microsoft.com | ||||||
|  | - Password: Pass@word1 | ||||||
|  | 
 | ||||||
|  | Below you can see the login page when providing those credentials. | ||||||
|  | <img src="img/login-demo-user.png"> | ||||||
|  | 
 | ||||||
|  | ### Deploying individiual services into docker | ||||||
|  | Under each project root you will find a readme.md file which describes how to run and deploy the service individually into a docker host. | ||||||
|  | 
 | ||||||
|  | > ### Note on Windows Containers | ||||||
|  | > As mentioned, the development and testing of this project was done on Docker Linux containers running in development machines with "Docker for Windows" and the default Hyper-V Linux VM (MobiLinuxVM) installed by "Docker for Windows".  | ||||||
|  | In order to run the application on Windows Containers you'd need to change the base images used by each container: | ||||||
|  | > - Official .NET Core base-image for Windows Containers, at Docker Hub: https://hub.docker.com/r/microsoft/dotnet/ (Using the Windows Nanoserver tag) | ||||||
|  | > - Official base-image for SQL Server on Windows Containers, at Docker Hub: https://hub.docker.com/r/microsoft/mssql-server-windows | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -16,7 +16,6 @@ dotnet restore $webPathToJson | |||||||
| dotnet build $webPathToJson | dotnet build $webPathToJson | ||||||
| dotnet publish $webPathToJson -o $webPathToPub | dotnet publish $webPathToJson -o $webPathToPub | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| # *** WebSPA image *** | # *** WebSPA image *** | ||||||
| $webSPAPathToJson = $scriptPath + "\src\Web\WebSPA\eShopOnContainers.WebSPA\project.json" | $webSPAPathToJson = $scriptPath + "\src\Web\WebSPA\eShopOnContainers.WebSPA\project.json" | ||||||
| Write-Host "webSPAPathToJson is $webSPAPathToJson" -ForegroundColor Yellow | Write-Host "webSPAPathToJson is $webSPAPathToJson" -ForegroundColor Yellow | ||||||
|  | |||||||
							
								
								
									
										69
									
								
								docker-compose.override.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,69 @@ | |||||||
|  | # | ||||||
|  | # docker-compose.override.yml is used to set up local configuration environment | ||||||
|  | # Things like the external ports to use or secrets/passwords depend on the  | ||||||
|  | # specific deployment environment you might be using. | ||||||
|  | # Further details and docs: https://docs.docker.com/compose/extends/  | ||||||
|  | # | ||||||
|  | 
 | ||||||
|  | version: '2' | ||||||
|  | 
 | ||||||
|  | services: | ||||||
|  | 
 | ||||||
|  | #  webmvc: | ||||||
|  | #    environment: | ||||||
|  | #      - CatalogUrl=http://catalog.api | ||||||
|  | #      - OrderingUrl=http://ordering.api:5102 | ||||||
|  |       #- IdentityUrl=http://104.40.62.65:5105           #Remote: VM Needs to have public access at 5105.  | ||||||
|  | #      - IdentityUrl=http://identity.service:5105        #Local: You need a entry in windows host file to run identity in local docker.  | ||||||
|  | #      - BasketUrl=http://basket.api:5103 | ||||||
|  | #    ports: | ||||||
|  | #      - "5100:5100" | ||||||
|  | 
 | ||||||
|  |   webspa: | ||||||
|  |     environment: | ||||||
|  |       - CatalogUrl=http://catalog.api | ||||||
|  |       - OrderingUrl=http://ordering.api | ||||||
|  |       #- IdentityUrl=http://104.40.62.65:5105           #Remote: VM Needs to have public access at 5105.  | ||||||
|  |       - IdentityUrl=http://identity.service:5105        #Local: You need a entry in windows host file to run identity in local docker.  | ||||||
|  |       - BasketUrl=http://basket.api:5103 | ||||||
|  |     ports: | ||||||
|  |       - "5104:80" | ||||||
|  | 
 | ||||||
|  |   basket.api: | ||||||
|  |     environment: | ||||||
|  |       - ConnectionString=basket.data | ||||||
|  |       #- identityUrl=http://104.40.62.65:5105           #Remote: VM Needs to have public access at 5105.  | ||||||
|  |       - identityUrl=http://identity.service:5105        #Local: You need a entry in windows host file to run identity in local docker.  | ||||||
|  |     ports: | ||||||
|  |       - "5103:5103" | ||||||
|  | 
 | ||||||
|  |   catalog.api: | ||||||
|  |     environment: | ||||||
|  |       - ConnectionString=Server=sql.data;Database=CatalogDB;User Id=sa;Password=Pass@word | ||||||
|  |     ports: | ||||||
|  |       - "5101:80" | ||||||
|  | 
 | ||||||
|  | #  ordering.api: | ||||||
|  | #    environment: | ||||||
|  | #      - ConnectionString=Server=sql.data;Database=Microsoft.eShopOnContainers.Services.OrderingDb;User Id=sa;Password=Pass@word | ||||||
|  | #      - identityUrl=http://identity.service:5105    #local | ||||||
|  |       #- identityUrl=http://104.40.62.65:5105       #remote | ||||||
|  | #    ports: | ||||||
|  | #      - "5102:5102" | ||||||
|  | 
 | ||||||
|  |   identity.service: | ||||||
|  |     environment: | ||||||
|  |       - SpaClient=http://localhost:5104 | ||||||
|  |       - ConnectionStrings__DefaultConnection=Server=sql.data;Database=aspnet-Microsoft.eShopOnContainers;User Id=sa;Password=Pass@word | ||||||
|  |       #- MvcClient=http://104.40.62.65:5100             #Remote: VM Needs to have public access at 5105.  | ||||||
|  |       - MvcClient=http://localhost:5100                 #Local: You need a entry in windows host file to run identity in local docker.  | ||||||
|  |                                                         #10.0.75.1:5105 CCE/TODO: try to avoid host entry.  | ||||||
|  |     ports: | ||||||
|  |       - "5105:5105" | ||||||
|  | 
 | ||||||
|  |   sql.data: | ||||||
|  |     environment: | ||||||
|  |       - SA_PASSWORD=Pass@word | ||||||
|  |       - ACCEPT_EULA=Y | ||||||
|  |     ports: | ||||||
|  |       - "5433:1433" | ||||||
| @ -1,108 +1,47 @@ | |||||||
|  | # | ||||||
|  | # docker-compose.yml is used to set up the base config per container to be deployed | ||||||
|  | # Take into account that when deploying, this base configuration is merged with the  | ||||||
|  | # configuration-per-environment specified at the docker-compose.override.yml | ||||||
|  | # Further details and docs: https://docs.docker.com/compose/extends/  | ||||||
|  | # | ||||||
| version: '2' | version: '2' | ||||||
| 
 | 
 | ||||||
| services: | services: | ||||||
|   webmvc: | #  webmvc: | ||||||
|     image: eshop/web | #    image: eshop/web | ||||||
|     build: | #    depends_on: | ||||||
|       context: . | #      - identity.service | ||||||
|       dockerfile: Dockerfile | #      - basket.api | ||||||
|     environment: |  | ||||||
|       - CatalogUrl=http://catalog.api |  | ||||||
|       - OrderingUrl=http://ordering.api |  | ||||||
|       #- IdentityUrl=http://104.40.62.65:5105           #Remote: VM Needs to have public access at 5105.  |  | ||||||
|       - IdentityUrl=http://identity.service:5105        #Local: You need a entry in windows host file to run identity in local docker.  |  | ||||||
|       - BasketUrl=http://basket.api |  | ||||||
|     ports: |  | ||||||
|       - "5100:5100" |  | ||||||
|     depends_on: |  | ||||||
|       - identity.service |  | ||||||
|       - basket.api |  | ||||||
| 
 | 
 | ||||||
|   webspa: |   webspa: | ||||||
|     image: eshop/webspa |     image: eshop/webspa | ||||||
|     build: |  | ||||||
|       context: . |  | ||||||
|       dockerfile: Dockerfile |  | ||||||
|     environment: |  | ||||||
|       - CatalogUrl=http://catalog.api |  | ||||||
|       - OrderingUrl=http://ordering.api |  | ||||||
|       #- IdentityUrl=http://104.40.62.65:5105           #Remote: VM Needs to have public access at 5105.  |  | ||||||
|       - IdentityUrl=http://identity.service:5105        #Local: You need a entry in windows host file to run identity in local docker.  |  | ||||||
|       - BasketUrl=http://basket.api |  | ||||||
|     ports: |  | ||||||
|       - "5104:80" |  | ||||||
|     depends_on: |     depends_on: | ||||||
|       - basket.api |       - basket.api | ||||||
|       - identity.service |       - identity.service | ||||||
| 
 | 
 | ||||||
|   identity.service: |  | ||||||
|     image: eshop/identity |  | ||||||
|     environment: |  | ||||||
|       - SpaClient=http://localhost:5104 |  | ||||||
|       - ConnectionString=Server=identity.data;Database=aspnet-Microsoft.eShopOnContainers;User Id=sa;Password=Pass@word |  | ||||||
|       #- MvcClient=http://104.40.62.65:5100             #Remote: VM Needs to have public access at 5105.  |  | ||||||
|       - MvcClient=http://localhost:5100                 #Local: You need a entry in windows host file to run identity in local docker.  |  | ||||||
|     ports: |  | ||||||
|       - "5105:5105" |  | ||||||
|     depends_on: |  | ||||||
|       - identity.data |  | ||||||
| 
 |  | ||||||
|   identity.data: |  | ||||||
|     image: microsoft/mssql-server-linux |  | ||||||
|     environment: |  | ||||||
|       - SA_PASSWORD=Pass@word |  | ||||||
|       - ACCEPT_EULA=Y |  | ||||||
|     ports: |  | ||||||
|       - "5433:1433" |  | ||||||
| 
 |  | ||||||
|   basket.api: |   basket.api: | ||||||
|     image: eshop/basket.api |     image: eshop/basket.api | ||||||
|     environment: |  | ||||||
|       - ConnectionString=basket.data |  | ||||||
|       #- identityUrl=http://104.40.62.65:5105           #Remote: VM Needs to have public access at 5105.  |  | ||||||
|       - identityUrl=http://identity.service:5105        #Local: You need a entry in windows host file to run identity in local docker.  |  | ||||||
|     build: |  | ||||||
|       context: . |  | ||||||
|       dockerfile: Dockerfile |  | ||||||
|     ports: |  | ||||||
|       - "5103:5103" |  | ||||||
|     depends_on: |     depends_on: | ||||||
|       - basket.data |       - basket.data | ||||||
|       - identity.service |       - identity.service | ||||||
| 
 | 
 | ||||||
|   basket.data: |  | ||||||
|     image: redis |  | ||||||
| 
 |  | ||||||
|   catalog.api: |   catalog.api: | ||||||
|     image: eshop/catalog.api |     image: eshop/catalog.api | ||||||
|     environment: |  | ||||||
|       - ConnectionString=Server=catalog.data;Database=CatalogDB;User Id=sa;Password=Pass@word |  | ||||||
|     ports: |  | ||||||
|       - "5101:80" |  | ||||||
|     depends_on: |     depends_on: | ||||||
|       - catalog.data |       - sql.data | ||||||
| 
 | 
 | ||||||
|   catalog.data: | #  ordering.api: | ||||||
|     image: microsoft/mssql-server-linux | #    image: eshop/ordering.api | ||||||
|     environment: | #    depends_on: | ||||||
|       - SA_PASSWORD=Pass@word | #      - sql.data | ||||||
|       - ACCEPT_EULA=Y |  | ||||||
|     ports: |  | ||||||
|       - "5434:1433" |  | ||||||
| 
 | 
 | ||||||
|   ordering.api: |   identity.service: | ||||||
|     image: eshop/ordering.api |     image: eshop/identity | ||||||
|     environment: |  | ||||||
|       - ConnectionString=Server=ordering.data;Database=Microsoft.eShopOnContainers.Services.OrderingDb;User Id=sa;Password=Pass@word |  | ||||||
|     ports: |  | ||||||
|       - "5102:80" |  | ||||||
|     depends_on: |     depends_on: | ||||||
|       - ordering.data |       - sql.data | ||||||
| 
 | 
 | ||||||
|   ordering.data: |   sql.data: | ||||||
|     image: microsoft/mssql-server-linux |     image: microsoft/mssql-server-linux | ||||||
|     environment: | 
 | ||||||
|       - SA_PASSWORD=Pass@word |   basket.data: | ||||||
|       - ACCEPT_EULA=Y |     image: redis | ||||||
|     ports: |  | ||||||
|       - "5432:1433" |  | ||||||
|  | |||||||
							
								
								
									
										515
									
								
								eShopOnContainers-MobileApps.sln
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,515 @@ | |||||||
|  |  | ||||||
|  | Microsoft Visual Studio Solution File, Format Version 12.00 | ||||||
|  | # Visual Studio 14 | ||||||
|  | VisualStudioVersion = 14.0.25420.1 | ||||||
|  | MinimumVisualStudioVersion = 10.0.40219.1 | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "src", "src", "{932D8224-11F6-4D07-B109-DA28AD288A63}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{3AF739CD-81D8-428D-A08A-0A58372DEBF6}" | ||||||
|  | 	ProjectSection(SolutionItems) = preProject | ||||||
|  | 		docker-compose.yml = docker-compose.yml | ||||||
|  | 		global.json = global.json | ||||||
|  | 		NuGet.config = NuGet.config | ||||||
|  | 	EndProjectSection | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Mobile Apps", "Mobile Apps", "{F61357CE-1CC2-410E-8776-B16EEBC98EB8}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "test", "test", "{A857AD10-40FF-4303-BEC2-FF1C58D5735E}" | ||||||
|  | EndProject | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.Core", "src\Mobile\eShopOnContainers\eShopOnContainers.Core\eShopOnContainers.Core.csproj", "{65116D1C-145B-4693-ABDA-F0FB6F425191}" | ||||||
|  | EndProject | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.Droid", "src\Mobile\eShopOnContainers\eShopOnContainers.Droid\eShopOnContainers.Droid.csproj", "{62DBB163-9CA9-4818-B48B-13233DF37C24}" | ||||||
|  | EndProject | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.iOS", "src\Mobile\eShopOnContainers\eShopOnContainers.iOS\eShopOnContainers.iOS.csproj", "{6EEB23DC-7063-4444-9AF8-90DF24F549C0}" | ||||||
|  | EndProject | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.Windows", "src\Mobile\eShopOnContainers\eShopOnContainers.Windows\eShopOnContainers.Windows.csproj", "{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Shared Code", "Shared Code", "{778289CA-31F7-4464-8C2A-612EE846F8A7}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Targets", "Targets", "{9CC7814B-72A6-465B-A61C-57B512DEE303}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Mobile Apps", "Mobile Apps", "{B7B1D395-4E06-4036-BE86-C216756B9367}" | ||||||
|  | EndProject | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.UnitTests", "src\Mobile\eShopOnContainers\eShopOnContainers.UnitTests\eShopOnContainers.UnitTests.csproj", "{F7B6A162-BC4D-4924-B16A-713F9B0344E7}" | ||||||
|  | EndProject | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.TestRunner.Droid", "src\Mobile\eShopOnContainers\eShopOnContainers.TestRunner.Droid\eShopOnContainers.TestRunner.Droid.csproj", "{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}" | ||||||
|  | EndProject | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.TestRunner.Windows", "src\Mobile\eShopOnContainers\eShopOnContainers.TestRunner.Windows\eShopOnContainers.TestRunner.Windows.csproj", "{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}" | ||||||
|  | EndProject | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.TestRunner.iOS", "src\Mobile\eShopOnContainers\eShopOnContainers.TestRunner.iOS\eShopOnContainers.TestRunner.iOS.csproj", "{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}" | ||||||
|  | EndProject | ||||||
|  | Global | ||||||
|  | 	GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||||||
|  | 		Ad-Hoc|Any CPU = Ad-Hoc|Any CPU | ||||||
|  | 		Ad-Hoc|ARM = Ad-Hoc|ARM | ||||||
|  | 		Ad-Hoc|iPhone = Ad-Hoc|iPhone | ||||||
|  | 		Ad-Hoc|iPhoneSimulator = Ad-Hoc|iPhoneSimulator | ||||||
|  | 		Ad-Hoc|x64 = Ad-Hoc|x64 | ||||||
|  | 		Ad-Hoc|x86 = Ad-Hoc|x86 | ||||||
|  | 		AppStore|Any CPU = AppStore|Any CPU | ||||||
|  | 		AppStore|ARM = AppStore|ARM | ||||||
|  | 		AppStore|iPhone = AppStore|iPhone | ||||||
|  | 		AppStore|iPhoneSimulator = AppStore|iPhoneSimulator | ||||||
|  | 		AppStore|x64 = AppStore|x64 | ||||||
|  | 		AppStore|x86 = AppStore|x86 | ||||||
|  | 		Debug|Any CPU = Debug|Any CPU | ||||||
|  | 		Debug|ARM = Debug|ARM | ||||||
|  | 		Debug|iPhone = Debug|iPhone | ||||||
|  | 		Debug|iPhoneSimulator = Debug|iPhoneSimulator | ||||||
|  | 		Debug|x64 = Debug|x64 | ||||||
|  | 		Debug|x86 = Debug|x86 | ||||||
|  | 		Release|Any CPU = Release|Any CPU | ||||||
|  | 		Release|ARM = Release|ARM | ||||||
|  | 		Release|iPhone = Release|iPhone | ||||||
|  | 		Release|iPhoneSimulator = Release|iPhoneSimulator | ||||||
|  | 		Release|x64 = Release|x64 | ||||||
|  | 		Release|x86 = Release|x86 | ||||||
|  | 	EndGlobalSection | ||||||
|  | 	GlobalSection(ProjectConfigurationPlatforms) = postSolution | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Ad-Hoc|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.AppStore|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Debug|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191}.Release|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|Any CPU.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|ARM.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|iPhone.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|iPhoneSimulator.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|x64.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Ad-Hoc|x86.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|Any CPU.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|ARM.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|iPhone.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|iPhoneSimulator.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|x64.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.AppStore|x86.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|Any CPU.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|ARM.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|iPhone.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|iPhoneSimulator.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|x64.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Debug|x86.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|Any CPU.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|ARM.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|iPhone.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|iPhoneSimulator.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|x64.Deploy.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24}.Release|x86.Deploy.0 = Release|Any CPU | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Ad-Hoc|Any CPU.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Ad-Hoc|ARM.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Ad-Hoc|iPhone.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Ad-Hoc|iPhone.Build.0 = Ad-Hoc|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Ad-Hoc|iPhoneSimulator | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Ad-Hoc|iPhoneSimulator.Build.0 = Ad-Hoc|iPhoneSimulator | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Ad-Hoc|x64.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Ad-Hoc|x86.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.AppStore|Any CPU.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.AppStore|ARM.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.AppStore|iPhone.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.AppStore|iPhone.Build.0 = AppStore|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.AppStore|iPhoneSimulator.ActiveCfg = AppStore|iPhoneSimulator | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.AppStore|iPhoneSimulator.Build.0 = AppStore|iPhoneSimulator | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.AppStore|x64.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.AppStore|x86.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Debug|Any CPU.ActiveCfg = Debug|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Debug|ARM.ActiveCfg = Debug|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Debug|iPhone.ActiveCfg = Debug|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Debug|iPhone.Build.0 = Debug|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Debug|iPhoneSimulator.ActiveCfg = Debug|iPhoneSimulator | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Debug|iPhoneSimulator.Build.0 = Debug|iPhoneSimulator | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Debug|x64.ActiveCfg = Debug|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Debug|x86.ActiveCfg = Debug|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Release|Any CPU.ActiveCfg = Release|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Release|ARM.ActiveCfg = Release|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Release|iPhone.ActiveCfg = Release|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Release|iPhone.Build.0 = Release|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Release|iPhoneSimulator.ActiveCfg = Release|iPhoneSimulator | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Release|iPhoneSimulator.Build.0 = Release|iPhoneSimulator | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Release|x64.ActiveCfg = Release|iPhone | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0}.Release|x86.ActiveCfg = Release|iPhone | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|Any CPU.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|Any CPU.Build.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|Any CPU.Deploy.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|ARM.ActiveCfg = Release|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|ARM.Build.0 = Release|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|ARM.Deploy.0 = Release|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|iPhone.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|iPhone.Build.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|iPhone.Deploy.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|iPhoneSimulator.Build.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|iPhoneSimulator.Deploy.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|x64.ActiveCfg = Release|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|x64.Build.0 = Release|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|x64.Deploy.0 = Release|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|x86.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|x86.Build.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Ad-Hoc|x86.Deploy.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|Any CPU.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|Any CPU.Build.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|Any CPU.Deploy.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|ARM.ActiveCfg = Release|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|ARM.Build.0 = Release|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|ARM.Deploy.0 = Release|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|iPhone.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|iPhone.Build.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|iPhone.Deploy.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|iPhoneSimulator.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|iPhoneSimulator.Build.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|iPhoneSimulator.Deploy.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|x64.ActiveCfg = Release|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|x64.Build.0 = Release|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|x64.Deploy.0 = Release|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|x86.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|x86.Build.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.AppStore|x86.Deploy.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|Any CPU.ActiveCfg = Debug|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|ARM.ActiveCfg = Debug|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|ARM.Build.0 = Debug|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|ARM.Deploy.0 = Debug|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|iPhone.ActiveCfg = Debug|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|iPhone.Build.0 = Debug|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|iPhone.Deploy.0 = Debug|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|iPhoneSimulator.ActiveCfg = Debug|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|x64.ActiveCfg = Debug|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|x64.Build.0 = Debug|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|x64.Deploy.0 = Debug|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|x86.ActiveCfg = Debug|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|x86.Build.0 = Debug|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Debug|x86.Deploy.0 = Debug|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|Any CPU.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|ARM.ActiveCfg = Release|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|ARM.Build.0 = Release|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|ARM.Deploy.0 = Release|ARM | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|iPhone.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|iPhoneSimulator.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|x64.ActiveCfg = Release|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|x64.Build.0 = Release|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|x64.Deploy.0 = Release|x64 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|x86.ActiveCfg = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|x86.Build.0 = Release|x86 | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B}.Release|x86.Deploy.0 = Release|x86 | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Ad-Hoc|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.AppStore|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Debug|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7}.Release|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|Any CPU.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|ARM.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|iPhone.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|iPhoneSimulator.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|x64.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Ad-Hoc|x86.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|Any CPU.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|ARM.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|iPhone.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|iPhoneSimulator.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|x64.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.AppStore|x86.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|Any CPU.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|ARM.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|iPhone.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|iPhoneSimulator.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|x64.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Debug|x86.Deploy.0 = Debug|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|Any CPU.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|ARM.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|iPhone.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|iPhoneSimulator.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|x64.Deploy.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1}.Release|x86.Deploy.0 = Release|Any CPU | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|Any CPU.ActiveCfg = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|Any CPU.Build.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|Any CPU.Deploy.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|ARM.ActiveCfg = Release|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|ARM.Build.0 = Release|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|ARM.Deploy.0 = Release|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|iPhone.ActiveCfg = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|iPhone.Build.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|iPhone.Deploy.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|iPhoneSimulator.Build.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|iPhoneSimulator.Deploy.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|x64.ActiveCfg = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|x64.Build.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|x64.Deploy.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|x86.ActiveCfg = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|x86.Build.0 = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Ad-Hoc|x86.Deploy.0 = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|Any CPU.ActiveCfg = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|Any CPU.Build.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|Any CPU.Deploy.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|ARM.ActiveCfg = Release|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|ARM.Build.0 = Release|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|ARM.Deploy.0 = Release|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|iPhone.ActiveCfg = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|iPhone.Build.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|iPhone.Deploy.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|iPhoneSimulator.ActiveCfg = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|iPhoneSimulator.Build.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|iPhoneSimulator.Deploy.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|x64.ActiveCfg = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|x64.Build.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|x64.Deploy.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|x86.ActiveCfg = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|x86.Build.0 = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.AppStore|x86.Deploy.0 = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|Any CPU.ActiveCfg = Debug|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|ARM.ActiveCfg = Debug|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|ARM.Build.0 = Debug|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|ARM.Deploy.0 = Debug|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|iPhone.ActiveCfg = Debug|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|iPhone.Build.0 = Debug|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|iPhone.Deploy.0 = Debug|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|iPhoneSimulator.ActiveCfg = Debug|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|x64.ActiveCfg = Debug|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|x64.Build.0 = Debug|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|x64.Deploy.0 = Debug|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|x86.ActiveCfg = Debug|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|x86.Build.0 = Debug|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Debug|x86.Deploy.0 = Debug|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|Any CPU.ActiveCfg = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|ARM.ActiveCfg = Release|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|ARM.Build.0 = Release|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|ARM.Deploy.0 = Release|ARM | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|iPhone.ActiveCfg = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|iPhoneSimulator.ActiveCfg = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|x64.ActiveCfg = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|x64.Build.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|x64.Deploy.0 = Release|x64 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|x86.ActiveCfg = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|x86.Build.0 = Release|x86 | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F}.Release|x86.Deploy.0 = Release|x86 | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Ad-Hoc|Any CPU.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Ad-Hoc|ARM.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Ad-Hoc|iPhone.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Ad-Hoc|iPhone.Build.0 = Ad-Hoc|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Ad-Hoc|iPhoneSimulator | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Ad-Hoc|iPhoneSimulator.Build.0 = Ad-Hoc|iPhoneSimulator | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Ad-Hoc|x64.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Ad-Hoc|x86.ActiveCfg = Ad-Hoc|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.AppStore|Any CPU.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.AppStore|ARM.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.AppStore|iPhone.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.AppStore|iPhone.Build.0 = AppStore|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.AppStore|iPhoneSimulator.ActiveCfg = AppStore|iPhoneSimulator | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.AppStore|iPhoneSimulator.Build.0 = AppStore|iPhoneSimulator | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.AppStore|x64.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.AppStore|x86.ActiveCfg = AppStore|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Debug|Any CPU.ActiveCfg = Debug|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Debug|ARM.ActiveCfg = Debug|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Debug|iPhone.ActiveCfg = Debug|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Debug|iPhone.Build.0 = Debug|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Debug|iPhoneSimulator.ActiveCfg = Debug|iPhoneSimulator | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Debug|iPhoneSimulator.Build.0 = Debug|iPhoneSimulator | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Debug|x64.ActiveCfg = Debug|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Debug|x86.ActiveCfg = Debug|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Release|Any CPU.ActiveCfg = Release|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Release|ARM.ActiveCfg = Release|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Release|iPhone.ActiveCfg = Release|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Release|iPhone.Build.0 = Release|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Release|iPhoneSimulator.ActiveCfg = Release|iPhoneSimulator | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Release|iPhoneSimulator.Build.0 = Release|iPhoneSimulator | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Release|x64.ActiveCfg = Release|iPhone | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3}.Release|x86.ActiveCfg = Release|iPhone | ||||||
|  | 	EndGlobalSection | ||||||
|  | 	GlobalSection(SolutionProperties) = preSolution | ||||||
|  | 		HideSolutionNode = FALSE | ||||||
|  | 	EndGlobalSection | ||||||
|  | 	GlobalSection(NestedProjects) = preSolution | ||||||
|  | 		{F61357CE-1CC2-410E-8776-B16EEBC98EB8} = {932D8224-11F6-4D07-B109-DA28AD288A63} | ||||||
|  | 		{65116D1C-145B-4693-ABDA-F0FB6F425191} = {778289CA-31F7-4464-8C2A-612EE846F8A7} | ||||||
|  | 		{62DBB163-9CA9-4818-B48B-13233DF37C24} = {9CC7814B-72A6-465B-A61C-57B512DEE303} | ||||||
|  | 		{6EEB23DC-7063-4444-9AF8-90DF24F549C0} = {9CC7814B-72A6-465B-A61C-57B512DEE303} | ||||||
|  | 		{C3C1E2CF-B1F7-4654-BBDC-50143DB22E0B} = {9CC7814B-72A6-465B-A61C-57B512DEE303} | ||||||
|  | 		{778289CA-31F7-4464-8C2A-612EE846F8A7} = {F61357CE-1CC2-410E-8776-B16EEBC98EB8} | ||||||
|  | 		{9CC7814B-72A6-465B-A61C-57B512DEE303} = {F61357CE-1CC2-410E-8776-B16EEBC98EB8} | ||||||
|  | 		{B7B1D395-4E06-4036-BE86-C216756B9367} = {A857AD10-40FF-4303-BEC2-FF1C58D5735E} | ||||||
|  | 		{F7B6A162-BC4D-4924-B16A-713F9B0344E7} = {B7B1D395-4E06-4036-BE86-C216756B9367} | ||||||
|  | 		{A289A7F0-ACD8-42AE-87B6-AB1AFD310BF1} = {B7B1D395-4E06-4036-BE86-C216756B9367} | ||||||
|  | 		{02680C26-CA1D-4D9D-A7E3-D66AF5BE6F2F} = {B7B1D395-4E06-4036-BE86-C216756B9367} | ||||||
|  | 		{B68C2B56-7581-46AE-B55D-D25DDFD3BFE3} = {B7B1D395-4E06-4036-BE86-C216756B9367} | ||||||
|  | 	EndGlobalSection | ||||||
|  | EndGlobal | ||||||
							
								
								
									
										419
									
								
								eShopOnContainers-ServicesAndWebApps.sln
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,419 @@ | |||||||
|  |  | ||||||
|  | Microsoft Visual Studio Solution File, Format Version 12.00 | ||||||
|  | # Visual Studio 14 | ||||||
|  | VisualStudioVersion = 14.0.25420.1 | ||||||
|  | MinimumVisualStudioVersion = 10.0.40219.1 | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "src", "src", "{932D8224-11F6-4D07-B109-DA28AD288A63}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{3AF739CD-81D8-428D-A08A-0A58372DEBF6}" | ||||||
|  | 	ProjectSection(SolutionItems) = preProject | ||||||
|  | 		docker-compose.override.yml = docker-compose.override.yml | ||||||
|  | 		docker-compose.yml = docker-compose.yml | ||||||
|  | 		global.json = global.json | ||||||
|  | 		NuGet.config = NuGet.config | ||||||
|  | 	EndProjectSection | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Services", "Services", "{91CF7717-08AB-4E65-B10E-0B426F01E2E8}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Web Apps", "Web Apps", "{E279BF0F-7F66-4F3A-A3AB-2CDA66C1CD04}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Catalog", "Catalog", "{326A7FB3-5295-468C-A4FE-67DCB823E1E5}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Basket", "Basket", "{BF3EF4F3-E4F5-41DA-9D2D-57223687D1A8}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Ordering", "Ordering", "{0BD0DB92-2D98-44D9-9AC0-C59186D59B0B}" | ||||||
|  | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Basket.API", "src\Services\Basket\Basket.API\Basket.API.xproj", "{2110CBB0-3B38-4EE4-A743-DF6968D80D90}" | ||||||
|  | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Catalog.API", "src\Services\Catalog\Catalog.API\Catalog.API.xproj", "{42681D9D-750A-4DF7-BD9F-9292CFD5C253}" | ||||||
|  | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Ordering.API", "src\Services\Ordering\Ordering.API\Ordering.API.xproj", "{231226CE-690B-4979-8870-9A79D80928E2}" | ||||||
|  | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Ordering.Domain", "src\Services\Ordering\Ordering.Domain\Ordering.Domain.xproj", "{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "test", "test", "{A857AD10-40FF-4303-BEC2-FF1C58D5735E}" | ||||||
|  | EndProject | ||||||
|  | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Services", "Services", "{EF0337F2-ED00-4643-89FD-EE10863F1870}" | ||||||
|  | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "eShopOnContainers.WebMVC", "src\Web\WebMVC\eShopOnContainers.WebMVC.xproj", "{F0333D8E-0B27-42B7-B2C6-78F3657624E2}" | ||||||
|  | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "eShopOnContainers.WebSPA", "src\Web\WebSPA\eShopOnContainers.WebSPA\eShopOnContainers.WebSPA.xproj", "{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}" | ||||||
|  | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Ordering.Application", "src\Services\Ordering\Ordering.Application\Ordering.Application.xproj", "{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}" | ||||||
|  | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Ordering.Infrastructure", "src\Services\Ordering\Ordering.Infrastructure\Ordering.Infrastructure.xproj", "{95F1F07C-4D92-4742-BD07-E5B805AAB651}" | ||||||
|  | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "FunctionalTests", "test\Services\FunctionalTests\FunctionalTests.xproj", "{621E7211-58D0-45FD-9600-1CB490BD930E}" | ||||||
|  | EndProject | ||||||
|  | Global | ||||||
|  | 	GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||||||
|  | 		Ad-Hoc|Any CPU = Ad-Hoc|Any CPU | ||||||
|  | 		Ad-Hoc|ARM = Ad-Hoc|ARM | ||||||
|  | 		Ad-Hoc|iPhone = Ad-Hoc|iPhone | ||||||
|  | 		Ad-Hoc|iPhoneSimulator = Ad-Hoc|iPhoneSimulator | ||||||
|  | 		Ad-Hoc|x64 = Ad-Hoc|x64 | ||||||
|  | 		Ad-Hoc|x86 = Ad-Hoc|x86 | ||||||
|  | 		AppStore|Any CPU = AppStore|Any CPU | ||||||
|  | 		AppStore|ARM = AppStore|ARM | ||||||
|  | 		AppStore|iPhone = AppStore|iPhone | ||||||
|  | 		AppStore|iPhoneSimulator = AppStore|iPhoneSimulator | ||||||
|  | 		AppStore|x64 = AppStore|x64 | ||||||
|  | 		AppStore|x86 = AppStore|x86 | ||||||
|  | 		Debug|Any CPU = Debug|Any CPU | ||||||
|  | 		Debug|ARM = Debug|ARM | ||||||
|  | 		Debug|iPhone = Debug|iPhone | ||||||
|  | 		Debug|iPhoneSimulator = Debug|iPhoneSimulator | ||||||
|  | 		Debug|x64 = Debug|x64 | ||||||
|  | 		Debug|x86 = Debug|x86 | ||||||
|  | 		Release|Any CPU = Release|Any CPU | ||||||
|  | 		Release|ARM = Release|ARM | ||||||
|  | 		Release|iPhone = Release|iPhone | ||||||
|  | 		Release|iPhoneSimulator = Release|iPhoneSimulator | ||||||
|  | 		Release|x64 = Release|x64 | ||||||
|  | 		Release|x86 = Release|x86 | ||||||
|  | 	EndGlobalSection | ||||||
|  | 	GlobalSection(ProjectConfigurationPlatforms) = postSolution | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.AppStore|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.AppStore|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.AppStore|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.AppStore|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.AppStore|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.AppStore|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.AppStore|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.AppStore|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.AppStore|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.AppStore|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.AppStore|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.AppStore|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.AppStore|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.AppStore|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.AppStore|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.AppStore|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.AppStore|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.AppStore|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.AppStore|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.AppStore|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.AppStore|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.AppStore|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.AppStore|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.AppStore|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.AppStore|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Ad-Hoc|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.AppStore|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Debug|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2}.Release|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Ad-Hoc|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.AppStore|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Debug|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7}.Release|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Ad-Hoc|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.AppStore|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Debug|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651}.Release|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|x86.Build.0 = Release|Any CPU | ||||||
|  | 	EndGlobalSection | ||||||
|  | 	GlobalSection(SolutionProperties) = preSolution | ||||||
|  | 		HideSolutionNode = FALSE | ||||||
|  | 	EndGlobalSection | ||||||
|  | 	GlobalSection(NestedProjects) = preSolution | ||||||
|  | 		{91CF7717-08AB-4E65-B10E-0B426F01E2E8} = {932D8224-11F6-4D07-B109-DA28AD288A63} | ||||||
|  | 		{E279BF0F-7F66-4F3A-A3AB-2CDA66C1CD04} = {932D8224-11F6-4D07-B109-DA28AD288A63} | ||||||
|  | 		{326A7FB3-5295-468C-A4FE-67DCB823E1E5} = {91CF7717-08AB-4E65-B10E-0B426F01E2E8} | ||||||
|  | 		{BF3EF4F3-E4F5-41DA-9D2D-57223687D1A8} = {91CF7717-08AB-4E65-B10E-0B426F01E2E8} | ||||||
|  | 		{0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} = {91CF7717-08AB-4E65-B10E-0B426F01E2E8} | ||||||
|  | 		{2110CBB0-3B38-4EE4-A743-DF6968D80D90} = {BF3EF4F3-E4F5-41DA-9D2D-57223687D1A8} | ||||||
|  | 		{42681D9D-750A-4DF7-BD9F-9292CFD5C253} = {326A7FB3-5295-468C-A4FE-67DCB823E1E5} | ||||||
|  | 		{231226CE-690B-4979-8870-9A79D80928E2} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | ||||||
|  | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | ||||||
|  | 		{EF0337F2-ED00-4643-89FD-EE10863F1870} = {A857AD10-40FF-4303-BEC2-FF1C58D5735E} | ||||||
|  | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2} = {E279BF0F-7F66-4F3A-A3AB-2CDA66C1CD04} | ||||||
|  | 		{9842DB3A-1391-48C7-A49C-2FABD0A18AC2} = {E279BF0F-7F66-4F3A-A3AB-2CDA66C1CD04} | ||||||
|  | 		{4193CAA3-A1C3-4818-A06F-A2D85FDE77E7} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | ||||||
|  | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E} = {EF0337F2-ED00-4643-89FD-EE10863F1870} | ||||||
|  | 	EndGlobalSection | ||||||
|  | EndGlobal | ||||||
| @ -7,6 +7,7 @@ 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.override.yml = docker-compose.override.yml | ||||||
| 		docker-compose.yml = docker-compose.yml | 		docker-compose.yml = docker-compose.yml | ||||||
| 		global.json = global.json | 		global.json = global.json | ||||||
| 		NuGet.config = NuGet.config | 		NuGet.config = NuGet.config | ||||||
| @ -36,8 +37,6 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "test", "test", "{A857AD10-4 | |||||||
| EndProject | EndProject | ||||||
| Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Services", "Services", "{EF0337F2-ED00-4643-89FD-EE10863F1870}" | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Services", "Services", "{EF0337F2-ED00-4643-89FD-EE10863F1870}" | ||||||
| EndProject | EndProject | ||||||
| Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "Ordering.Test", "test\Services\Ordering.Test\Ordering.Test.xproj", "{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}" |  | ||||||
| EndProject |  | ||||||
| Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "eShopOnContainers.WebMVC", "src\Web\WebMVC\eShopOnContainers.WebMVC.xproj", "{F0333D8E-0B27-42B7-B2C6-78F3657624E2}" | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "eShopOnContainers.WebMVC", "src\Web\WebMVC\eShopOnContainers.WebMVC.xproj", "{F0333D8E-0B27-42B7-B2C6-78F3657624E2}" | ||||||
| EndProject | EndProject | ||||||
| Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.Core", "src\Mobile\eShopOnContainers\eShopOnContainers.Core\eShopOnContainers.Core.csproj", "{65116D1C-145B-4693-ABDA-F0FB6F425191}" | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "eShopOnContainers.Core", "src\Mobile\eShopOnContainers\eShopOnContainers.Core\eShopOnContainers.Core.csproj", "{65116D1C-145B-4693-ABDA-F0FB6F425191}" | ||||||
| @ -72,6 +71,8 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Identity", "Identity", "{02 | |||||||
| EndProject | EndProject | ||||||
| Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "eShopOnContainers.Identity", "src\Services\Identity\eShopOnContainers.Identity\eShopOnContainers.Identity.xproj", "{A579E108-5445-403D-A407-339AC4D1611B}" | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "eShopOnContainers.Identity", "src\Services\Identity\eShopOnContainers.Identity\eShopOnContainers.Identity.xproj", "{A579E108-5445-403D-A407-339AC4D1611B}" | ||||||
| EndProject | EndProject | ||||||
|  | Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "FunctionalTests", "test\Services\FunctionalTests\FunctionalTests.xproj", "{621E7211-58D0-45FD-9600-1CB490BD930E}" | ||||||
|  | EndProject | ||||||
| Global | Global | ||||||
| 	GlobalSection(SolutionConfigurationPlatforms) = preSolution | 	GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||||||
| 		Ad-Hoc|Any CPU = Ad-Hoc|Any CPU | 		Ad-Hoc|Any CPU = Ad-Hoc|Any CPU | ||||||
| @ -204,32 +205,6 @@ Global | |||||||
| 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
| 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|x64.ActiveCfg = Release|Any CPU | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
| 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|x86.ActiveCfg = Release|Any CPU | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.AppStore|Any CPU.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.AppStore|ARM.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.AppStore|iPhone.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.AppStore|x64.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.AppStore|x86.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Debug|Any CPU.ActiveCfg = Debug|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Debug|Any CPU.Build.0 = Debug|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Debug|ARM.ActiveCfg = Debug|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Debug|iPhone.ActiveCfg = Debug|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Debug|x64.ActiveCfg = Debug|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Debug|x86.ActiveCfg = Debug|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Release|Any CPU.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Release|Any CPU.Build.0 = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Release|ARM.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Release|iPhone.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Release|x64.ActiveCfg = Release|Any CPU |  | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967}.Release|x86.ActiveCfg = Release|Any CPU |  | ||||||
| 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU | ||||||
| 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU | ||||||
| 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU | ||||||
| @ -876,6 +851,54 @@ Global | |||||||
| 		{A579E108-5445-403D-A407-339AC4D1611B}.Release|x64.Build.0 = Release|Any CPU | 		{A579E108-5445-403D-A407-339AC4D1611B}.Release|x64.Build.0 = Release|Any CPU | ||||||
| 		{A579E108-5445-403D-A407-339AC4D1611B}.Release|x86.ActiveCfg = Release|Any CPU | 		{A579E108-5445-403D-A407-339AC4D1611B}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
| 		{A579E108-5445-403D-A407-339AC4D1611B}.Release|x86.Build.0 = Release|Any CPU | 		{A579E108-5445-403D-A407-339AC4D1611B}.Release|x86.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Ad-Hoc|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.AppStore|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|ARM.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|ARM.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|iPhone.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|iPhone.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|x64.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|x64.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|x86.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Debug|x86.Build.0 = Debug|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|ARM.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|ARM.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|iPhone.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|iPhone.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|iPhoneSimulator.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|x64.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|x64.Build.0 = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|x86.ActiveCfg = Release|Any CPU | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E}.Release|x86.Build.0 = Release|Any CPU | ||||||
| 	EndGlobalSection | 	EndGlobalSection | ||||||
| 	GlobalSection(SolutionProperties) = preSolution | 	GlobalSection(SolutionProperties) = preSolution | ||||||
| 		HideSolutionNode = FALSE | 		HideSolutionNode = FALSE | ||||||
| @ -892,7 +915,6 @@ Global | |||||||
| 		{231226CE-690B-4979-8870-9A79D80928E2} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | 		{231226CE-690B-4979-8870-9A79D80928E2} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | ||||||
| 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | 		{F5598DCB-6DDE-4661-AD9D-A55612DA7E76} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | ||||||
| 		{EF0337F2-ED00-4643-89FD-EE10863F1870} = {A857AD10-40FF-4303-BEC2-FF1C58D5735E} | 		{EF0337F2-ED00-4643-89FD-EE10863F1870} = {A857AD10-40FF-4303-BEC2-FF1C58D5735E} | ||||||
| 		{A0AFC432-3846-4B4E-BD8E-3C8C896F4967} = {EF0337F2-ED00-4643-89FD-EE10863F1870} |  | ||||||
| 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2} = {E279BF0F-7F66-4F3A-A3AB-2CDA66C1CD04} | 		{F0333D8E-0B27-42B7-B2C6-78F3657624E2} = {E279BF0F-7F66-4F3A-A3AB-2CDA66C1CD04} | ||||||
| 		{65116D1C-145B-4693-ABDA-F0FB6F425191} = {778289CA-31F7-4464-8C2A-612EE846F8A7} | 		{65116D1C-145B-4693-ABDA-F0FB6F425191} = {778289CA-31F7-4464-8C2A-612EE846F8A7} | ||||||
| 		{62DBB163-9CA9-4818-B48B-13233DF37C24} = {9CC7814B-72A6-465B-A61C-57B512DEE303} | 		{62DBB163-9CA9-4818-B48B-13233DF37C24} = {9CC7814B-72A6-465B-A61C-57B512DEE303} | ||||||
| @ -910,5 +932,6 @@ Global | |||||||
| 		{95F1F07C-4D92-4742-BD07-E5B805AAB651} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | 		{95F1F07C-4D92-4742-BD07-E5B805AAB651} = {0BD0DB92-2D98-44D9-9AC0-C59186D59B0B} | ||||||
| 		{02DF7FEE-C302-433D-A6CD-237A2569F236} = {91CF7717-08AB-4E65-B10E-0B426F01E2E8} | 		{02DF7FEE-C302-433D-A6CD-237A2569F236} = {91CF7717-08AB-4E65-B10E-0B426F01E2E8} | ||||||
| 		{A579E108-5445-403D-A407-339AC4D1611B} = {02DF7FEE-C302-433D-A6CD-237A2569F236} | 		{A579E108-5445-403D-A407-339AC4D1611B} = {02DF7FEE-C302-433D-A6CD-237A2569F236} | ||||||
|  | 		{621E7211-58D0-45FD-9600-1CB490BD930E} = {EF0337F2-ED00-4643-89FD-EE10863F1870} | ||||||
| 	EndGlobalSection | 	EndGlobalSection | ||||||
| EndGlobal | EndGlobal | ||||||
|  | |||||||
| @ -3,7 +3,8 @@ | |||||||
|     "src", |     "src", | ||||||
|     "test", |     "test", | ||||||
|     "src/Services/Ordering", |     "src/Services/Ordering", | ||||||
|     "src/Web" |     "src/Web", | ||||||
|  |     "src/Services/Catalog" | ||||||
|   ], |   ], | ||||||
| 
 | 
 | ||||||
|   "sdk": { |   "sdk": { | ||||||
|  | |||||||
							
								
								
									
										23
									
								
								hosts
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,23 @@ | |||||||
|  | # Copyright (c) 1993-2009 Microsoft Corp. | ||||||
|  | # | ||||||
|  | # This is a sample HOSTS file used by Microsoft TCP/IP for Windows. | ||||||
|  | # | ||||||
|  | # This file contains the mappings of IP addresses to host names. Each | ||||||
|  | # entry should be kept on an individual line. The IP address should | ||||||
|  | # be placed in the first column followed by the corresponding host name. | ||||||
|  | # The IP address and the host name should be separated by at least one | ||||||
|  | # space. | ||||||
|  | # | ||||||
|  | # Additionally, comments (such as these) may be inserted on individual | ||||||
|  | # lines or following the machine name denoted by a '#' symbol. | ||||||
|  | # | ||||||
|  | # For example: | ||||||
|  | # | ||||||
|  | #      102.54.94.97     rhino.acme.com          # source server | ||||||
|  | #       38.25.63.10     x.acme.com              # x client host | ||||||
|  | 
 | ||||||
|  | # localhost name resolution is handled within DNS itself. | ||||||
|  | #	127.0.0.1       localhost | ||||||
|  | #	::1             localhost | ||||||
|  | 
 | ||||||
|  |        10.0.75.1     identity.service | ||||||
							
								
								
									
										
											BIN
										
									
								
								img/Bower_and_Gulp_setup.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 123 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/Generating_Docker_Images.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 152 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/docker-compose-up-1.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 198 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/docker-compose-up-2.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 162 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/docker-ps-with-all-microservices.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 103 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/eShopOnContainers_Architecture_Diagram.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 302 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/eshop-webmvc-app-screenshot.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.1 MiB | 
							
								
								
									
										
											BIN
										
									
								
								img/eshop_logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 14 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/list-of-images.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 60 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/login-demo-user.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 94 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/vs-solution-structure.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 383 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/xamarin-mobile-App.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 189 KiB | 
| @ -35,6 +35,7 @@ namespace eShopOnContainers.Core.Controls | |||||||
|                         SelectedItem = item; |                         SelectedItem = item; | ||||||
|                         break; |                         break; | ||||||
|                     } |                     } | ||||||
|  | 
 | ||||||
|                     index++; |                     index++; | ||||||
|                 } |                 } | ||||||
|             }; |             }; | ||||||
| @ -73,6 +74,7 @@ namespace eShopOnContainers.Core.Controls | |||||||
|             if (ItemsSource != null) |             if (ItemsSource != null) | ||||||
|             { |             { | ||||||
|                 var index = 0; |                 var index = 0; | ||||||
|  | 
 | ||||||
|                 foreach (var item in ItemsSource) |                 foreach (var item in ItemsSource) | ||||||
|                 { |                 { | ||||||
|                     string strItem = item?.ToString(); |                     string strItem = item?.ToString(); | ||||||
| @ -84,6 +86,7 @@ namespace eShopOnContainers.Core.Controls | |||||||
|                         selectedIndex = index; |                         selectedIndex = index; | ||||||
|                         break; |                         break; | ||||||
|                     } |                     } | ||||||
|  | 
 | ||||||
|                     index++; |                     index++; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @ -113,10 +116,8 @@ namespace eShopOnContainers.Core.Controls | |||||||
|         { |         { | ||||||
|             var boundPicker = (BindablePicker)bindable; |             var boundPicker = (BindablePicker)bindable; | ||||||
| 
 | 
 | ||||||
|             if (boundPicker.ItemSelected != null) |             boundPicker.ItemSelected?.Invoke(boundPicker,  | ||||||
|             { |                 new SelectedItemChangedEventArgs(newValue)); | ||||||
|                 boundPicker.ItemSelected(boundPicker, new SelectedItemChangedEventArgs(newValue)); |  | ||||||
|             } |  | ||||||
| 
 | 
 | ||||||
|             if(boundPicker.ItemSelectedCommand != null) |             if(boundPicker.ItemSelectedCommand != null) | ||||||
|             { |             { | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ namespace eShopOnContainers.Core.Converters | |||||||
| { | { | ||||||
|     public class ItemsToHeightConverter : IValueConverter |     public class ItemsToHeightConverter : IValueConverter | ||||||
|     { |     { | ||||||
|         private const int ItemHeight = 144; |         private const int ItemHeight = 156; | ||||||
| 
 | 
 | ||||||
|         public object Convert(object value, Type targetType, object parameter, CultureInfo culture) |         public object Convert(object value, Type targetType, object parameter, CultureInfo culture) | ||||||
|         { |         { | ||||||
|  | |||||||
| @ -0,0 +1,8 @@ | |||||||
|  | namespace eShopOnContainers.Core.Models.Orders | ||||||
|  | { | ||||||
|  |     public class CardType | ||||||
|  |     { | ||||||
|  |         public int Id { get; set; } | ||||||
|  |         public string Name { get; set; } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -12,7 +12,6 @@ using eShopOnContainers.Core.Controls; | |||||||
| using eShopOnContainers.Droid.Renderers; | using eShopOnContainers.Droid.Renderers; | ||||||
| using Android.Support.V4.View; | using Android.Support.V4.View; | ||||||
| using Android.Graphics; | using Android.Graphics; | ||||||
| using static Android.Widget.ImageView; |  | ||||||
| 
 | 
 | ||||||
| [assembly: ExportRenderer(typeof(TabbedPage), typeof(CustomTabbedPageRenderer))] | [assembly: ExportRenderer(typeof(TabbedPage), typeof(CustomTabbedPageRenderer))] | ||||||
| namespace eShopOnContainers.Droid.Renderers | namespace eShopOnContainers.Droid.Renderers | ||||||
|  | |||||||
| @ -62,12 +62,6 @@ | |||||||
|     <None Include="app.config" /> |     <None Include="app.config" /> | ||||||
|     <None Include="packages.config" /> |     <None Include="packages.config" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <ItemGroup> |  | ||||||
|     <ProjectReference Include="..\eShopOnContainers.Core\eShopOnContainers.Core.csproj"> |  | ||||||
|       <Project>{65116d1c-145b-4693-abda-f0fb6f425191}</Project> |  | ||||||
|       <Name>eShopOnContainers.Core</Name> |  | ||||||
|     </ProjectReference> |  | ||||||
|   </ItemGroup> |  | ||||||
|   <Import Project="$(MSBuildExtensionsPath32)\Microsoft\Portable\$(TargetFrameworkVersion)\Microsoft.Portable.CSharp.targets" /> |   <Import Project="$(MSBuildExtensionsPath32)\Microsoft\Portable\$(TargetFrameworkVersion)\Microsoft.Portable.CSharp.targets" /> | ||||||
|   <!-- To modify your build process, add your task inside one of the targets below and uncomment it.  |   <!-- To modify your build process, add your task inside one of the targets below and uncomment it.  | ||||||
|        Other similar extension points exist, see Microsoft.Common.targets. |        Other similar extension points exist, see Microsoft.Common.targets. | ||||||
|  | |||||||
| @ -11,8 +11,8 @@ | |||||||
|     <AssemblyName>eShopOnContainers.Windows</AssemblyName> |     <AssemblyName>eShopOnContainers.Windows</AssemblyName> | ||||||
|     <DefaultLanguage>en-US</DefaultLanguage> |     <DefaultLanguage>en-US</DefaultLanguage> | ||||||
|     <TargetPlatformIdentifier>UAP</TargetPlatformIdentifier> |     <TargetPlatformIdentifier>UAP</TargetPlatformIdentifier> | ||||||
|     <TargetPlatformVersion>10.0.14393.0</TargetPlatformVersion> |     <TargetPlatformVersion>10.0.10586.0</TargetPlatformVersion> | ||||||
|     <TargetPlatformMinVersion>10.0.14393.0</TargetPlatformMinVersion> |     <TargetPlatformMinVersion>10.0.10586.0</TargetPlatformMinVersion> | ||||||
|     <MinimumVisualStudioVersion>14</MinimumVisualStudioVersion> |     <MinimumVisualStudioVersion>14</MinimumVisualStudioVersion> | ||||||
|     <EnableDotNetNativeCompatibleProfile>true</EnableDotNetNativeCompatibleProfile> |     <EnableDotNetNativeCompatibleProfile>true</EnableDotNetNativeCompatibleProfile> | ||||||
|     <FileAlignment>512</FileAlignment> |     <FileAlignment>512</FileAlignment> | ||||||
| @ -174,11 +174,10 @@ | |||||||
|     </ProjectReference> |     </ProjectReference> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <SDKReference Include="WindowsMobile, Version=10.0.14393.0"> |     <SDKReference Include="WindowsMobile, Version=10.0.10586.0"> | ||||||
|       <Name>Windows Mobile Extensions for the UWP</Name> |       <Name>Windows Mobile Extensions for the UWP</Name> | ||||||
|     </SDKReference> |     </SDKReference> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <ItemGroup /> |  | ||||||
|   <PropertyGroup Condition=" '$(VisualStudioVersion)' == '' or '$(VisualStudioVersion)' < '14.0' "> |   <PropertyGroup Condition=" '$(VisualStudioVersion)' == '' or '$(VisualStudioVersion)' < '14.0' "> | ||||||
|     <VisualStudioVersion>14.0</VisualStudioVersion> |     <VisualStudioVersion>14.0</VisualStudioVersion> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|  | |||||||
| @ -2,5 +2,5 @@ FROM microsoft/aspnetcore:1.0.1 | |||||||
| ENTRYPOINT ["dotnet", "Basket.API.dll"] | ENTRYPOINT ["dotnet", "Basket.API.dll"] | ||||||
| ARG source=. | ARG source=. | ||||||
| WORKDIR /app | WORKDIR /app | ||||||
| EXPOSE 80 | ENV ASPNETCORE_URLS http://*:5103 | ||||||
| COPY $source . | COPY $source . | ||||||
|  | |||||||
| @ -15,6 +15,7 @@ namespace Microsoft.eShopOnContainers.Services.Basket.API | |||||||
|             var host = new WebHostBuilder() |             var host = new WebHostBuilder() | ||||||
|                 .UseKestrel() |                 .UseKestrel() | ||||||
|                 .UseContentRoot(Directory.GetCurrentDirectory()) |                 .UseContentRoot(Directory.GetCurrentDirectory()) | ||||||
|  |                 .UseUrls("http://0.0.0.0:5103") | ||||||
|                 .UseIISIntegration() |                 .UseIISIntegration() | ||||||
|                 .UseStartup<Startup>() |                 .UseStartup<Startup>() | ||||||
|                 .Build(); |                 .Build(); | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
|     "windowsAuthentication": false, |     "windowsAuthentication": false, | ||||||
|     "anonymousAuthentication": true, |     "anonymousAuthentication": true, | ||||||
|     "iisExpress": { |     "iisExpress": { | ||||||
|       "applicationUrl": "http://localhost:2160/", |       "applicationUrl": "http://localhost:5003/", | ||||||
|       "sslPort": 0 |       "sslPort": 0 | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|  | |||||||
| @ -68,7 +68,7 @@ namespace Microsoft.eShopOnContainers.Services.Basket.API | |||||||
|             // Use frameworks |             // Use frameworks | ||||||
|             app.UseCors("CorsPolicy"); |             app.UseCors("CorsPolicy"); | ||||||
| 
 | 
 | ||||||
|             var identityUrl = Configuration.GetValue(typeof(string), "IdentityUrl"); |             var identityUrl = Configuration.GetValue<string>("IdentityUrl"); | ||||||
| 
 | 
 | ||||||
|             app.UseIdentityServerAuthentication(new IdentityServerAuthenticationOptions |             app.UseIdentityServerAuthentication(new IdentityServerAuthenticationOptions | ||||||
|             { |             { | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| { | { | ||||||
|   "Logging": { |   "Logging": { | ||||||
|     "IncludeScopes": false, |     "IncludeScopes": false, | ||||||
|     "LogLevel": { |     "LogLevel": { | ||||||
| @ -7,6 +7,6 @@ | |||||||
|       "Microsoft": "Information" |       "Microsoft": "Information" | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   "IdentityUrl": "http://localhost:5105", |   "IdentityUrl": "http://identity.service:5105", | ||||||
|   "ConnectionString": "127.0.0.1" |   "ConnectionString": "127.0.0.1" | ||||||
| } | } | ||||||
|  | |||||||
| @ -20,7 +20,6 @@ namespace Microsoft.eShopOnContainers.Services.Catalog.API.Controllers | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // GET api/v1/[controller]/items/[?pageSize=3&pageIndex=10] |         // GET api/v1/[controller]/items/[?pageSize=3&pageIndex=10] | ||||||
| 
 |  | ||||||
|         [HttpGet] |         [HttpGet] | ||||||
|         [Route("[action]")]
 |         [Route("[action]")]
 | ||||||
|         public async Task<IActionResult> Items(int pageSize = 10, int pageIndex = 0) |         public async Task<IActionResult> Items(int pageSize = 10, int pageIndex = 0) | ||||||
| @ -41,7 +40,6 @@ namespace Microsoft.eShopOnContainers.Services.Catalog.API.Controllers | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // GET api/v1/[controller]/items/withname/samplename |         // GET api/v1/[controller]/items/withname/samplename | ||||||
| 
 |  | ||||||
|         [HttpGet] |         [HttpGet] | ||||||
|         [Route("[action]/withname/{name:minlength(1)}")]
 |         [Route("[action]/withname/{name:minlength(1)}")]
 | ||||||
|         public async Task<IActionResult> Items(string name, int pageSize = 10, int pageIndex = 0) |         public async Task<IActionResult> Items(string name, int pageSize = 10, int pageIndex = 0) | ||||||
| @ -64,7 +62,6 @@ namespace Microsoft.eShopOnContainers.Services.Catalog.API.Controllers | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // GET api/v1/[controller]/items/type/1/brand/null |         // GET api/v1/[controller]/items/type/1/brand/null | ||||||
| 
 |  | ||||||
|         [HttpGet] |         [HttpGet] | ||||||
|         [Route("[action]/type/{catalogTypeId}/brand/{catalogBrandId}")]
 |         [Route("[action]/type/{catalogTypeId}/brand/{catalogBrandId}")]
 | ||||||
|         public async Task<IActionResult> Items(int? catalogTypeId, int? catalogBrandId, int pageSize = 10, int pageIndex = 0) |         public async Task<IActionResult> Items(int? catalogTypeId, int? catalogBrandId, int pageSize = 10, int pageIndex = 0) | ||||||
| @ -96,7 +93,6 @@ namespace Microsoft.eShopOnContainers.Services.Catalog.API.Controllers | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // GET api/v1/[controller]/CatalogTypes |         // GET api/v1/[controller]/CatalogTypes | ||||||
| 
 |  | ||||||
|         [HttpGet] |         [HttpGet] | ||||||
|         [Route("[action]")]
 |         [Route("[action]")]
 | ||||||
|         public async Task<IActionResult> CatalogTypes() |         public async Task<IActionResult> CatalogTypes() | ||||||
| @ -108,7 +104,6 @@ namespace Microsoft.eShopOnContainers.Services.Catalog.API.Controllers | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // GET api/v1/[controller]/CatalogBrands |         // GET api/v1/[controller]/CatalogBrands | ||||||
| 
 |  | ||||||
|         [HttpGet] |         [HttpGet] | ||||||
|         [Route("[action]")]
 |         [Route("[action]")]
 | ||||||
|         public async Task<IActionResult> CatalogBrands() |         public async Task<IActionResult> CatalogBrands() | ||||||
|  | |||||||
| @ -8,20 +8,14 @@ | |||||||
|         public CatalogContext(DbContextOptions options) : base(options) |         public CatalogContext(DbContextOptions options) : base(options) | ||||||
|         { |         { | ||||||
|         } |         } | ||||||
| 
 |  | ||||||
|         public DbSet<CatalogItem> CatalogItems { get; set; } |         public DbSet<CatalogItem> CatalogItems { get; set; } | ||||||
| 
 |  | ||||||
|         public DbSet<CatalogBrand> CatalogBrands { get; set; } |         public DbSet<CatalogBrand> CatalogBrands { get; set; } | ||||||
| 
 |  | ||||||
|         public DbSet<CatalogType> CatalogTypes { get; set; } |         public DbSet<CatalogType> CatalogTypes { get; set; } | ||||||
| 
 |  | ||||||
|         protected override void OnModelCreating(ModelBuilder builder) |         protected override void OnModelCreating(ModelBuilder builder) | ||||||
|         { |         { | ||||||
|             builder.Entity<CatalogBrand>(ConfigureCatalogBrand); |             builder.Entity<CatalogBrand>(ConfigureCatalogBrand); | ||||||
|             builder.Entity<CatalogType>(ConfigureCatalogType); |             builder.Entity<CatalogType>(ConfigureCatalogType); | ||||||
|             builder.Entity<CatalogItem>(ConfigureCatalogItem); |             builder.Entity<CatalogItem>(ConfigureCatalogItem); | ||||||
|             |  | ||||||
| 
 |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         void ConfigureCatalogItem(EntityTypeBuilder<CatalogItem> builder) |         void ConfigureCatalogItem(EntityTypeBuilder<CatalogItem> builder) | ||||||
| @ -49,7 +43,6 @@ | |||||||
|             builder.HasOne(ci => ci.CatalogType) |             builder.HasOne(ci => ci.CatalogType) | ||||||
|                 .WithMany() |                 .WithMany() | ||||||
|                 .HasForeignKey(ci => ci.CatalogTypeId); |                 .HasForeignKey(ci => ci.CatalogTypeId); | ||||||
| 
 |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         void ConfigureCatalogBrand(EntityTypeBuilder<CatalogBrand> builder) |         void ConfigureCatalogBrand(EntityTypeBuilder<CatalogBrand> builder) | ||||||
| @ -69,7 +62,6 @@ | |||||||
| 
 | 
 | ||||||
|         void ConfigureCatalogType(EntityTypeBuilder<CatalogType> builder) |         void ConfigureCatalogType(EntityTypeBuilder<CatalogType> builder) | ||||||
|         { |         { | ||||||
| 
 |  | ||||||
|             builder.ToTable("CatalogType"); |             builder.ToTable("CatalogType"); | ||||||
| 
 | 
 | ||||||
|             builder.HasKey(ci => ci.Id); |             builder.HasKey(ci => ci.Id); | ||||||
|  | |||||||
| @ -63,8 +63,10 @@ | |||||||
|         { |         { | ||||||
|             return new List<CatalogBrand>() |             return new List<CatalogBrand>() | ||||||
|             { |             { | ||||||
|                 new CatalogBrand() { Brand="Azure"}, |                 new CatalogBrand() { Brand = "Azure"}, | ||||||
|                 new CatalogBrand() { Brand = "Visual Studio" } |                 new CatalogBrand() { Brand = ".NET" }, | ||||||
|  |                 new CatalogBrand() { Brand = "Visual Studio" }, | ||||||
|  |                 new CatalogBrand() { Brand = "SQL Server" } | ||||||
|             }; |             }; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -72,8 +74,10 @@ | |||||||
|         { |         { | ||||||
|             return new List<CatalogType>() |             return new List<CatalogType>() | ||||||
|             { |             { | ||||||
|                 new CatalogType() { Type="Mug"}, |                 new CatalogType() { Type = "Mug"}, | ||||||
|                 new CatalogType() { Type = "T-Shirt" } |                 new CatalogType() { Type = "T-Shirt" }, | ||||||
|  |                 new CatalogType() { Type = "Backpack" }, | ||||||
|  |                 new CatalogType() { Type = "USB Memory Stick" } | ||||||
|             }; |             }; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| namespace Microsoft.eShopOnContainers.Services.Catalog.API.Infrastructure | using System; | ||||||
| { |  | ||||||
|     using System; |  | ||||||
| 
 | 
 | ||||||
|  | namespace Microsoft.eShopOnContainers.Services.Catalog.API.Infrastructure | ||||||
|  | { | ||||||
|     public class CatalogItem |     public class CatalogItem | ||||||
|     { |     { | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|  | |||||||
| @ -10,6 +10,8 @@ | |||||||
|   "profiles": { |   "profiles": { | ||||||
|     "IIS Express": { |     "IIS Express": { | ||||||
|       "commandName": "IISExpress", |       "commandName": "IISExpress", | ||||||
|  |       "launchBrowser": true, | ||||||
|  |       "launchUrl": "/swagger/ui", | ||||||
|       "environmentVariables": { |       "environmentVariables": { | ||||||
|         "ASPNETCORE_ENVIRONMENT": "Development" |         "ASPNETCORE_ENVIRONMENT": "Development" | ||||||
|       } |       } | ||||||
|  | |||||||
| @ -54,9 +54,9 @@ | |||||||
|                 options.DescribeAllEnumsAsStrings(); |                 options.DescribeAllEnumsAsStrings(); | ||||||
|                 options.SingleApiVersion(new Swashbuckle.Swagger.Model.Info() |                 options.SingleApiVersion(new Swashbuckle.Swagger.Model.Info() | ||||||
|                 { |                 { | ||||||
|                     Title = "Catalog HTTP API", |                     Title = "eShopOnContainers - Catalog HTTP API", | ||||||
|                     Version = "v1", |                     Version = "v1", | ||||||
|                     Description = "The Catalog Service HTTP API", |                     Description = "The Catalog Microservice HTTP API. This is a Data-Driven/CRUD microservice sample", | ||||||
|                     TermsOfService = "Terms Of Service" |                     TermsOfService = "Terms Of Service" | ||||||
|                 }); |                 }); | ||||||
|             }); |             }); | ||||||
|  | |||||||
| @ -3,9 +3,6 @@ version: '2' | |||||||
| services: | services: | ||||||
|   catalog.api: |   catalog.api: | ||||||
|     image: eshop/catalog.api |     image: eshop/catalog.api | ||||||
|     build: |  | ||||||
|     context: . |  | ||||||
|     dockerfile: Dockerfile |  | ||||||
|     environment: |     environment: | ||||||
|       - ConnectionString=Server=catalog.data;Initial Catalog=CatalogData;User Id=sa;Password=Pass@word |       - ConnectionString=Server=catalog.data;Initial Catalog=CatalogData;User Id=sa;Password=Pass@word | ||||||
|     expose: |     expose: | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| { | { | ||||||
|   "ConnectionString": "Server=tcp:127.0.0.1,1433;Initial Catalog=CatalogDB;User Id=sa;Password=Pass@word", |   "ConnectionString": "Server=tcp:127.0.0.1,5433;Initial Catalog=CatalogDB;User Id=sa;Password=Pass@word", | ||||||
|   "Logging": { |   "Logging": { | ||||||
|     "IncludeScopes": false, |     "IncludeScopes": false, | ||||||
|     "LogLevel": { |     "LogLevel": { | ||||||
|  | |||||||
| @ -70,6 +70,7 @@ namespace IdentityServer4.Quickstart.UI.Controllers | |||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             var vm = await BuildLoginViewModelAsync(returnUrl, context); |             var vm = await BuildLoginViewModelAsync(returnUrl, context); | ||||||
|  |             ViewData["ReturnUrl"] = returnUrl; | ||||||
| 
 | 
 | ||||||
|             return View(vm); |             return View(vm); | ||||||
|         } |         } | ||||||
| @ -98,12 +99,11 @@ namespace IdentityServer4.Quickstart.UI.Controllers | |||||||
|                         props = new AuthenticationProperties |                         props = new AuthenticationProperties | ||||||
|                         { |                         { | ||||||
|                             IsPersistent = true, |                             IsPersistent = true, | ||||||
|                             ExpiresUtc = DateTimeOffset.UtcNow.AddMonths(1) |                             ExpiresUtc = DateTimeOffset.UtcNow.AddYears(10) | ||||||
|                         }; |                         }; | ||||||
|                     }; |                     }; | ||||||
| 
 | 
 | ||||||
|                     await _loginService.SignIn(user); |                     await _loginService.SignIn(user); | ||||||
| 
 |  | ||||||
|                     // make sure the returnUrl is still valid, and if yes - redirect back to authorize endpoint |                     // make sure the returnUrl is still valid, and if yes - redirect back to authorize endpoint | ||||||
|                     if (_interaction.IsValidReturnUrl(model.ReturnUrl)) |                     if (_interaction.IsValidReturnUrl(model.ReturnUrl)) | ||||||
|                     { |                     { | ||||||
| @ -118,6 +118,7 @@ namespace IdentityServer4.Quickstart.UI.Controllers | |||||||
| 
 | 
 | ||||||
|             // something went wrong, show form with error |             // something went wrong, show form with error | ||||||
|             var vm = await BuildLoginViewModelAsync(model); |             var vm = await BuildLoginViewModelAsync(model); | ||||||
|  |             ViewData["ReturnUrl"] = model.ReturnUrl; | ||||||
|             return View(vm); |             return View(vm); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -296,7 +297,10 @@ namespace IdentityServer4.Quickstart.UI.Controllers | |||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (returnUrl != null) { |             if (returnUrl != null) { | ||||||
|                 return Redirect(returnUrl); |                 if (HttpContext.User.Identity.IsAuthenticated) | ||||||
|  |                     return Redirect(returnUrl); | ||||||
|  |                 else | ||||||
|  |                     return RedirectToAction("login", "account", new { returnUrl = returnUrl }); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             return RedirectToAction("index", "home"); |             return RedirectToAction("index", "home"); | ||||||
|  | |||||||
| @ -0,0 +1,85 @@ | |||||||
|  | namespace Microsoft.eShopOnContainers.Services.Catalog.API.Infrastructure | ||||||
|  | { | ||||||
|  |     using AspNetCore.Identity; | ||||||
|  |     using EntityFrameworkCore; | ||||||
|  |     using Extensions.Logging; | ||||||
|  |     using global::eShopOnContainers.Identity.Data; | ||||||
|  |     using global::eShopOnContainers.Identity.Models; | ||||||
|  |     using Microsoft.AspNetCore.Builder; | ||||||
|  |     using System; | ||||||
|  |     using System.Collections.Generic; | ||||||
|  |     using System.Linq; | ||||||
|  |     using System.Security.Cryptography; | ||||||
|  |     using System.Threading.Tasks; | ||||||
|  | 
 | ||||||
|  |     public class ApplicationContextSeed | ||||||
|  |     { | ||||||
|  |         private readonly IPasswordHasher<ApplicationUser> _passwordHasher; | ||||||
|  | 
 | ||||||
|  |         public ApplicationContextSeed(IPasswordHasher<ApplicationUser> passwordHasher) | ||||||
|  |         { | ||||||
|  |             _passwordHasher = passwordHasher; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public async Task SeedAsync(IApplicationBuilder applicationBuilder, ILoggerFactory loggerFactory, int? retry = 0) | ||||||
|  |         { | ||||||
|  |             int retryForAvaiability = retry.Value; | ||||||
|  |             try | ||||||
|  |             { | ||||||
|  |                 var context = (ApplicationDbContext)applicationBuilder | ||||||
|  |                     .ApplicationServices.GetService(typeof(ApplicationDbContext)); | ||||||
|  | 
 | ||||||
|  |                 context.Database.Migrate(); | ||||||
|  | 
 | ||||||
|  |                 if (!context.Users.Any()) | ||||||
|  |                 { | ||||||
|  |                     context.Users.AddRange( | ||||||
|  |                         GetDefaultUser()); | ||||||
|  | 
 | ||||||
|  |                     await context.SaveChangesAsync(); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             catch (Exception ex) | ||||||
|  |             { | ||||||
|  |                 if (retryForAvaiability < 10) | ||||||
|  |                 { | ||||||
|  |                     retryForAvaiability++; | ||||||
|  |                     var log = loggerFactory.CreateLogger("catalog seed"); | ||||||
|  |                     log.LogError(ex.Message); | ||||||
|  |                     await SeedAsync(applicationBuilder, loggerFactory, retryForAvaiability); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         private ApplicationUser GetDefaultUser() | ||||||
|  |         { | ||||||
|  |             var user =  | ||||||
|  |             new ApplicationUser() | ||||||
|  |             { | ||||||
|  |                 CardHolderName = "DemoUser", | ||||||
|  |                 CardNumber = "4012888888881881", | ||||||
|  |                 CardType = 1, | ||||||
|  |                 City = "Redmond", | ||||||
|  |                 Country = "U.S.", | ||||||
|  |                 Email = "demouser@microsoft.com", | ||||||
|  |                 Expiration = "12/20", | ||||||
|  |                 Id = Guid.NewGuid().ToString(),  | ||||||
|  |                 LastName = "DemoLastName",  | ||||||
|  |                 Name = "DemoUser",  | ||||||
|  |                 PhoneNumber = "1234567890",  | ||||||
|  |                 UserName = "demouser@microsoft.com",  | ||||||
|  |                 ZipCode = "98052",  | ||||||
|  |                 State = "WA",  | ||||||
|  |                 Street = "15703 NE 61st Ct",  | ||||||
|  |                 SecurityNumber = "535",  | ||||||
|  |                 NormalizedEmail = "DEMOUSER@MICROSOFT.COM",  | ||||||
|  |                 NormalizedUserName = "DEMOUSER@MICROSOFT.COM",  | ||||||
|  |                 SecurityStamp = Guid.NewGuid().ToString("D") | ||||||
|  |             }; | ||||||
|  | 
 | ||||||
|  |             user.PasswordHash = _passwordHasher.HashPassword(user, "Pass@word1"); | ||||||
|  | 
 | ||||||
|  |             return user; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -49,14 +49,11 @@ namespace WebMVC.Migrations | |||||||
|                     City = table.Column<string>(nullable: true), |                     City = table.Column<string>(nullable: true), | ||||||
|                     ConcurrencyStamp = table.Column<string>(nullable: true), |                     ConcurrencyStamp = table.Column<string>(nullable: true), | ||||||
|                     Country = table.Column<string>(nullable: true), |                     Country = table.Column<string>(nullable: true), | ||||||
|                     CountryCode = table.Column<string>(nullable: true), |  | ||||||
|                     Email = table.Column<string>(maxLength: 256, nullable: true), |                     Email = table.Column<string>(maxLength: 256, nullable: true), | ||||||
|                     EmailConfirmed = table.Column<bool>(nullable: false), |                     EmailConfirmed = table.Column<bool>(nullable: false), | ||||||
|                     Expiration = table.Column<string>(nullable: true), |                     Expiration = table.Column<string>(nullable: true), | ||||||
|                     Latitude = table.Column<double>(nullable: false), |  | ||||||
|                     LockoutEnabled = table.Column<bool>(nullable: false), |                     LockoutEnabled = table.Column<bool>(nullable: false), | ||||||
|                     LockoutEnd = table.Column<DateTimeOffset>(nullable: true), |                     LockoutEnd = table.Column<DateTimeOffset>(nullable: true), | ||||||
|                     Longitude = table.Column<double>(nullable: false), |  | ||||||
|                     NormalizedEmail = table.Column<string>(maxLength: 256, nullable: true), |                     NormalizedEmail = table.Column<string>(maxLength: 256, nullable: true), | ||||||
|                     NormalizedUserName = table.Column<string>(maxLength: 256, nullable: true), |                     NormalizedUserName = table.Column<string>(maxLength: 256, nullable: true), | ||||||
|                     PasswordHash = table.Column<string>(nullable: true), |                     PasswordHash = table.Column<string>(nullable: true), | ||||||
| @ -65,7 +62,6 @@ namespace WebMVC.Migrations | |||||||
|                     SecurityNumber = table.Column<string>(nullable: true), |                     SecurityNumber = table.Column<string>(nullable: true), | ||||||
|                     SecurityStamp = table.Column<string>(nullable: true), |                     SecurityStamp = table.Column<string>(nullable: true), | ||||||
|                     State = table.Column<string>(nullable: true), |                     State = table.Column<string>(nullable: true), | ||||||
|                     StateCode = table.Column<string>(nullable: true), |  | ||||||
|                     Street = table.Column<string>(nullable: true), |                     Street = table.Column<string>(nullable: true), | ||||||
|                     TwoFactorEnabled = table.Column<bool>(nullable: false), |                     TwoFactorEnabled = table.Column<bool>(nullable: false), | ||||||
|                     UserName = table.Column<string>(maxLength: 256, nullable: true), |                     UserName = table.Column<string>(maxLength: 256, nullable: true), | ||||||
|  | |||||||
| @ -1,16 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Security.Principal; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
| 
 |  | ||||||
| namespace eShopOnContainers.Identity.Extensions |  | ||||||
| { |  | ||||||
|     //public static class PrincipalExtensions |  | ||||||
|     //{ |  | ||||||
|     //    public static string GetSubjectId(this IPrincipal principal) |  | ||||||
|     //    { |  | ||||||
|     //        return principal.Identity.GetSubjectId(); |  | ||||||
|     //    } |  | ||||||
|     //} |  | ||||||
| } |  | ||||||
| @ -10,21 +10,29 @@ namespace eShopOnContainers.Identity.Models | |||||||
|     // Add profile data for application users by adding properties to the ApplicationUser class |     // Add profile data for application users by adding properties to the ApplicationUser class | ||||||
|     public class ApplicationUser : IdentityUser |     public class ApplicationUser : IdentityUser | ||||||
|     { |     { | ||||||
|  |         [Required] | ||||||
|         public string CardNumber { get; set; } |         public string CardNumber { get; set; } | ||||||
|  |         [Required] | ||||||
|         public string SecurityNumber { get; set; } |         public string SecurityNumber { get; set; } | ||||||
|  |         [Required] | ||||||
|  |         [RegularExpression(@"(0[1-9]|1[0-2])\/[0-9]{2}", ErrorMessage = "Expiration should match a valid MM/YY value")]
 | ||||||
|         public string Expiration { get; set; } |         public string Expiration { get; set; } | ||||||
|  |         [Required] | ||||||
|         public string CardHolderName { get; set; } |         public string CardHolderName { get; set; } | ||||||
|         public int CardType { get; set; } |         public int CardType { get; set; } | ||||||
|  |         [Required] | ||||||
|         public string Street { get; set; } |         public string Street { get; set; } | ||||||
|  |         [Required] | ||||||
|         public string City { get; set; } |         public string City { get; set; } | ||||||
|  |         [Required] | ||||||
|         public string State { get; set; } |         public string State { get; set; } | ||||||
|         public string StateCode { get; set; } |         [Required] | ||||||
|         public string Country { get; set; } |         public string Country { get; set; } | ||||||
|         public string CountryCode { get; set; } |         [Required] | ||||||
|         public string ZipCode { get; set; } |         public string ZipCode { get; set; } | ||||||
|         public double Latitude { get; set; } |         [Required] | ||||||
|         public double Longitude { get; set; } |  | ||||||
|         public string Name { get; set; } |         public string Name { get; set; } | ||||||
|  |         [Required] | ||||||
|         public string LastName { get; set; } |         public string LastName { get; set; } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ namespace eShopOnContainers.Identity | |||||||
|                 .UseKestrel() |                 .UseKestrel() | ||||||
|                 .UseUrls("http://0.0.0.0:5105") |                 .UseUrls("http://0.0.0.0:5105") | ||||||
|                 .UseContentRoot(Directory.GetCurrentDirectory()) |                 .UseContentRoot(Directory.GetCurrentDirectory()) | ||||||
|                 //.UseIISIntegration() |                 .UseIISIntegration() | ||||||
|                 .UseStartup<Startup>() |                 .UseStartup<Startup>() | ||||||
|                 .Build(); |                 .Build(); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -11,7 +11,7 @@ | |||||||
|     "IIS Express": { |     "IIS Express": { | ||||||
|       "commandName": "IISExpress", |       "commandName": "IISExpress", | ||||||
|       "launchBrowser": true, |       "launchBrowser": true, | ||||||
|       "launchUrl": "http://localhost:5000", |       "launchUrl": "http://localhost:5105", | ||||||
|       "environmentVariables": { |       "environmentVariables": { | ||||||
|         "ASPNETCORE_ENVIRONMENT": "Development" |         "ASPNETCORE_ENVIRONMENT": "Development" | ||||||
|       } |       } | ||||||
|  | |||||||
| @ -19,7 +19,7 @@ namespace eShopOnContainers.Identity.Services | |||||||
| 
 | 
 | ||||||
|         public async Task<ApplicationUser> FindByUsername(string user) |         public async Task<ApplicationUser> FindByUsername(string user) | ||||||
|         { |         { | ||||||
|             return await _userManager.FindByNameAsync(user); |             return await _userManager.FindByEmailAsync(user); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public async Task<bool> ValidateCredentials(ApplicationUser user, string password) |         public async Task<bool> ValidateCredentials(ApplicationUser user, string password) | ||||||
|  | |||||||
| @ -88,6 +88,9 @@ namespace eShopOnContainers.Identity.Services | |||||||
|             if (!string.IsNullOrWhiteSpace(user.SecurityNumber)) |             if (!string.IsNullOrWhiteSpace(user.SecurityNumber)) | ||||||
|                 claims.Add(new Claim("card_security_number", user.SecurityNumber)); |                 claims.Add(new Claim("card_security_number", user.SecurityNumber)); | ||||||
| 
 | 
 | ||||||
|  |             if (!string.IsNullOrWhiteSpace(user.Expiration)) | ||||||
|  |                 claims.Add(new Claim("card_expiration", user.Expiration)); | ||||||
|  | 
 | ||||||
|             if (!string.IsNullOrWhiteSpace(user.City)) |             if (!string.IsNullOrWhiteSpace(user.City)) | ||||||
|                 claims.Add(new Claim("address_city", user.City)); |                 claims.Add(new Claim("address_city", user.City)); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -15,6 +15,8 @@ using eShopOnContainers.Identity.Services; | |||||||
| using eShopOnContainers.Identity.Configuration; | using eShopOnContainers.Identity.Configuration; | ||||||
| using IdentityServer4.Services; | using IdentityServer4.Services; | ||||||
| using System.Threading; | using System.Threading; | ||||||
|  | using Microsoft.eShopOnContainers.Services.Catalog.API.Infrastructure; | ||||||
|  | using Microsoft.AspNetCore.Identity; | ||||||
| 
 | 
 | ||||||
| namespace eShopOnContainers.Identity | namespace eShopOnContainers.Identity | ||||||
| { | { | ||||||
| @ -51,6 +53,7 @@ namespace eShopOnContainers.Identity | |||||||
|                 .AddDefaultTokenProviders(); |                 .AddDefaultTokenProviders(); | ||||||
|                  |                  | ||||||
|           |           | ||||||
|  | 
 | ||||||
|             services.AddMvc(); |             services.AddMvc(); | ||||||
| 
 | 
 | ||||||
|             services.AddTransient<IEmailSender, AuthMessageSender>(); |             services.AddTransient<IEmailSender, AuthMessageSender>(); | ||||||
| @ -102,29 +105,10 @@ namespace eShopOnContainers.Identity | |||||||
|                     template: "{controller=Home}/{action=Index}/{id?}"); |                     template: "{controller=Home}/{action=Index}/{id?}"); | ||||||
|             }); |             }); | ||||||
| 
 | 
 | ||||||
|             MigrateDb(app); |             //Seed Data | ||||||
|         } |             var hasher = new PasswordHasher<ApplicationUser>(); | ||||||
| 
 |             new ApplicationContextSeed(hasher).SeedAsync(app, loggerFactory) | ||||||
|         int retries = 0; |             .Wait(); | ||||||
| 
 |  | ||||||
|         private void MigrateDb(IApplicationBuilder app) |  | ||||||
|         { |  | ||||||
|             try |  | ||||||
|             { |  | ||||||
|                 var context = (ApplicationDbContext)app |  | ||||||
|                     .ApplicationServices.GetService(typeof(ApplicationDbContext)); |  | ||||||
|                 using (context) |  | ||||||
|                 { |  | ||||||
|                     context.Database.Migrate(); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|             } |  | ||||||
|             catch (Exception) |  | ||||||
|             { |  | ||||||
|                 retries++; |  | ||||||
|                 if (retries < 2) |  | ||||||
|                     MigrateDb(app); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,10 +0,0 @@ | |||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Confirm Email"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| <div> |  | ||||||
|     <p> |  | ||||||
|         Thank you for confirming your email. Please <a asp-controller="Account" asp-action="Login">Click here to Log in</a>. |  | ||||||
|     </p> |  | ||||||
| </div> |  | ||||||
| @ -1,35 +0,0 @@ | |||||||
| @model ExternalLoginConfirmationViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Register"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| <h3>Associate your @ViewData["LoginProvider"] account.</h3> |  | ||||||
| 
 |  | ||||||
| <form asp-controller="Account" asp-action="ExternalLoginConfirmation" asp-route-returnurl="@ViewData["ReturnUrl"]" method="post" class="form-horizontal"> |  | ||||||
|     <h4>Association Form</h4> |  | ||||||
|     <hr /> |  | ||||||
|     <div asp-validation-summary="All" class="text-danger"></div> |  | ||||||
| 
 |  | ||||||
|     <p class="text-info"> |  | ||||||
|         You've successfully authenticated with <strong>@ViewData["LoginProvider"]</strong>. |  | ||||||
|         Please enter an email address for this site below and click the Register button to finish |  | ||||||
|         logging in. |  | ||||||
|     </p> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="Email" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="Email" class="form-control" /> |  | ||||||
|             <span asp-validation-for="Email" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <div class="col-md-offset-2 col-md-10"> |  | ||||||
|             <button type="submit" class="btn btn-default">Register</button> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </form> |  | ||||||
| 
 |  | ||||||
| @section Scripts { |  | ||||||
|     @{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); } |  | ||||||
| } |  | ||||||
| @ -1,8 +0,0 @@ | |||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Login Failure"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <header> |  | ||||||
|     <h2>@ViewData["Title"].</h2> |  | ||||||
|     <p class="text-danger">Unsuccessful login with service.</p> |  | ||||||
| </header> |  | ||||||
| @ -1,31 +0,0 @@ | |||||||
| @model ForgotPasswordViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Forgot your password?"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"]</h2> |  | ||||||
| <p> |  | ||||||
|     For more information on how to enable reset password please see this <a href="http://go.microsoft.com/fwlink/?LinkID=532713">article</a>. |  | ||||||
| </p> |  | ||||||
| 
 |  | ||||||
| @*<form asp-controller="Account" asp-action="ForgotPassword" method="post" class="form-horizontal"> |  | ||||||
|     <h4>Enter your email.</h4> |  | ||||||
|     <hr /> |  | ||||||
|     <div asp-validation-summary="All" class="text-danger"></div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="Email" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="Email" class="form-control" /> |  | ||||||
|             <span asp-validation-for="Email" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <div class="col-md-offset-2 col-md-10"> |  | ||||||
|             <button type="submit" class="btn btn-default">Submit</button> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </form>*@ |  | ||||||
| 
 |  | ||||||
| @section Scripts { |  | ||||||
|     @{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); } |  | ||||||
| } |  | ||||||
| @ -1,8 +0,0 @@ | |||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Forgot Password Confirmation"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| <p> |  | ||||||
|     Please check your email to reset your password. |  | ||||||
| </p> |  | ||||||
| @ -1,8 +0,0 @@ | |||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Locked out"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <header> |  | ||||||
|     <h1 class="text-danger">Locked out.</h1> |  | ||||||
|     <p class="text-danger">This account has been locked out, please try again later.</p> |  | ||||||
| </header> |  | ||||||
| @ -1,6 +1,6 @@ | |||||||
| @model eShopOnContainers.Identity.Models.AccountViewModels.LoggedOutViewModel | @model eShopOnContainers.Identity.Models.AccountViewModels.LoggedOutViewModel | ||||||
| 
 | 
 | ||||||
| <div class="page-header"> | <div class="container page-header"> | ||||||
|     <h1> |     <h1> | ||||||
|         Logout |         Logout | ||||||
|         <small>You are now logged out</small> |         <small>You are now logged out</small> | ||||||
|  | |||||||
| @ -1,6 +1,6 @@ | |||||||
| @model eShopOnContainers.Identity.Models.AccountViewModels.LogoutViewModel | @model eShopOnContainers.Identity.Models.AccountViewModels.LogoutViewModel | ||||||
| 
 | 
 | ||||||
| <div class="logout-page"> | <div class="container logout-page"> | ||||||
|     <div class="page-header"> |     <div class="page-header"> | ||||||
|         <h1>Logout</h1> |         <h1>Logout</h1> | ||||||
|     </div> |     </div> | ||||||
|  | |||||||
| @ -1,43 +0,0 @@ | |||||||
| @model ResetPasswordViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Reset password"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| 
 |  | ||||||
| <form asp-controller="Account" asp-action="ResetPassword" method="post" class="form-horizontal"> |  | ||||||
|     <h4>Reset your password.</h4> |  | ||||||
|     <hr /> |  | ||||||
|     <div asp-validation-summary="All" class="text-danger"></div> |  | ||||||
|     <input asp-for="Code" type="hidden" /> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="Email" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="Email" class="form-control" /> |  | ||||||
|             <span asp-validation-for="Email" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="Password" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="Password" class="form-control" /> |  | ||||||
|             <span asp-validation-for="Password" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="ConfirmPassword" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="ConfirmPassword" class="form-control" /> |  | ||||||
|             <span asp-validation-for="ConfirmPassword" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <div class="col-md-offset-2 col-md-10"> |  | ||||||
|             <button type="submit" class="btn btn-default">Reset</button> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </form> |  | ||||||
| 
 |  | ||||||
| @section Scripts { |  | ||||||
|     @{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); } |  | ||||||
| } |  | ||||||
| @ -1,8 +0,0 @@ | |||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Reset password confirmation"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h1>@ViewData["Title"].</h1> |  | ||||||
| <p> |  | ||||||
|     Your password has been reset. Please <a asp-controller="Account" asp-action="Login">Click here to log in</a>. |  | ||||||
| </p> |  | ||||||
| @ -1,21 +0,0 @@ | |||||||
| @model SendCodeViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Send Verification Code"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| 
 |  | ||||||
| <form asp-controller="Account" asp-action="SendCode" asp-route-returnurl="@Model.ReturnUrl" method="post" class="form-horizontal"> |  | ||||||
|     <input asp-for="RememberMe" type="hidden" /> |  | ||||||
|     <div class="row"> |  | ||||||
|         <div class="col-md-8"> |  | ||||||
|             Select Two-Factor Authentication Provider: |  | ||||||
|             <select asp-for="SelectedProvider" asp-items="Model.Providers"></select> |  | ||||||
|             <button type="submit" class="btn btn-default">Submit</button> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </form> |  | ||||||
| 
 |  | ||||||
| @section Scripts { |  | ||||||
|     @{await Html.RenderPartialAsync("_ValidationScriptsPartial"); } |  | ||||||
| } |  | ||||||
| @ -1,38 +0,0 @@ | |||||||
| @model VerifyCodeViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Verify"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| 
 |  | ||||||
| <form asp-controller="Account" asp-action="VerifyCode" asp-route-returnurl="@ViewData["ReturnUrl"]" method="post" class="form-horizontal"> |  | ||||||
|     <div asp-validation-summary="All" class="text-danger"></div> |  | ||||||
|     <input asp-for="Provider" type="hidden" /> |  | ||||||
|     <input asp-for="RememberMe" type="hidden" /> |  | ||||||
|     <h4>@ViewData["Status"]</h4> |  | ||||||
|     <hr /> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="Code" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="Code" class="form-control" /> |  | ||||||
|             <span asp-validation-for="Code" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <div class="col-md-offset-2 col-md-10"> |  | ||||||
|             <div class="checkbox"> |  | ||||||
|                 <input asp-for="RememberBrowser" /> |  | ||||||
|                 <label asp-for="RememberBrowser"></label> |  | ||||||
|             </div> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <div class="col-md-offset-2 col-md-10"> |  | ||||||
|             <button type="submit" class="btn btn-default">Submit</button> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </form> |  | ||||||
| 
 |  | ||||||
| @section Scripts { |  | ||||||
|     @{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); } |  | ||||||
| } |  | ||||||
| @ -1,6 +1,6 @@ | |||||||
| @model eShopOnContainers.Identity.Models.AccountViewModels.ConsentViewModel | @model eShopOnContainers.Identity.Models.AccountViewModels.ConsentViewModel | ||||||
| 
 | 
 | ||||||
| <div class="page-consent"> | <div class="container page-consent"> | ||||||
|     <div class="row page-header"> |     <div class="row page-header"> | ||||||
|         <div class="col-sm-10"> |         <div class="col-sm-10"> | ||||||
|             @if (Model.ClientLogoUrl != null) |             @if (Model.ClientLogoUrl != null) | ||||||
|  | |||||||
| @ -1,27 +0,0 @@ | |||||||
| @model AddPhoneNumberViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Add Phone Number"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| <form asp-controller="Manage" asp-action="AddPhoneNumber" method="post" class="form-horizontal"> |  | ||||||
|     <h4>Add a phone number.</h4> |  | ||||||
|     <hr /> |  | ||||||
|     <div asp-validation-summary="All" class="text-danger"></div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="PhoneNumber" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="PhoneNumber" class="form-control" /> |  | ||||||
|             <span asp-validation-for="PhoneNumber" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <div class="col-md-offset-2 col-md-10"> |  | ||||||
|             <button type="submit" class="btn btn-default">Send verification code</button> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </form> |  | ||||||
| 
 |  | ||||||
| @section Scripts { |  | ||||||
|     @{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); } |  | ||||||
| } |  | ||||||
| @ -1,42 +0,0 @@ | |||||||
| @model ChangePasswordViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Change Password"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| 
 |  | ||||||
| <form asp-controller="Manage" asp-action="ChangePassword" method="post" class="form-horizontal"> |  | ||||||
|     <h4>Change Password Form</h4> |  | ||||||
|     <hr /> |  | ||||||
|     <div asp-validation-summary="All" class="text-danger"></div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="OldPassword" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="OldPassword" class="form-control" /> |  | ||||||
|             <span asp-validation-for="OldPassword" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="NewPassword" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="NewPassword" class="form-control" /> |  | ||||||
|             <span asp-validation-for="NewPassword" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="ConfirmPassword" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="ConfirmPassword" class="form-control" /> |  | ||||||
|             <span asp-validation-for="ConfirmPassword" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <div class="col-md-offset-2 col-md-10"> |  | ||||||
|             <button type="submit" class="btn btn-default">Change password</button> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </form> |  | ||||||
| 
 |  | ||||||
| @section Scripts { |  | ||||||
|     @{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); } |  | ||||||
| } |  | ||||||
| @ -1,71 +0,0 @@ | |||||||
| @model IndexViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Manage your account"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| <p class="text-success">@ViewData["StatusMessage"]</p> |  | ||||||
| 
 |  | ||||||
| <div> |  | ||||||
|     <h4>Change your account settings</h4> |  | ||||||
|     <hr /> |  | ||||||
|     <dl class="dl-horizontal"> |  | ||||||
|         <dt>Password:</dt> |  | ||||||
|         <dd> |  | ||||||
|             @if (Model.HasPassword) |  | ||||||
|             { |  | ||||||
|                 <a asp-controller="Manage" asp-action="ChangePassword" class="btn-bracketed">Change</a> |  | ||||||
|             } |  | ||||||
|             else |  | ||||||
|             { |  | ||||||
|                 <a asp-controller="Manage" asp-action="SetPassword" class="btn-bracketed">Create</a> |  | ||||||
|             } |  | ||||||
|         </dd> |  | ||||||
|         <dt>External Logins:</dt> |  | ||||||
|         <dd> |  | ||||||
| 
 |  | ||||||
|             @Model.Logins.Count <a asp-controller="Manage" asp-action="ManageLogins" class="btn-bracketed">Manage</a> |  | ||||||
|         </dd> |  | ||||||
|         <dt>Phone Number:</dt> |  | ||||||
|         <dd> |  | ||||||
|             <p> |  | ||||||
|                 Phone Numbers can used as a second factor of verification in two-factor authentication. |  | ||||||
|                 See <a href="http://go.microsoft.com/fwlink/?LinkID=532713">this article</a> |  | ||||||
|                 for details on setting up this ASP.NET application to support two-factor authentication using SMS. |  | ||||||
|             </p> |  | ||||||
|             @*@(Model.PhoneNumber ?? "None") |  | ||||||
|                 @if (Model.PhoneNumber != null) |  | ||||||
|                 { |  | ||||||
|                     <br /> |  | ||||||
|                     <a asp-controller="Manage" asp-action="AddPhoneNumber" class="btn-bracketed">Change</a> |  | ||||||
|                     <form asp-controller="Manage" asp-action="RemovePhoneNumber" method="post"> |  | ||||||
|                         [<button type="submit" class="btn-link">Remove</button>] |  | ||||||
|                     </form> |  | ||||||
|                 } |  | ||||||
|                 else |  | ||||||
|                 { |  | ||||||
|                     <a asp-controller="Manage" asp-action="AddPhoneNumber" class="btn-bracketed">Add</a> |  | ||||||
|                 }*@ |  | ||||||
|         </dd> |  | ||||||
| 
 |  | ||||||
|         <dt>Two-Factor Authentication:</dt> |  | ||||||
|         <dd> |  | ||||||
|             <p> |  | ||||||
|                 There are no two-factor authentication providers configured. See <a href="http://go.microsoft.com/fwlink/?LinkID=532713">this article</a> |  | ||||||
|                 for setting up this application to support two-factor authentication. |  | ||||||
|             </p> |  | ||||||
|             @*@if (Model.TwoFactor) |  | ||||||
|                 { |  | ||||||
|                     <form asp-controller="Manage" asp-action="DisableTwoFactorAuthentication" method="post" class="form-horizontal"> |  | ||||||
|                         Enabled <button type="submit" class="btn-link btn-bracketed">Disable</button> |  | ||||||
|                     </form> |  | ||||||
|                 } |  | ||||||
|                 else |  | ||||||
|                 { |  | ||||||
|                     <form asp-controller="Manage" asp-action="EnableTwoFactorAuthentication" method="post" class="form-horizontal"> |  | ||||||
|                         <button type="submit" class="btn-link btn-bracketed">Enable</button> Disabled |  | ||||||
|                     </form> |  | ||||||
|                 }*@ |  | ||||||
|         </dd> |  | ||||||
|     </dl> |  | ||||||
| </div> |  | ||||||
| @ -1,54 +0,0 @@ | |||||||
| @model ManageLoginsViewModel |  | ||||||
| @using Microsoft.AspNetCore.Http.Authentication |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Manage your external logins"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| 
 |  | ||||||
| <p class="text-success">@ViewData["StatusMessage"]</p> |  | ||||||
| @if (Model.CurrentLogins.Count > 0) |  | ||||||
| { |  | ||||||
|     <h4>Registered Logins</h4> |  | ||||||
|     <table class="table"> |  | ||||||
|         <tbody> |  | ||||||
|             @for (var index = 0; index < Model.CurrentLogins.Count; index++) |  | ||||||
|             { |  | ||||||
|                 <tr> |  | ||||||
|                     <td>@Model.CurrentLogins[index].LoginProvider</td> |  | ||||||
|                     <td> |  | ||||||
|                         @if ((bool)ViewData["ShowRemoveButton"]) |  | ||||||
|                         { |  | ||||||
|                             <form asp-controller="Manage" asp-action="RemoveLogin" method="post" class="form-horizontal"> |  | ||||||
|                                 <div> |  | ||||||
|                                     <input asp-for="@Model.CurrentLogins[index].LoginProvider" name="LoginProvider" type="hidden" /> |  | ||||||
|                                     <input asp-for="@Model.CurrentLogins[index].ProviderKey" name="ProviderKey" type="hidden" /> |  | ||||||
|                                     <input type="submit" class="btn btn-default" value="Remove" title="Remove this @Model.CurrentLogins[index].LoginProvider login from your account" /> |  | ||||||
|                                 </div> |  | ||||||
|                             </form> |  | ||||||
|                         } |  | ||||||
|                         else |  | ||||||
|                         { |  | ||||||
|                             @:   |  | ||||||
|                         } |  | ||||||
|                     </td> |  | ||||||
|                 </tr> |  | ||||||
|             } |  | ||||||
|         </tbody> |  | ||||||
|     </table> |  | ||||||
| } |  | ||||||
| @if (Model.OtherLogins.Count > 0) |  | ||||||
| { |  | ||||||
|     <h4>Add another service to log in.</h4> |  | ||||||
|     <hr /> |  | ||||||
|     <form asp-controller="Manage" asp-action="LinkLogin" method="post" class="form-horizontal"> |  | ||||||
|         <div id="socialLoginList"> |  | ||||||
|             <p> |  | ||||||
|                 @foreach (var provider in Model.OtherLogins) |  | ||||||
|                 { |  | ||||||
|                     <button type="submit" class="btn btn-default" name="provider" value="@provider.AuthenticationScheme" title="Log in using your @provider.DisplayName account">@provider.AuthenticationScheme</button> |  | ||||||
|                 } |  | ||||||
|             </p> |  | ||||||
|         </div> |  | ||||||
|     </form> |  | ||||||
| } |  | ||||||
| @ -1,38 +0,0 @@ | |||||||
| @model SetPasswordViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Set Password"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <p class="text-info"> |  | ||||||
|     You do not have a local username/password for this site. Add a local |  | ||||||
|     account so you can log in without an external login. |  | ||||||
| </p> |  | ||||||
| 
 |  | ||||||
| <form asp-controller="Manage" asp-action="SetPassword" asp-route-returnurl="@ViewData["ReturnUrl"]" method="post" class="form-horizontal"> |  | ||||||
|     <h4>Set your password</h4> |  | ||||||
|     <hr /> |  | ||||||
|     <div asp-validation-summary="All" class="text-danger"></div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="NewPassword" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="NewPassword" class="form-control" /> |  | ||||||
|             <span asp-validation-for="NewPassword" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="ConfirmPassword" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="ConfirmPassword" class="form-control" /> |  | ||||||
|             <span asp-validation-for="ConfirmPassword" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <div class="col-md-offset-2 col-md-10"> |  | ||||||
|             <button type="submit" class="btn btn-default">Set password</button> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </form> |  | ||||||
| 
 |  | ||||||
| @section Scripts { |  | ||||||
|     @{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); } |  | ||||||
| } |  | ||||||
| @ -1,30 +0,0 @@ | |||||||
| @model VerifyPhoneNumberViewModel |  | ||||||
| @{ |  | ||||||
|     ViewData["Title"] = "Verify Phone Number"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| <h2>@ViewData["Title"].</h2> |  | ||||||
| 
 |  | ||||||
| <form asp-controller="Manage" asp-action="VerifyPhoneNumber" asp-route-returnurl="@ViewData["ReturnUrl"]" method="post" class="form-horizontal"> |  | ||||||
|     <input asp-for="PhoneNumber" type="hidden" /> |  | ||||||
|     <h4>Add a phone number.</h4> |  | ||||||
|     <h5>@ViewData["Status"]</h5> |  | ||||||
|     <hr /> |  | ||||||
|     <div asp-validation-summary="All" class="text-danger"></div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <label asp-for="Code" class="col-md-2 control-label"></label> |  | ||||||
|         <div class="col-md-10"> |  | ||||||
|             <input asp-for="Code" class="form-control" /> |  | ||||||
|             <span asp-validation-for="Code" class="text-danger"></span> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
|     <div class="form-group"> |  | ||||||
|         <div class="col-md-offset-2 col-md-10"> |  | ||||||
|             <button type="submit" class="btn btn-default">Submit</button> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </form> |  | ||||||
| 
 |  | ||||||
| @section Scripts { |  | ||||||
|     @{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); } |  | ||||||
| } |  | ||||||
| @ -21,7 +21,7 @@ | |||||||
|                 <div> |                 <div> | ||||||
|                     <a asp-action="Register" asp-controller="Account">Register User</a> |                     <a asp-action="Register" asp-controller="Account">Register User</a> | ||||||
|                 </div> |                 </div> | ||||||
|                 @if (User.Identity.IsAuthenticated) |                 @*@if (User.Identity.IsAuthenticated) | ||||||
|                 { |                 { | ||||||
|                     <ul class="nav navbar-nav"> |                     <ul class="nav navbar-nav"> | ||||||
|                         <li class="dropdown"> |                         <li class="dropdown"> | ||||||
| @ -31,7 +31,7 @@ | |||||||
|                             </ul> |                             </ul> | ||||||
|                         </li> |                         </li> | ||||||
|                     </ul> |                     </ul> | ||||||
|                 } |                 }*@ | ||||||
|             </div> |             </div> | ||||||
|         </div> |         </div> | ||||||
|     </div> |     </div> | ||||||
|  | |||||||
| @ -1,7 +1,6 @@ | |||||||
| { | { | ||||||
|   "ConnectionStrings": { |   "ConnectionStrings": { | ||||||
|     "DefaultConnection": "Server=identity.data;Database=aspnet-Microsoft.eShopOnContainers;User Id=sa;Password=Pass@word" |     "DefaultConnection": "Server=127.0.0.1,5433;Database=aspnet-Microsoft.eShopOnContainers;User Id=sa;Password=Pass@word" | ||||||
|     //"DefaultConnection": "Server=127.0.0.1,5433;Database=aspnet-Microsoft.eShopOnContainers;User Id=sa;Password=Pass@word" |  | ||||||
|   }, |   }, | ||||||
|   "MvcClient": "http://localhost:5100", |   "MvcClient": "http://localhost:5100", | ||||||
|   "SpaClient": "http://localhost:5104", |   "SpaClient": "http://localhost:5104", | ||||||
|  | |||||||
| @ -1,11 +1,11 @@ | |||||||
| version: '2' | version: '2' | ||||||
| 
 | 
 | ||||||
| services: | services: | ||||||
| identity.service: |   identity.service: | ||||||
|     image: eshop/identity |     image: eshop/identity | ||||||
|     environment: |     environment: | ||||||
|       - SpaClient=http://localhost:5104 |       - SpaClient=http://localhost:5104 | ||||||
|       - ConnectionString=Server=identity.data;Database=aspnet-Microsoft.eShopOnContainers;User Id=sa;Password=Pass@word |       - ConnectionStrings__DefaultConnection=Server=identity.data;Database=aspnet-Microsoft.eShopOnContainers;User Id=sa;Password=Pass@word | ||||||
|       #- MvcClient=http://104.40.62.65:5100             #Remote: VM Needs to have public access at 5105.  |       #- MvcClient=http://104.40.62.65:5100             #Remote: VM Needs to have public access at 5105.  | ||||||
|       - MvcClient=http://localhost:5100                 #Local: You need a entry in windows host file to run identity in local docker.  |       - MvcClient=http://localhost:5100                 #Local: You need a entry in windows host file to run identity in local docker.  | ||||||
|     ports: |     ports: | ||||||
|  | |||||||
| @ -14,6 +14,7 @@ | |||||||
|   position: relative; |   position: relative; | ||||||
|   top: -10px; |   top: -10px; | ||||||
| } | } | ||||||
|  | 
 | ||||||
| .page-consent .client-logo { | .page-consent .client-logo { | ||||||
|   float: left; |   float: left; | ||||||
| } | } | ||||||
| @ -902,3 +903,16 @@ form .col-md-4 { | |||||||
|         max-width: 360px; |         max-width: 360px; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | @media screen and (max-width: 415px) { | ||||||
|  |     .account-login-container { | ||||||
|  |         margin-left: -50px; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     .page-consent { | ||||||
|  |         margin-left: 10px; | ||||||
|  |         margin-right: 80px; | ||||||
|  |         padding-right: 0px; | ||||||
|  |         padding-left: 0px; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -2,13 +2,16 @@ | |||||||
| { | { | ||||||
|     using Application.Commands; |     using Application.Commands; | ||||||
|     using Application.Queries; |     using Application.Queries; | ||||||
|  |     using AspNetCore.Authorization; | ||||||
|     using MediatR; |     using MediatR; | ||||||
|     using Microsoft.AspNetCore.Mvc; |     using Microsoft.AspNetCore.Mvc; | ||||||
|     using Models; |     using Models; | ||||||
|     using System; |     using System; | ||||||
|  |     using System.Collections.Generic; | ||||||
|     using System.Threading.Tasks; |     using System.Threading.Tasks; | ||||||
| 
 | 
 | ||||||
|     [Route("api/v1/[controller]")]
 |     [Route("api/v1/[controller]")]
 | ||||||
|  |     [Authorize] | ||||||
|     public class OrdersController : Controller |     public class OrdersController : Controller | ||||||
|     { |     { | ||||||
|         private readonly IMediator _mediator; |         private readonly IMediator _mediator; | ||||||
| @ -32,24 +35,14 @@ | |||||||
| 
 | 
 | ||||||
|         [Route("new")] |         [Route("new")] | ||||||
|         [HttpPost] |         [HttpPost] | ||||||
|         public async Task<IActionResult> AddOrder([FromBody]NewOrderViewModel order) |         public async Task<IActionResult> AddOrder([FromBody]NewOrderRequest order) | ||||||
|         { |         { | ||||||
|             var newOrderRequest = new NewOrderRequest() |             if (order.CardExpiration == DateTime.MinValue) | ||||||
|             { |                 order.CardExpiration = DateTime.Now; | ||||||
|                 Buyer =GetUserName(), //TODO |  | ||||||
|                 CardTypeId = 1, //TODO |  | ||||||
|                 CardHolderName = order.CardHolderName, |  | ||||||
|                 CardNumber = order.CardNumber, |  | ||||||
|                 CardExpiration = order.CardExpiration, |  | ||||||
|                 CardSecurityNumber = order.CardSecurityNumber, |  | ||||||
|                 State = order.ShippingState, |  | ||||||
|                 City = order.ShippingCity, |  | ||||||
|                 Country = order.ShippingCountry, |  | ||||||
|                 Street = order.ShippingStreet |  | ||||||
|             }; |  | ||||||
| 
 | 
 | ||||||
|             var added = await _mediator.SendAsync(newOrderRequest); |             order.Buyer = GetUserName(); | ||||||
| 
 | 
 | ||||||
|  |             var added = await _mediator.SendAsync(order); | ||||||
|             if (added) |             if (added) | ||||||
|             { |             { | ||||||
|                 return Ok(); |                 return Ok(); | ||||||
| @ -62,10 +55,15 @@ | |||||||
|         [HttpGet] |         [HttpGet] | ||||||
|         public async Task<IActionResult> GetOrder(int orderId) |         public async Task<IActionResult> GetOrder(int orderId) | ||||||
|         { |         { | ||||||
|             var order = await _orderQueries.GetOrder(orderId); |             try | ||||||
| 
 |             { | ||||||
|              |                 var order = await _orderQueries.GetOrder(orderId); | ||||||
|             return Ok(order); |                 return Ok(order); | ||||||
|  |             } | ||||||
|  |             catch (KeyNotFoundException) | ||||||
|  |             { | ||||||
|  |                 return NotFound(); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         [Route("")] |         [Route("")] | ||||||
| @ -74,7 +72,6 @@ | |||||||
|         { |         { | ||||||
|             var orders = await _orderQueries.GetOrders(); |             var orders = await _orderQueries.GetOrders(); | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|             return Ok(orders); |             return Ok(orders); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -87,9 +84,13 @@ | |||||||
|             return Ok(cardTypes); |             return Ok(cardTypes); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         /// <summary> | ||||||
|  |         /// Returns the GUID corresponding to the Id of the authenticated user. | ||||||
|  |         /// </summary> | ||||||
|  |         /// <returns>GUID (string)</returns> | ||||||
|         string GetUserName() |         string GetUserName() | ||||||
|         { |         { | ||||||
|             return "MOCK"; |             return HttpContext.User.FindFirst("sub").Value; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -4,5 +4,5 @@ FROM microsoft/aspnetcore:1.0.1 | |||||||
| ENTRYPOINT ["dotnet", "Ordering.API.dll"] | ENTRYPOINT ["dotnet", "Ordering.API.dll"] | ||||||
| ARG source=. | ARG source=. | ||||||
| WORKDIR /app | WORKDIR /app | ||||||
| EXPOSE 80 | ENV ASPNETCORE_URLS http://*:5102 | ||||||
| COPY $source . | COPY $source . | ||||||
|  | |||||||
| @ -1,9 +1,11 @@ | |||||||
| namespace Microsoft.eShopOnContainers.Services.Ordering.API.Infrastructure.Filters | namespace Microsoft.eShopOnContainers.Services.Ordering.API.Infrastructure.Filters | ||||||
| { | { | ||||||
|  |     using AspNetCore.Mvc; | ||||||
|     using Microsoft.AspNetCore.Hosting; |     using Microsoft.AspNetCore.Hosting; | ||||||
|     using Microsoft.AspNetCore.Mvc.Filters; |     using Microsoft.AspNetCore.Mvc.Filters; | ||||||
|     using Microsoft.eShopOnContainers.Services.Ordering.API.Infrastructure.ActionResults; |     using Microsoft.eShopOnContainers.Services.Ordering.API.Infrastructure.ActionResults; | ||||||
|     using Microsoft.Extensions.Logging; |     using Microsoft.Extensions.Logging; | ||||||
|  |     using System; | ||||||
| 
 | 
 | ||||||
|     public class HttpGlobalExceptionFilter : IExceptionFilter |     public class HttpGlobalExceptionFilter : IExceptionFilter | ||||||
|     { |     { | ||||||
| @ -22,17 +24,30 @@ | |||||||
|                 context.Exception, |                 context.Exception, | ||||||
|                 context.Exception.Message); |                 context.Exception.Message); | ||||||
| 
 | 
 | ||||||
|             var json = new JsonErrorResponse |             if (context.Exception.GetType() == typeof(ArgumentException)) //TODO:Select a common exception for application like EshopException | ||||||
|             { |             { | ||||||
|                 Messages = new[] { "An error ocurr.Try it again." } |                 var json = new JsonErrorResponse | ||||||
|             }; |                 { | ||||||
|  |                     Messages = new[] { context.Exception.Message } | ||||||
|  |                 }; | ||||||
| 
 | 
 | ||||||
|             if (env.IsDevelopment()) |                 context.Result = new BadRequestObjectResult(json); | ||||||
|  |             } | ||||||
|  |             else | ||||||
|             { |             { | ||||||
|                 json.DeveloperMeesage = context.Exception; |                 var json = new JsonErrorResponse | ||||||
|  |                 { | ||||||
|  |                     Messages = new[] { "An error ocurr.Try it again." } | ||||||
|  |                 }; | ||||||
|  | 
 | ||||||
|  |                 if (env.IsDevelopment()) | ||||||
|  |                 { | ||||||
|  |                     json.DeveloperMeesage = context.Exception; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 context.Result = new InternalServerErrorObjectResult(json); | ||||||
|             } |             } | ||||||
|              |              | ||||||
|             context.Result = new InternalServerErrorObjectResult(json); |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private class JsonErrorResponse |         private class JsonErrorResponse | ||||||
|  | |||||||
| @ -172,6 +172,7 @@ namespace Ordering.API.Infrastructure.Migrations | |||||||
|                     OrderId = table.Column<int>(nullable: false), |                     OrderId = table.Column<int>(nullable: false), | ||||||
|                     ProductId = table.Column<int>(nullable: false), |                     ProductId = table.Column<int>(nullable: false), | ||||||
|                     ProductName = table.Column<string>(nullable: false), |                     ProductName = table.Column<string>(nullable: false), | ||||||
|  |                     PictureUrl = table.Column<string>(nullable: false), | ||||||
|                     UnitPrice = table.Column<decimal>(nullable: false), |                     UnitPrice = table.Column<decimal>(nullable: false), | ||||||
|                     Units = table.Column<int>(nullable: false, defaultValue: 1) |                     Units = table.Column<int>(nullable: false, defaultValue: 1) | ||||||
|                 }, |                 }, | ||||||
|  | |||||||
| @ -1,4 +1,5 @@ | |||||||
| using System; | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
| 
 | 
 | ||||||
| namespace Microsoft.eShopOnContainers.Services.Ordering.API.Models | namespace Microsoft.eShopOnContainers.Services.Ordering.API.Models | ||||||
| { | { | ||||||
| @ -21,5 +22,12 @@ namespace Microsoft.eShopOnContainers.Services.Ordering.API.Models | |||||||
|         public DateTime CardExpiration { get; set; } |         public DateTime CardExpiration { get; set; } | ||||||
| 
 | 
 | ||||||
|         public string CardSecurityNumber { get; set; } |         public string CardSecurityNumber { get; set; } | ||||||
|  | 
 | ||||||
|  |         public List<OrderItemViewModel> Items { get; set; } | ||||||
|  | 
 | ||||||
|  |         public NewOrderViewModel() | ||||||
|  |         { | ||||||
|  |             Items = new List<OrderItemViewModel>(); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,17 @@ | |||||||
|  | namespace Microsoft.eShopOnContainers.Services.Ordering.API.Models | ||||||
|  | { | ||||||
|  |     public class OrderItemViewModel | ||||||
|  |     { | ||||||
|  |         public int ProductId { get;  set; } | ||||||
|  | 
 | ||||||
|  |         public string ProductName { get;  set; } | ||||||
|  | 
 | ||||||
|  |         public decimal UnitPrice { get;  set; } | ||||||
|  | 
 | ||||||
|  |         public decimal Discount { get;  set; } | ||||||
|  | 
 | ||||||
|  |         public int Units { get;  set; } | ||||||
|  | 
 | ||||||
|  |         public string PictureUrl { get; set; } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -15,9 +15,9 @@ namespace Microsoft.eShopOnContainers.Services.Ordering.API | |||||||
|             var host = new WebHostBuilder() |             var host = new WebHostBuilder() | ||||||
|                 .UseKestrel() |                 .UseKestrel() | ||||||
|                 .UseContentRoot(Directory.GetCurrentDirectory()) |                 .UseContentRoot(Directory.GetCurrentDirectory()) | ||||||
|  |                 .UseUrls("http://0.0.0.0:5102") | ||||||
|                 .UseIISIntegration() |                 .UseIISIntegration() | ||||||
|                 .UseStartup<Startup>() |                 .UseStartup<Startup>() | ||||||
|                 //.UseUrls("http://localhost:5555")  //Just for KESTREL |  | ||||||
|                 .Build(); |                 .Build(); | ||||||
| 
 | 
 | ||||||
|             host.Run(); |             host.Run(); | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
|     "windowsAuthentication": false, |     "windowsAuthentication": false, | ||||||
|     "anonymousAuthentication": true, |     "anonymousAuthentication": true, | ||||||
|     "iisExpress": { |     "iisExpress": { | ||||||
|       "applicationUrl": "http://localhost:2446/", |       "applicationUrl": "http://localhost:5102/", | ||||||
|       "sslPort": 0 |       "sslPort": 0 | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|  | |||||||
| @ -45,9 +45,7 @@ | |||||||
| 
 | 
 | ||||||
|             services.AddMvc(options => |             services.AddMvc(options => | ||||||
|             { |             { | ||||||
| 
 |  | ||||||
|                 options.Filters.Add(typeof(HttpGlobalExceptionFilter)); |                 options.Filters.Add(typeof(HttpGlobalExceptionFilter)); | ||||||
| 
 |  | ||||||
|             }).AddControllersAsServices(); |             }).AddControllersAsServices(); | ||||||
| 
 | 
 | ||||||
|             services.AddEntityFrameworkSqlServer() |             services.AddEntityFrameworkSqlServer() | ||||||
| @ -70,12 +68,19 @@ | |||||||
|                 }); |                 }); | ||||||
|             }); |             }); | ||||||
| 
 | 
 | ||||||
|  |             services.AddCors(options => | ||||||
|  |             { | ||||||
|  |                 options.AddPolicy("CorsPolicy", | ||||||
|  |                     builder => builder.AllowAnyOrigin() | ||||||
|  |                     .AllowAnyMethod() | ||||||
|  |                     .AllowAnyHeader() | ||||||
|  |                     .AllowCredentials()); | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|             services.AddSingleton<IConfiguration>(this.Configuration); |             services.AddSingleton<IConfiguration>(this.Configuration); | ||||||
| 
 | 
 | ||||||
|             services.AddOptions(); |             services.AddOptions(); | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|             //configure autofac |             //configure autofac | ||||||
| 
 | 
 | ||||||
|             var container = new ContainerBuilder(); |             var container = new ContainerBuilder(); | ||||||
| @ -84,7 +89,6 @@ | |||||||
|             container.RegisterModule(new MediatorModule()); |             container.RegisterModule(new MediatorModule()); | ||||||
|             container.RegisterModule(new ApplicationModule()); |             container.RegisterModule(new ApplicationModule()); | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|             return new AutofacServiceProvider(container.Build()); |             return new AutofacServiceProvider(container.Build()); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -98,6 +102,17 @@ | |||||||
|                 app.UseDeveloperExceptionPage(); |                 app.UseDeveloperExceptionPage(); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             app.UseCors("CorsPolicy"); | ||||||
|  | 
 | ||||||
|  |             var identityUrl = Configuration.GetValue<string>("IdentityUrl"); | ||||||
|  | 
 | ||||||
|  |             app.UseIdentityServerAuthentication(new IdentityServerAuthenticationOptions | ||||||
|  |             { | ||||||
|  |                 Authority = identityUrl.ToString(), | ||||||
|  |                 ScopeName = "orders", | ||||||
|  |                 RequireHttpsMetadata = false | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
|             app.UseMvcWithDefaultRoute(); |             app.UseMvcWithDefaultRoute(); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,10 +0,0 @@ | |||||||
| { |  | ||||||
|   "Logging": { |  | ||||||
|     "IncludeScopes": false, |  | ||||||
|     "LogLevel": { |  | ||||||
|       "Default": "Debug", |  | ||||||
|       "System": "Information", |  | ||||||
|       "Microsoft": "Information" |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @ -27,7 +27,8 @@ | |||||||
|     "Ordering.Domain": "1.0.0-*", |     "Ordering.Domain": "1.0.0-*", | ||||||
|     "Ordering.Application": "1.0.0-*", |     "Ordering.Application": "1.0.0-*", | ||||||
|     "Ordering.Infrastructure": "1.0.0-*", |     "Ordering.Infrastructure": "1.0.0-*", | ||||||
|     "System.Reflection": "4.3.0" |     "System.Reflection": "4.3.0", | ||||||
|  |     "IdentityServer4.AccessTokenValidation": "1.0.1-rc3" | ||||||
|   }, |   }, | ||||||
|   "tools": { |   "tools": { | ||||||
|     "Microsoft.EntityFrameworkCore.Tools": "1.0.0-preview2-final", |     "Microsoft.EntityFrameworkCore.Tools": "1.0.0-preview2-final", | ||||||
| @ -56,7 +57,7 @@ | |||||||
|       "wwwroot", |       "wwwroot", | ||||||
|       "Views", |       "Views", | ||||||
|       "Areas/**/Views", |       "Areas/**/Views", | ||||||
|       "appsettings.json", |       "settings.json", | ||||||
|       "web.config", |       "web.config", | ||||||
|       "docker-compose.yml", |       "docker-compose.yml", | ||||||
|       "docker-compose.debug.yml", |       "docker-compose.debug.yml", | ||||||
|  | |||||||
| @ -1,4 +1,12 @@ | |||||||
| { | { | ||||||
|   //"ConnectionString": "Server=ordering.data;Database=Microsoft.eShopOnContainers.Services.OrderingDb;User Id=sa;Password=Pass@word;" |   "ConnectionString": "Server=tcp:127.0.0.1,5433;Database=Microsoft.eShopOnContainers.Services.OrderingDb;User Id=sa;Password=Pass@word;", | ||||||
|   "ConnectionString": "Server=tcp:127.0.0.1,5432;Database=Microsoft.eShopOnContainers.Services.OrderingDb;User Id=sa;Password=Pass@word;" |   "IdentityUrl": "http://identity.service:5105",  | ||||||
|  |   "Logging": { | ||||||
|  |     "IncludeScopes": false, | ||||||
|  |     "LogLevel": { | ||||||
|  |       "Default": "Debug", | ||||||
|  |       "System": "Information", | ||||||
|  |       "Microsoft": "Information" | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -30,7 +30,7 @@ | |||||||
|         } |         } | ||||||
|         public async Task<bool> Handle(NewOrderRequest message) |         public async Task<bool> Handle(NewOrderRequest message) | ||||||
|         { |         { | ||||||
|             //find buyer/payment or add a new one  |             //find buyer/payment or add a new one buyer/payment  | ||||||
| 
 | 
 | ||||||
|             var buyer = await _buyerRepository.FindAsync(message.Buyer); |             var buyer = await _buyerRepository.FindAsync(message.Buyer); | ||||||
| 
 | 
 | ||||||
| @ -41,9 +41,11 @@ | |||||||
| 
 | 
 | ||||||
|             var payment = GetExistingPaymentOrAddANewOne(buyer, message); |             var payment = GetExistingPaymentOrAddANewOne(buyer, message); | ||||||
| 
 | 
 | ||||||
|             await _buyerRepository.UnitOfWork.SaveChangesAsync(); |             await _buyerRepository.UnitOfWork | ||||||
|  |                 .SaveChangesAsync(); | ||||||
|  | 
 | ||||||
|  |             //create order for buyer and payment method | ||||||
| 
 | 
 | ||||||
|             //create order |  | ||||||
|             var order = CreateOrder(buyer.Id, payment.Id, 0); |             var order = CreateOrder(buyer.Id, payment.Id, 0); | ||||||
|             order.SetAddress( new Address() |             order.SetAddress( new Address() | ||||||
|             { |             { | ||||||
| @ -53,9 +55,15 @@ | |||||||
|                 ZipCode = message.ZipCode |                 ZipCode = message.ZipCode | ||||||
|             }); |             }); | ||||||
| 
 | 
 | ||||||
|  |             foreach (var item in message.OrderItems) | ||||||
|  |             { | ||||||
|  |                 order.AddOrderItem(item); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|             _orderRepository.Add(order); |             _orderRepository.Add(order); | ||||||
| 
 | 
 | ||||||
|             var result = await _orderRepository.UnitOfWork.SaveChangesAsync(); |             var result = await _orderRepository.UnitOfWork | ||||||
|  |                 .SaveChangesAsync(); | ||||||
| 
 | 
 | ||||||
|             return result > 0; |             return result > 0; | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -2,10 +2,15 @@ | |||||||
| { | { | ||||||
|     using System; |     using System; | ||||||
|     using MediatR; |     using MediatR; | ||||||
|  |     using Domain; | ||||||
|  |     using System.Collections; | ||||||
|  |     using System.Collections.Generic; | ||||||
| 
 | 
 | ||||||
|     public class NewOrderRequest |     public class NewOrderRequest | ||||||
|         :IAsyncRequest<bool> |         :IAsyncRequest<bool> | ||||||
|     { |     { | ||||||
|  | 
 | ||||||
|  |         private readonly List<OrderItem> _orderItems; | ||||||
|         public string City { get; set; } |         public string City { get; set; } | ||||||
| 
 | 
 | ||||||
|         public string Street { get; set; } |         public string Street { get; set; } | ||||||
| @ -28,8 +33,16 @@ | |||||||
| 
 | 
 | ||||||
|         public string Buyer { get; set; } |         public string Buyer { get; set; } | ||||||
| 
 | 
 | ||||||
|  |         public IEnumerable<OrderItem> OrderItems => _orderItems; | ||||||
|  | 
 | ||||||
|  |         public void AddOrderItem(OrderItem item) | ||||||
|  |         { | ||||||
|  |             _orderItems.Add(item); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         public NewOrderRequest() |         public NewOrderRequest() | ||||||
|         { |         { | ||||||
|  |             _orderItems = new List<OrderItem>(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -5,6 +5,8 @@ | |||||||
|     using System.Data.SqlClient; |     using System.Data.SqlClient; | ||||||
|     using System.Threading.Tasks; |     using System.Threading.Tasks; | ||||||
|     using System; |     using System; | ||||||
|  |     using System.Dynamic; | ||||||
|  |     using System.Collections.Generic; | ||||||
| 
 | 
 | ||||||
|     public class OrderQueries |     public class OrderQueries | ||||||
|         :IOrderQueries |         :IOrderQueries | ||||||
| @ -23,7 +25,22 @@ | |||||||
|             { |             { | ||||||
|                 connection.Open(); |                 connection.Open(); | ||||||
| 
 | 
 | ||||||
|                 return await connection.QueryAsync<dynamic>("SELECT * FROM ordering.Orders where Id=@id",new { id }); |                 var result = await connection.QueryAsync<dynamic>( | ||||||
|  |                    @"select o.[Id] as ordernumber,o.OrderDate as date, os.Name as status, 
 | ||||||
|  |                         oi.ProductName as productname, oi.Units as units, oi.UnitPrice as unitprice, oi.PictureUrl as pictureurl,  | ||||||
|  | 						oa.Street as street, oa.City as city, oa.Country as country, oa.State as state, oa.ZipCode as zipcode | ||||||
|  |                         FROM ordering.Orders o | ||||||
|  |                         LEFT JOIN ordering.Orderitems oi ON o.Id = oi.orderid  | ||||||
|  |                         LEFT JOIN ordering.orderstatus os on o.StatusId = os.Id | ||||||
|  | 						LEFT JOIN ordering.address oa on o.ShippingAddressId = oa.Id | ||||||
|  |                         WHERE o.Id=@id"
 | ||||||
|  |                         , new { id } | ||||||
|  |                     ); | ||||||
|  | 
 | ||||||
|  |                 if (result.AsList().Count == 0) | ||||||
|  |                     throw new KeyNotFoundException(); | ||||||
|  | 
 | ||||||
|  |                 return MapOrderItems(result); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -51,5 +68,34 @@ | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         private dynamic MapOrderItems(dynamic result) | ||||||
|  |         { | ||||||
|  |             dynamic order = new ExpandoObject(); | ||||||
|  | 
 | ||||||
|  |             order.ordernumber = result[0].ordernumber; | ||||||
|  |             order.date = result[0].date; | ||||||
|  |             order.status = result[0].status; | ||||||
|  |             order.street = result[0].street; | ||||||
|  |             order.city = result[0].city; | ||||||
|  |             order.zipcode = result[0].zipcode; | ||||||
|  |             order.country = result[0].country; | ||||||
|  | 
 | ||||||
|  |             order.orderitems = new List<dynamic>(); | ||||||
|  |             order.total = 0; | ||||||
|  | 
 | ||||||
|  |             foreach (dynamic item in result) | ||||||
|  |             { | ||||||
|  |                 dynamic orderitem = new ExpandoObject(); | ||||||
|  |                 orderitem.productname = item.productname; | ||||||
|  |                 orderitem.units = item.units; | ||||||
|  |                 orderitem.unitprice = item.unitprice; | ||||||
|  |                 orderitem.pictureurl = item.pictureurl; | ||||||
|  | 
 | ||||||
|  |                 order.total += item.units * item.unitprice; | ||||||
|  |                 order.orderitems.Add(orderitem); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return order; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ | |||||||
| 
 | 
 | ||||||
|         public OrderStatus Status { get; private set; } |         public OrderStatus Status { get; private set; } | ||||||
| 
 | 
 | ||||||
|         public ICollection<OrderItem> OrderItems { get; set; } |         public ICollection<OrderItem> OrderItems { get; private set; } | ||||||
| 
 | 
 | ||||||
|         public int? ShippingAddressId { get; private set; } |         public int? ShippingAddressId { get; private set; } | ||||||
| 
 | 
 | ||||||
| @ -35,6 +35,7 @@ | |||||||
|             PaymentId = paymentId; |             PaymentId = paymentId; | ||||||
|             StatusId = OrderStatus.InProcess.Id; |             StatusId = OrderStatus.InProcess.Id; | ||||||
|             OrderDate = DateTime.UtcNow; |             OrderDate = DateTime.UtcNow; | ||||||
|  |             OrderItems = new List<OrderItem>(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void SetAddress(Address address) |         public void SetAddress(Address address) | ||||||
| @ -46,5 +47,12 @@ | |||||||
| 
 | 
 | ||||||
|             ShippingAddress = address; |             ShippingAddress = address; | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         public void AddOrderItem(OrderItem item) | ||||||
|  |         { | ||||||
|  |             // Note: Some logic could be added here (like grouping items in one single OrderItem) | ||||||
|  |             // Also validation logic could be added here (like ensuring adding almost one item) | ||||||
|  |             OrderItems.Add(item); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -6,20 +6,19 @@ | |||||||
|     public class OrderItem |     public class OrderItem | ||||||
|         :Entity |         :Entity | ||||||
|     { |     { | ||||||
|         public int ProductId { get; private set; } |         public int ProductId { get;  set; } | ||||||
| 
 | 
 | ||||||
|         public string ProductName { get; private set; } |         public string ProductName { get;  set; } | ||||||
| 
 | 
 | ||||||
|         public int OrderId { get; private set; } |         public string PictureUrl { get; set; } | ||||||
| 
 | 
 | ||||||
|         public decimal UnitPrice { get; private set; } |         public int OrderId { get;  set; } | ||||||
| 
 | 
 | ||||||
|         public decimal Discount { get; private set; } |         public decimal UnitPrice { get;  set; } | ||||||
| 
 | 
 | ||||||
|         public int Units { get; private set; } |         public decimal Discount { get;  set; } | ||||||
|  | 
 | ||||||
|  |         public int Units { get;  set; } | ||||||
| 
 | 
 | ||||||
|         protected OrderItem() |  | ||||||
|         { |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -40,6 +40,7 @@ namespace Microsoft.eShopOnContainers.WebMVC.Controllers | |||||||
|         { |         { | ||||||
|             HttpContext.Authentication.SignOutAsync("Cookies"); |             HttpContext.Authentication.SignOutAsync("Cookies"); | ||||||
|             HttpContext.Authentication.SignOutAsync("oidc"); |             HttpContext.Authentication.SignOutAsync("oidc"); | ||||||
|  |               | ||||||
|             return new SignOutResult("oidc", new AuthenticationProperties { RedirectUri = "/" }); |             return new SignOutResult("oidc", new AuthenticationProperties { RedirectUri = "/" }); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ using Microsoft.AspNetCore.Mvc; | |||||||
| using Microsoft.eShopOnContainers.WebMVC.Services; | using Microsoft.eShopOnContainers.WebMVC.Services; | ||||||
| using Microsoft.eShopOnContainers.WebMVC.Models; | using Microsoft.eShopOnContainers.WebMVC.Models; | ||||||
| using Microsoft.AspNetCore.Authorization; | using Microsoft.AspNetCore.Authorization; | ||||||
| using Microsoft.eShopOnContainers.WebMVC.Models.OrderViewModels; | using System.Net.Http; | ||||||
| 
 | 
 | ||||||
| namespace Microsoft.eShopOnContainers.WebMVC.Controllers | namespace Microsoft.eShopOnContainers.WebMVC.Controllers | ||||||
| { | { | ||||||
| @ -25,40 +25,25 @@ namespace Microsoft.eShopOnContainers.WebMVC.Controllers | |||||||
| 
 | 
 | ||||||
|         public async Task<IActionResult> Create() |         public async Task<IActionResult> Create() | ||||||
|         { |         { | ||||||
|             var vm = new CreateOrderViewModel(); |  | ||||||
|             var user = _appUserParser.Parse(HttpContext.User); |             var user = _appUserParser.Parse(HttpContext.User); | ||||||
|             var basket = await _basketSvc.GetBasket(user); |             var basket = await _basketSvc.GetBasket(user); | ||||||
|             var order = _basketSvc.MapBasketToOrder(basket); |             var order = _basketSvc.MapBasketToOrder(basket); | ||||||
|             vm.Order = _orderSvc.MapUserInfoIntoOrder(user, order); |             var vm = _orderSvc.MapUserInfoIntoOrder(user, order); | ||||||
|  |             vm.CardExpirationShortFormat(); | ||||||
| 
 | 
 | ||||||
|             return View(vm); |             return View(vm); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         [HttpPost] |         [HttpPost] | ||||||
|         public async Task<IActionResult> Create(CreateOrderViewModel model, Dictionary<string, int> quantities, string action) |         public async Task<IActionResult> Create(Order model, string action) | ||||||
|         { |         { | ||||||
|             var user = _appUserParser.Parse(HttpContext.User); |             var user = _appUserParser.Parse(HttpContext.User); | ||||||
|             var basket = await _basketSvc.SetQuantities(user, quantities); |  | ||||||
|             basket = await _basketSvc.UpdateBasket(basket); |  | ||||||
|             var order = _basketSvc.MapBasketToOrder(basket); |  | ||||||
| 
 |  | ||||||
|             // override if user has changed some shipping address or payment info data. |  | ||||||
|             _orderSvc.OverrideUserInfoIntoOrder(model.Order, order); |  | ||||||
| 
 |  | ||||||
|             if (action == "[ Place Order ]") |             if (action == "[ Place Order ]") | ||||||
|             { |             { | ||||||
|                 try |                 await _orderSvc.CreateOrder(model); | ||||||
|                 { |  | ||||||
|                     await _orderSvc.CreateOrder(user, order); |  | ||||||
| 
 | 
 | ||||||
|                     //Empty basket for current user.  |                 //Empty basket for current user.  | ||||||
|                     await _basketSvc.CleanBasket(user); |                 await _basketSvc.CleanBasket(user); | ||||||
| 
 |  | ||||||
|                 } |  | ||||||
|                 catch (Exception) { |  | ||||||
|                     //redirect to some error page if the operation fails.  |  | ||||||
|                     return Redirect("http://www.google.com"); |  | ||||||
|                 } |  | ||||||
| 
 | 
 | ||||||
|                 //Redirect to historic list. |                 //Redirect to historic list. | ||||||
|                 return RedirectToAction("Index"); |                 return RedirectToAction("Index"); | ||||||
| @ -67,18 +52,19 @@ namespace Microsoft.eShopOnContainers.WebMVC.Controllers | |||||||
|             return View(model); |             return View(model); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public IActionResult Detail(string orderId) |         public async Task<IActionResult> Detail(string orderId) | ||||||
|         { |         { | ||||||
|             var user = _appUserParser.Parse(HttpContext.User); |             var user = _appUserParser.Parse(HttpContext.User); | ||||||
|             var order = _orderSvc.GetOrder(user, orderId); |  | ||||||
| 
 | 
 | ||||||
|  |             var order = await _orderSvc.GetOrder(user, orderId); | ||||||
|             return View(order); |             return View(order); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public IActionResult Index(Order item) |         public async Task<IActionResult> Index(Order item) | ||||||
|         { |         { | ||||||
|             var user = _appUserParser.Parse(HttpContext.User); |             var user = _appUserParser.Parse(HttpContext.User); | ||||||
|             return View(_orderSvc.GetMyOrders(user)); |             var vm = await _orderSvc.GetMyOrders(user); | ||||||
|  |             return View(vm); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -1,15 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.ComponentModel.DataAnnotations; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
| 
 |  | ||||||
| namespace Microsoft.eShopOnContainers.WebMVC.Models.AccountViewModels |  | ||||||
| { |  | ||||||
|     public class ExternalLoginConfirmationViewModel |  | ||||||
|     { |  | ||||||
|         [Required] |  | ||||||
|         [EmailAddress] |  | ||||||
|         public string Email { get; set; } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,15 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.ComponentModel.DataAnnotations; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
| 
 |  | ||||||
| namespace Microsoft.eShopOnContainers.WebMVC.Models.AccountViewModels |  | ||||||
| { |  | ||||||
|     public class ForgotPasswordViewModel |  | ||||||
|     { |  | ||||||
|         [Required] |  | ||||||
|         [EmailAddress] |  | ||||||
|         public string Email { get; set; } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,22 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.ComponentModel.DataAnnotations; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
| 
 |  | ||||||
| namespace Microsoft.eShopOnContainers.WebMVC.Models.AccountViewModels |  | ||||||
| { |  | ||||||
|     public class LoginViewModel |  | ||||||
|     { |  | ||||||
|         [Required] |  | ||||||
|         [EmailAddress] |  | ||||||
|         public string Email { get; set; } |  | ||||||
| 
 |  | ||||||
|         [Required] |  | ||||||
|         [DataType(DataType.Password)] |  | ||||||
|         public string Password { get; set; } |  | ||||||
| 
 |  | ||||||
|         [Display(Name = "Remember me?")] |  | ||||||
|         public bool RememberMe { get; set; } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,29 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.ComponentModel.DataAnnotations; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
| 
 |  | ||||||
| namespace Microsoft.eShopOnContainers.WebMVC.Models.AccountViewModels |  | ||||||
| { |  | ||||||
|     public class RegisterViewModel |  | ||||||
|     { |  | ||||||
|         [Required] |  | ||||||
|         [EmailAddress] |  | ||||||
|         [Display(Name = "Email")] |  | ||||||
|         public string Email { get; set; } |  | ||||||
| 
 |  | ||||||
|         [Required] |  | ||||||
|         [StringLength(100, ErrorMessage = "The {0} must be at least {2} and at max {1} characters long.", MinimumLength = 6)] |  | ||||||
|         [DataType(DataType.Password)] |  | ||||||
|         [Display(Name = "Password")] |  | ||||||
|         public string Password { get; set; } |  | ||||||
| 
 |  | ||||||
|         [DataType(DataType.Password)] |  | ||||||
|         [Display(Name = "Confirm password")] |  | ||||||
|         [Compare("Password", ErrorMessage = "The password and confirmation password do not match.")] |  | ||||||
|         public string ConfirmPassword { get; set; } |  | ||||||
| 
 |  | ||||||
|         public ApplicationUser User { get; set; } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,27 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.ComponentModel.DataAnnotations; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
| 
 |  | ||||||
| namespace Microsoft.eShopOnContainers.WebMVC.Models.AccountViewModels |  | ||||||
| { |  | ||||||
|     public class ResetPasswordViewModel |  | ||||||
|     { |  | ||||||
|         [Required] |  | ||||||
|         [EmailAddress] |  | ||||||
|         public string Email { get; set; } |  | ||||||
| 
 |  | ||||||
|         [Required] |  | ||||||
|         [StringLength(100, ErrorMessage = "The {0} must be at least {2} and at max {1} characters long.", MinimumLength = 6)] |  | ||||||
|         [DataType(DataType.Password)] |  | ||||||
|         public string Password { get; set; } |  | ||||||
| 
 |  | ||||||
|         [DataType(DataType.Password)] |  | ||||||
|         [Display(Name = "Confirm password")] |  | ||||||
|         [Compare("Password", ErrorMessage = "The password and confirmation password do not match.")] |  | ||||||
|         public string ConfirmPassword { get; set; } |  | ||||||
| 
 |  | ||||||
|         public string Code { get; set; } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,19 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
| using Microsoft.AspNetCore.Mvc.Rendering; |  | ||||||
| 
 |  | ||||||
| namespace Microsoft.eShopOnContainers.WebMVC.Models.AccountViewModels |  | ||||||
| { |  | ||||||
|     public class SendCodeViewModel |  | ||||||
|     { |  | ||||||
|         public string SelectedProvider { get; set; } |  | ||||||
| 
 |  | ||||||
|         public ICollection<SelectListItem> Providers { get; set; } |  | ||||||
| 
 |  | ||||||
|         public string ReturnUrl { get; set; } |  | ||||||
| 
 |  | ||||||
|         public bool RememberMe { get; set; } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,25 +0,0 @@ | |||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.ComponentModel.DataAnnotations; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Threading.Tasks; |  | ||||||
| 
 |  | ||||||
| namespace Microsoft.eShopOnContainers.WebMVC.Models.AccountViewModels |  | ||||||
| { |  | ||||||
|     public class VerifyCodeViewModel |  | ||||||
|     { |  | ||||||
|         [Required] |  | ||||||
|         public string Provider { get; set; } |  | ||||||
| 
 |  | ||||||
|         [Required] |  | ||||||
|         public string Code { get; set; } |  | ||||||
| 
 |  | ||||||
|         public string ReturnUrl { get; set; } |  | ||||||
| 
 |  | ||||||
|         [Display(Name = "Remember this browser?")] |  | ||||||
|         public bool RememberBrowser { get; set; } |  | ||||||
| 
 |  | ||||||
|         [Display(Name = "Remember me?")] |  | ||||||
|         public bool RememberMe { get; set; } |  | ||||||
|     } |  | ||||||
| } |  | ||||||