medusa-config.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. const dotenv = require("dotenv");
  2. let ENV_FILE_NAME = "";
  3. switch (process.env.NODE_ENV) {
  4. case "production":
  5. ENV_FILE_NAME = ".env.production";
  6. break;
  7. case "staging":
  8. ENV_FILE_NAME = ".env.staging";
  9. break;
  10. case "test":
  11. ENV_FILE_NAME = ".env.test";
  12. break;
  13. case "development":
  14. default:
  15. ENV_FILE_NAME = ".env";
  16. break;
  17. }
  18. try {
  19. dotenv.config({ path: process.cwd() + "/" + ENV_FILE_NAME });
  20. } catch (e) {}
  21. // CORS when consuming Medusa from admin
  22. const ADMIN_CORS =
  23. process.env.ADMIN_CORS || "http://localhost:7000,http://localhost:7001";
  24. // CORS to avoid issues when consuming Medusa from a client
  25. const STORE_CORS = process.env.STORE_CORS || "http://localhost:8000";
  26. const DATABASE_URL =
  27. process.env.DATABASE_URL || "postgres://localhost/medusa-starter-default";
  28. const REDIS_URL = process.env.REDIS_URL || "redis://localhost:6379";
  29. const plugins = [
  30. `medusa-fulfillment-manual`,
  31. `medusa-payment-manual`,
  32. {
  33. resolve: `@medusajs/file-local`,
  34. options: {
  35. upload_dir: "uploads",
  36. },
  37. },
  38. ];
  39. const modules = {
  40. /*eventBus: {
  41. resolve: "@medusajs/event-bus-redis",
  42. options: {
  43. redisUrl: REDIS_URL
  44. }
  45. },
  46. cacheService: {
  47. resolve: "@medusajs/cache-redis",
  48. options: {
  49. redisUrl: REDIS_URL
  50. }
  51. },*/
  52. apiKey: {
  53. resolve: "@medusajs/api-key"
  54. },
  55. auth: {
  56. resolve: "@medusajs/auth",
  57. options: {
  58. providers: [
  59. {
  60. name: "emailpass",
  61. scopes: {
  62. admin: {},
  63. store: {},
  64. },
  65. },
  66. ],
  67. },
  68. },
  69. cart: {
  70. resolve: "@medusajs/cart"
  71. },
  72. customer: {
  73. resolve: "@medusajs/customer"
  74. },
  75. currency: {
  76. resolve: "@medusajs/currency"
  77. },
  78. fulfillment: {
  79. resolve: "@medusajs/fulfillment"
  80. },
  81. inventoryService: {
  82. resolve: "@medusajs/inventory-next"
  83. },
  84. order: {
  85. resolve: "@medusajs/order"
  86. },
  87. payment: {
  88. resolve: "@medusajs/payment"
  89. },
  90. pricingService: {
  91. resolve: "@medusajs/pricing"
  92. },
  93. productService: {
  94. resolve: "@medusajs/product"
  95. },
  96. promotion: {
  97. resolve: "@medusajs/promotion"
  98. },
  99. region: {
  100. resolve: "@medusajs/region"
  101. },
  102. salesChannel: {
  103. resolve: "@medusajs/sales-channel"
  104. },
  105. stockLocationService: {
  106. resolve: "@medusajs/stock-location-next"
  107. },
  108. store: {
  109. resolve: "@medusajs/store"
  110. },
  111. tax: {
  112. resolve: "@medusajs/tax"
  113. },
  114. user: {
  115. resolve: "@medusajs/user",
  116. options: {
  117. jwt_secret: process.env.JWT_SECRET
  118. }
  119. },
  120. };
  121. /** @type {import('@medusajs/medusa').ConfigModule["projectConfig"]} */
  122. const projectConfig = {
  123. jwtSecret: process.env.JWT_SECRET,
  124. cookieSecret: process.env.COOKIE_SECRET,
  125. store_cors: STORE_CORS,
  126. database_url: DATABASE_URL,
  127. admin_cors: ADMIN_CORS,
  128. auth_cors: process.env.AUTH_CORS || ADMIN_CORS
  129. // Uncomment the following lines to enable REDIS
  130. // redis_url: REDIS_URL
  131. };
  132. /** @type {import('@medusajs/medusa').ConfigModule} */
  133. module.exports = {
  134. projectConfig,
  135. plugins,
  136. modules,
  137. featureFlags: {
  138. medusa_v2: true
  139. }
  140. };