Files
NKC/README.md
2021-11-18 16:28:31 +01:00

91 lines
3.9 KiB
Markdown

# NKC
Progetto per NKC Sauder con Egaltech
## Architettura
L'architettura prevede
## Db Scaffolding EFCore
Per la gestione dell'accesso al DB si opera con EFCore --> app blazor server
Per generare le classi da un DB esistente con cui operare EFCore CodeFirst usare lo scaffolding coi seguenti comandi.
Attenzione: la classe DbCOntext viene creata INSIEME alle viste nella folder DatabaseModel (nell'esempio seguente...)
### DB iniziale
Scaffold-DbContext "Server=SQL2016DEV;Database=Sauder_NKC;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir DbModels
### SOLO di tabelle/viste selezionate (con force update)
Scaffold-DbContext "Server=SQL2016DEV;Database=Sauder_NKC;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir DbModels -Tables Models
### Approfondimenti
Qualche link di approfondimento:
- https://docs.microsoft.com/en-us/ef/core/
- https://docs.microsoft.com/en-us/ef/core/extensions/
- https://www.entityframeworktutorial.net/efcore/create-model-for-existing-database-in-ef-core.aspx
- https://entityframework.net/ef-code-first
## Note setup
Va installato
- powershell
- salt
- IIS
- SqlServer
- Redis
- tools vari x gestione dei 3
va inoiltre configurato IIS per gestire el chaimate PUT/DELETE di WebAPI: in particoalre per **abilitare i METODI PUT**
Task | Come
---------|----------
Conf IIS | modificare il file **applicationHost.config** che si trova in *C:\Windows\System32\inetsrv\config*
WebDAV | disinstallare webDav oppure commentare le righe dell'*esempio (1)* sottostante
Conf IIS | aggiungere PUT/DELETE a handler come nell'*esempio (2)* sottostante
*esempio (1)*
```xml
<!-- <add name="WebDAVModule" /> -->
<!-- <add name="WebDAVModule" image="%windir%\System32\inetsrv\webdav.dll" /> -->
<!-- <add name="WebDAV" path="*" verb="PROPFIND,PROPPATCH,MKCOL,PUT,COPY,DELETE,MOVE,LOCK,UNLOCK" modules="WebDAVModule" resourceType="Unspecified" requireAccess="None" /> -->
```
*esempio (2)*:
```xml
<add name="ExtensionlessUrlHandler-ISAPI-4.0_64bit" path="*." verb="GET,HEAD,POST,DEBUG,PUT,DELETE" modules="IsapiModule" scriptProcessor="%windir%\Microsoft.NET\Framework64\v4.0.30319\aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness64" responseBufferLimit="0" />
<add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="GET,HEAD,POST,DEBUG,PUT,DELETE" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" responseBufferLimit="0" />
```
## Specifica codici DataMatrix
Abbiamo convenuto di tenere i codici datamatrix piùcporti possibili. La lunghezza target è 10char.
Le prime due cifre servono a distinguere COSA stiamo traccaindo
Le restanti 8 ci permettono di codificare in HEX (escludenxo 0x iniziale) cifre sino a FFFF FFFF = 4 miliardi di codici (INT di SQL è la emtà essendo con segno).
Ogni tipo di oggetto tracciato avrà quindi una codifica parlante in cui la prima cifra indicherà la sua natura secondo il seguente schema:
Cifra iniziale | Oggetto | Esempio | Note
---------|----------|---------|---------|---------|---------
BN | Bin | BN00041F120 | Ceste, usiamo la conversione HEX del contatore BinId |
CR | Cart | CR004B0F120 | Carrelli, usiamo la conversione HEX del contatore CartId |
IT | Item | IT000F1234 | Usiamo la conversione HEX del contatore ItemId
IG | Item GENERIC |IG000F2314 | Viene staccato ogni giorno un nuovo numero x indicare gli items uguali della giornata, con conversione Hex |
MT | Material | MT00006120 | Viene usato il codice del materiale originale con padding di zero (no conv HEX) |
OR | Order | OR000B0F120 | Usiamo la conversione HEX del contatore OrderId |
ST | Stack | ST000FB120 | Usiamo la conversione HEX del contatore StackId |
## Postazioni
### Postazione OrderManager
Questa prima psotazione serve alla gestione preliminare degli ordini e quindi al calcolo del tempo stimato dal **NESTING + CNC** delel alvorazioni connesse.