connection.ts 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. import {AnyJson, DataPersisterArgs, DataProviderArgs} from "~/types/interfaces";
  2. import {HTTP_METHOD} from "~/types/enums";
  3. import {NuxtAxiosInstance} from "@nuxtjs/axios";
  4. import {AxiosRequestConfig} from "axios";
  5. /**
  6. * @category Services/connection
  7. * @class Connection
  8. * Classe Wrapper du connecteur de requete (Axios dans notre cas)
  9. */
  10. class Connection{
  11. static connector:NuxtAxiosInstance;
  12. /**
  13. * Initialisation du connecteur (Axios dans notre cas)
  14. * @param {NuxtAxiosInstance} connector
  15. */
  16. static initConnector(connector: NuxtAxiosInstance){
  17. Connection.connector = connector
  18. }
  19. /**
  20. * Main méthode qui apperlera les méthode privées correspondantes (getItem, getCollection, put, post, delete)
  21. * @param {HTTP_METHOD} method de requetage
  22. * @param {string} url
  23. * @param {DataProviderArgs|DataPersisterArgs} args
  24. * @return {Promise<any>}
  25. */
  26. invoke(method: HTTP_METHOD, url: string, args:DataProviderArgs|DataPersisterArgs): Promise<any>{
  27. switch (method) {
  28. case HTTP_METHOD.GET:
  29. if(args.id)
  30. return this.getItem(url, args.id)
  31. else
  32. return this.getCollection(url)
  33. case HTTP_METHOD.PUT:
  34. if(this.isArgsIsDataPersisterArgs(args)){
  35. if(!args.data)
  36. throw new Error('data not found')
  37. return this.put(url, args.id, args.data)
  38. }
  39. }
  40. throw new Error('Method unknown')
  41. }
  42. /**
  43. * GET Item : préparation de la config pour la récupération d'un item
  44. * @param {string} url
  45. * @param {number} id
  46. * @return {Promise<any>}
  47. */
  48. private getItem(url: string, id: number): Promise<any>{
  49. const config:AxiosRequestConfig = {
  50. url: `${url}/${id}`,
  51. method: HTTP_METHOD.GET,
  52. }
  53. return this.request(config)
  54. }
  55. /**
  56. * Get collection : préparation de la config pour la récupération d'une collection d'items
  57. * @param {string} url
  58. * @return {Promise<any>}
  59. */
  60. private getCollection(url: string): Promise<any>{
  61. const config:AxiosRequestConfig = {
  62. url: `${url}`,
  63. method: HTTP_METHOD.GET,
  64. }
  65. return this.request(config)
  66. }
  67. /**
  68. * Put : préparation de la config pour la mise à jour d'un item
  69. * @param {string} url
  70. * @param {number} id
  71. * @param {AnyJson} data
  72. * @return {Promise<any>}
  73. */
  74. private put(url: string, id: number, data: AnyJson): Promise<any>{
  75. const config:AxiosRequestConfig = {
  76. url: `${url}/${id}`,
  77. method: HTTP_METHOD.PUT,
  78. data: data
  79. }
  80. return this.request(config)
  81. }
  82. /**
  83. * Exécution de la requete
  84. * @param {AxiosRequestConfig} config
  85. * @return {Promise<any>}
  86. */
  87. private async request(config:AxiosRequestConfig): Promise<any>{
  88. return await Connection.connector.$request(config)
  89. }
  90. /**
  91. * Test si l'argument est bien de type DataPersister
  92. * @param args
  93. */
  94. private isArgsIsDataPersisterArgs(args:DataProviderArgs|DataPersisterArgs): args is DataPersisterArgs{
  95. return (args as DataPersisterArgs).data !== undefined
  96. }
  97. }
  98. export default Connection