2014-11-04 5 views

risposta

1

sto citando la risposta dell'autore qui dal https://github.com/khellang/Nancy.Swagger/issues/59

L'installazione dovrebbe essere molto semplice, basta tirare verso il basso il pacchetto NuGet, aggiungere moduli di metadati per descrivere i percorsi, e API-docs colpito /. Questo dovrebbe portarti il ​​JSON. Se vuoi aggiungere anche swagger-ui, devi aggiungerlo manualmente in questo momento.

+1

"dovrebbe", sì. In realtà non funziona –

3

Nel mio progetto attuale ho cercato molto in questo problema. Ho usato sia nancy.swagger che nancy.swagger.attributes.

Ho rapidamente scartato Nancy.swagger, perché per me personalmente non sembra corretto dover creare una classe di documentazione pura per ogni modulo nancy. La soluzione degli attributi era un po '"più pulita" - almeno la base di codice e la documentazione erano in un unico posto. Ma molto velocemente questo è diventato irrinunciabile. Il codice del modulo è illeggibile a causa di molti attributi. Nulla viene generato automaticamente: devi inserire il percorso, tutti i parametri, anche il metodo http come attributo. Questo è un enorme sforzo di duplicazione. I problemi arrivarono molto velocemente, alcuni esempi:

  • Ho cambiato POST in PUT in Nancy e ho dimenticato di aggiornare l'attributo [Metodo].
  • Ho aggiunto un parametro ma non l'attributo per esso.
  • Ho modificato il parametro dal percorso alla query e non ho aggiornato l'attributo.

È troppo facile dimenticare di aggiornare gli attributi (per non parlare della soluzione del modulo di documentazione), che porta a discrepanze tra la documentazione e il codice effettivo. Il nostro team di interfaccia utente è in un altro paese e hanno avuto qualche problema nell'utilizzo delle API perché docu non era aggiornato.

La mia soluzione? Non mescolare codice e documentazione. Generare docu dal codice (come fa Swashbuckle) È ok, ma in realtà scrivere docu nel codice e provare a pubblicare il codice in docu NON è così. Non è meglio che scriverlo in un documento Word per i tuoi clienti.

Se vuoi Swagger docu, fallo come Swagger. - Passa un po 'di tempo con Swagger.Editor e crea davvero la tua API in YAML. Sembra tutto testo e difficile, ma una volta che ci si abitua, è no. - Passa un po 'di tempo con Swagger.Codegen e adattalo (fa già un buon lavoro per generare il codice del server di Nancy e con alcune modifiche ai modelli di baffi era proprio quello di cui avevo bisogno). - Automatizza il tuo processo: scrivi un paio di lotti per generare i tuoi moduli e modelli da yaml e copiali nel tuo repository.

Vantaggi?Un bel po ': -

  • tua definizione YAML è ora la sola verità del contratto REST. Se qualcosa da qualche parte è defferente, è sbagliato.
  • codice del server Nancy è auto-generati
  • basi di codice client sono generati automaticamente (nel nostro caso si tratta di Android, iOS e angolare)

Così ogni volta che cambia qualcosa nel contratto di REST, tutte le basi di codice sono rigenerato e aggiunto a progetti in un unico lotto. Devo solo dire ai team che qualcosa è stato aggiornato. Non devono guardare attraverso alcuni documenti e cercarli. Hanno solo il loro codice rigenerato e probabilmente vedono alcuni errori di compilazione, in caso di rotture delle modifiche.

Continuo a utilizzare nancy.swagger (.annotations)? Sì, lo uso in un altro progetto, che ha solo un endpoint con un paio di metodi. Non cambiano spesso. Non vale la pena di impostare tutto, ho il mio swagger docu attivo e funzionante. Ma se il tuo progetto è grande, l'API sta cambiando, e hai più basi di codice a seconda della tua API, il mio consiglio è di investire un po 'di tempo in una vera e propria configurazione di swagger.