Skip to content

MinhLu12/AdminDashboard

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

58 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Admin Dashboard

Reference to the design document

Table of Contents

Setup

  1. Install MySQL on local machine (or dockerize). Connection strings in appsettings.json need to be changed appropriately.
  2. Navigate to the AdminDashboard/ directory (where the .sln file is) and run dotnet restore
  3. Run dotnet user-secrets init
  4. Run dotnet user-secrets "AuthorizationConfiguration:Secret" "RY25waYFu+VlSdPUikfbLJEUpt2SuD5rF2bkQMAqwJ+N+6hm (For purposes of running the application, the credentials are exposed as shown)
  5. Navigate to the client/ directory and run npm install
  6. Run npm start. Make sure the webpack.config.js points at the exposed URL from the server.

Workflow

  1. Log in. Username is [email protected] and password is GravitationalInterviewByMinhNovember2019
  2. Through a REST client like Postman, register users on the account (Note the account's ID is exposed on the UI for convenience)
  3. Once the user limit is reached, upgrade the plan to enterprise
  4. Dismiss the congratulatory upgrade message
  5. Log out

Tests

  1. In the TestFixture.cs of the backend, insert line Client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", <token>); on line 29. To get the token, call the login endpoint on the web API with the correct username and password.

Improvements to make

  1. Have the integration tests run without any manual changes by overriding Startup.cs and bypassing authorization.
  2. Refactor server side so there is no concept of "Account ID", and have a default account to use by the client. On the client side, have the account already created by the time the admin logs in and simply get the default account.
  3. Use react router correctly and include the account ID as query parameters between components
  4. Upon server side errors, handle correctly in the client to redirect to an Error page

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published