Nyss is a Norwegian word and means to "get the wind of something". The first Norwegian computer was called Nusse.
Nyss is a reimplementation of the previous CBS solution and proudly extending all the great work done there.
How to run and develop everything on your local machine.
- .NET Core Installer - SDK 3.1.100
- Azure Functions Core Tools
- Microsoft Azure Storage Emulator. Alternatively, especially if you are using mac/linux: Azurite
- Microsoft Azure Storage Explorer
-
Docker After downloading: Go to Settings -> Features in development and enable Use Rosetta for x86/amd64 emulation on Apple Silicon
-
Azurite
- Downlad as a docker image:
docker run --name azurite -d --restart unless-stopped -p 10000:10000 -p 10001:10001 -p 10002:10002 -v /Users/<your username>/azurite/data mcr.microsoft.com/azure-storage/azurite
- Downlad as a docker image:
- IDE:
- Git client:
- TortoiseGit(Windows only)
- Fork
- GitLens (Extension for VS code)
- Azure Data Studio or SQL Server Management Studio
- Service Bus Explorer (Windows only)
- Make sure the connection string for
NyssDatabase
inappsettings.Development.json
is correct. By default, a SQL Server Express LocalDB instance is used, which should work out of the box if you are using Visual Studio on Windows. On mac, an alternative can be to run SQL Server in in a docker container. (A nice guide) - Ensure you have the ef core dotnet tool installed:
dotnet tool install --global dotnet-ef
- Update the two data base contextes:
dotnet ef database update --context NyssContext
dotnet ef database update --context ApplicationDbContext
See Database and migrations for further details on working with the database.
Apple has released its own chip which uses ARM architecture and causes a problem since SQL Server isn’t supported on the ARM architecture. However, the container image for Azure SQL Edge can be installed instead of the SQL Server image.
-
Open the terminal and run:
-
In you terminal, run:
docker pull mcr.microsoft.com/mssql/server:2022-latest
- In the follwing command, you will need a password that complies to these guidelines. The following command generates a SQL server with a default system administrator (
sa
) user with the password that you will set forMSSQL_SA_PASSWORD
.
sudo docker run --cap-add SYS_PTRACE -e 'ACCEPT_EULA=Y' -e 'MSSQL_SA_PASSWORD=YourStrong@Passw0rd' -p 1433:1433 --platform linux/amd64 --name sqledge -d mcr.microsoft.com/mssql/server:2022-latest
- In
src/RX.Nyss.Web/appsettings.Development.json
, change the string value of ConnectionStrings.NyssDatabase to:
"Server=localhost,1433\\;Database=Rx.Nyss.Db;User=sa;Password=YourStrong@Passw0rd;"
- You can now connect to your Azure SQL Edge installation by using the details provided when launching the Docker image. It is recommended to connect to Azure Data Studio. Below is a screenshot of how to connect via Azure Data Studio. Use all the credentials from the image:
- Ensure you have the ef core dotnet tool installed:
dotnet tool install --global dotnet-ef
- Navigate to the
src/RX.Nyss.Web
folder and update the two data base contextes:
dotnet ef database update --context NyssContext
dotnet ef database update --context ApplicationDbContext
-
Make sure that the Azure storage emulator (or Azurite for Mac) is running, and open the emulator connection in Azure Storage Explorer.
- Connect to Azure resources
- Select Local storage emulator
- Display name can be changed
- Use default settings on everything
-
Create the containers that are needed in
Storage Accounts / (Emulator - Default Ports) (Key)
(all containers are listed in the AppSettings.json file in the Nyss.Web project):sms-gateway
nyss-blob-container
nyss-agreements-container
-
Inside each container, you will need these files. You may need to contact your supervisor for these.
-
Inside
sms-gateway
:authorized-api-keys.txt
-
Inside
nyss-blob-container
:emailContentResources.json
smsContentResources.json
stringsResources.json
platform-agreement-en.pdf
platform-agreement-es.pdf
platform-agreement-fr.pdf
-
Inside
nyss-agreements-container
:- Not specified
-
-
If you want to test sending emails locally, create a new text file
whitelisted-email-addresses.txt
with a list of email addresses that you want to use (separated by newline) and upload it to thesms-gateway
container. -
If you want to test sending SMSes locally, create a new text file
whitelisted-phone-numbers.txt
with a list of email addresses that you want to use (separated by newline) and upload it to thesms-gateway
container.
In order to test everything locally, there are a couple of sensitive configuration variables that should be set. We store these as UserSecrets in order make them less prone to being checked in to our git repository. Most should work without these, but some parts of nyss uses some services that you can't run locally and therefore need a connection string, api key of some sort. You can find all keys values in the appsettings.json
files. The most important ones to think of is:
SERVICEBUS_CONNECTIONSTRING
/ConnectionStrings.ServiceBus
(in order to send service bus messages locally)MailConfig.Sendgrid.ApiKey
(if you are going to test sending emails locally)
The user secrets file is the same for all running applications. How to access it:
- In Visual Studio Code, the extension with the id:
doggy8088.netcore-extension-pack
can be used to manage the user secret.- After downloading the extension, open
RX.Nyss.Web
in your VSCode explorer and right-clickRX.Nyss.Web.csproj
and pressManage User Secrets
. - A
secrets.json
file will appear. Contact your supervisor for the content inside this file.
- After downloading the extension, open
- In Rider, right click the
RX.Nyss.Web
folder and hover overtools
and then select.NET User Secrets
.- A
secrets.json
file will appear. Contact your supervisor for the content inside this file.
- A
- In VS2019, right-click either a FunctionApp or WebApp project, and click "Manage User Secrets".
- On Windows this file is normally located at
%AppData%\Microsoft\UserSecrets\<user_secrets_id>\secrets.json
- On Linux/MacOs, it should be located here:
~/.microsoft/usersecrets/<user_secrets_id>/secrets.json
(theuser_secrets_id
can be found in the .csproj files)
- Naviagte to
src/RX.Nyss.Web
orsrc/RX.Nyss.ReportApi
directory and in a terminal rundotnet run
. The first build may take up to 5 minutes, the applicatiion is ready to open when you see Compiled Successfully! in the npm command prompt. - Each application should open a browser window, or you can manually open https://localhost:5001/ (Web application) or https://localhost:5003/swagger (Report Api).
- A default login of System Administrator is
[email protected]
and a password isP@ssw0rd
.
- Naviagte to
src/RX.Nyss.FuncApp
orsrc/RX.Nyss.ReportFuncApp
directory and in a terminal runfunc host start
. References: Code and test Azure Functions locally
Nyss app includes the integration with DHIS2 API. If you want to test or develop that solution, please visit that readme file to setup your machine.
- PR branch is on top of master
- Build and all unit tests are green (and business logic is covered by unit tests)
- The code fulfills the acceptance criteria
- The code is easy to understand or has substantial documentation on how to understand
- "How to test" steps should be applied and understandable for both tester and reviewer
- Test that it is working in dev once the PR is completed, merged to master and deployed
- The code is formatted according to code conventions
- If data model changes, ER diagram needs to be updated
- C# code style should be specified in the .editorconfig file in the repository root directory. Examples:
- line length (and wrap)
- public members on top
- object initializers
- usings
- Git Commit Best Practices
- Commit often and push if you feel for it. Squash them if a lot of them doesn't add value
- Branch name format:
feature or bugfix/workitem-number
-workitem-name
, eg:feature/23-add-system-administrator
bugfix/73-add-missing-margins-in-project-dashboard
- Commit messages: Imperative style: Write what the code now does and not what the developer has done. Example:
# wrong
Added mapper, updated controller
# correct
Add validation rules for creating a supervisor
- Add mapper
- Update supervisor controller