router.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897
  1. package router
  2. import (
  3. "net/http"
  4. "os"
  5. "github.com/go-chi/chi"
  6. "github.com/porter-dev/porter/server/api"
  7. "github.com/porter-dev/porter/server/requestlog"
  8. mw "github.com/porter-dev/porter/server/router/middleware"
  9. )
  10. // New creates a new Chi router instance and registers all routes supported by the
  11. // API
  12. func New(a *api.App) *chi.Mux {
  13. l := a.Logger
  14. r := chi.NewRouter()
  15. auth := mw.NewAuth(a.Store, a.ServerConf.CookieName, a.Repo)
  16. r.Route("/api", func(r chi.Router) {
  17. r.Use(mw.ContentTypeJSON)
  18. // health checks
  19. r.Method("GET", "/livez", http.HandlerFunc(a.HandleLive))
  20. r.Method("GET", "/readyz", http.HandlerFunc(a.HandleReady))
  21. // /api/users routes
  22. r.Method(
  23. "GET",
  24. "/users/{user_id}",
  25. auth.DoesUserIDMatch(
  26. requestlog.NewHandler(a.HandleReadUser, l),
  27. mw.URLParam,
  28. ),
  29. )
  30. r.Method(
  31. "GET",
  32. "/users/{user_id}/projects",
  33. auth.DoesUserIDMatch(
  34. requestlog.NewHandler(a.HandleListUserProjects, l),
  35. mw.URLParam,
  36. ),
  37. )
  38. r.Method(
  39. "POST",
  40. "/users",
  41. requestlog.NewHandler(a.HandleCreateUser, l),
  42. )
  43. r.Method(
  44. "DELETE",
  45. "/users/{user_id}",
  46. auth.DoesUserIDMatch(
  47. requestlog.NewHandler(a.HandleDeleteUser, l),
  48. mw.URLParam,
  49. ),
  50. )
  51. r.Method(
  52. "POST",
  53. "/login",
  54. requestlog.NewHandler(a.HandleLoginUser, l),
  55. )
  56. r.Method(
  57. "GET",
  58. "/auth/check",
  59. auth.BasicAuthenticate(
  60. requestlog.NewHandler(a.HandleAuthCheck, l),
  61. ),
  62. )
  63. r.Method(
  64. "POST",
  65. "/logout",
  66. auth.BasicAuthenticate(
  67. requestlog.NewHandler(a.HandleLogoutUser, l),
  68. ),
  69. )
  70. // /api/integrations routes
  71. r.Method(
  72. "GET",
  73. "/integrations/cluster",
  74. auth.BasicAuthenticate(
  75. requestlog.NewHandler(a.HandleListClusterIntegrations, l),
  76. ),
  77. )
  78. r.Method(
  79. "GET",
  80. "/integrations/registry",
  81. auth.BasicAuthenticate(
  82. requestlog.NewHandler(a.HandleListRegistryIntegrations, l),
  83. ),
  84. )
  85. r.Method(
  86. "GET",
  87. "/integrations/helm",
  88. auth.BasicAuthenticate(
  89. requestlog.NewHandler(a.HandleListHelmRepoIntegrations, l),
  90. ),
  91. )
  92. r.Method(
  93. "GET",
  94. "/integrations/repo",
  95. auth.BasicAuthenticate(
  96. requestlog.NewHandler(a.HandleListRepoIntegrations, l),
  97. ),
  98. )
  99. // /api/templates routes
  100. r.Method(
  101. "GET",
  102. "/templates",
  103. auth.BasicAuthenticate(
  104. requestlog.NewHandler(a.HandleListTemplates, l),
  105. ),
  106. )
  107. r.Method(
  108. "GET",
  109. "/templates/{name}/{version}",
  110. auth.BasicAuthenticate(
  111. requestlog.NewHandler(a.HandleReadTemplate, l),
  112. ),
  113. )
  114. // /api/oauth routes
  115. r.Method(
  116. "GET",
  117. "/oauth/projects/{project_id}/github",
  118. auth.DoesUserHaveProjectAccess(
  119. requestlog.NewHandler(a.HandleGithubOAuthStartProject, l),
  120. mw.URLParam,
  121. mw.WriteAccess,
  122. ),
  123. )
  124. r.Method(
  125. "GET",
  126. "/oauth/github/callback",
  127. requestlog.NewHandler(a.HandleGithubOAuthCallback, l),
  128. )
  129. // /api/projects routes
  130. r.Method(
  131. "GET",
  132. "/projects/{project_id}",
  133. auth.DoesUserHaveProjectAccess(
  134. requestlog.NewHandler(a.HandleReadProject, l),
  135. mw.URLParam,
  136. mw.ReadAccess,
  137. ),
  138. )
  139. r.Method(
  140. "POST",
  141. "/projects",
  142. auth.BasicAuthenticate(
  143. requestlog.NewHandler(a.HandleCreateProject, l),
  144. ),
  145. )
  146. r.Method(
  147. "DELETE",
  148. "/projects/{project_id}",
  149. auth.DoesUserHaveProjectAccess(
  150. requestlog.NewHandler(a.HandleDeleteProject, l),
  151. mw.URLParam,
  152. mw.WriteAccess,
  153. ),
  154. )
  155. // /api/projects/{project_id}/infra routes
  156. r.Method(
  157. "GET",
  158. "/projects/{project_id}/infra",
  159. auth.DoesUserHaveProjectAccess(
  160. requestlog.NewHandler(a.HandleListProjectInfra, l),
  161. mw.URLParam,
  162. mw.ReadAccess,
  163. ),
  164. )
  165. // /api/projects/{project_id}/provision routes
  166. r.Method(
  167. "POST",
  168. "/projects/{project_id}/provision/test",
  169. auth.DoesUserHaveProjectAccess(
  170. requestlog.NewHandler(a.HandleProvisionTest, l),
  171. mw.URLParam,
  172. mw.ReadAccess,
  173. ),
  174. )
  175. r.Method(
  176. "POST",
  177. "/projects/{project_id}/provision/ecr",
  178. auth.DoesUserHaveProjectAccess(
  179. auth.DoesUserHaveAWSIntegrationAccess(
  180. requestlog.NewHandler(a.HandleProvisionAWSECRInfra, l),
  181. mw.URLParam,
  182. mw.BodyParam,
  183. true,
  184. ),
  185. mw.URLParam,
  186. mw.ReadAccess,
  187. ),
  188. )
  189. r.Method(
  190. "POST",
  191. "/projects/{project_id}/provision/eks",
  192. auth.DoesUserHaveProjectAccess(
  193. auth.DoesUserHaveAWSIntegrationAccess(
  194. requestlog.NewHandler(a.HandleProvisionAWSEKSInfra, l),
  195. mw.URLParam,
  196. mw.BodyParam,
  197. true,
  198. ),
  199. mw.URLParam,
  200. mw.ReadAccess,
  201. ),
  202. )
  203. r.Method(
  204. "POST",
  205. "/projects/{project_id}/provision/gcr",
  206. auth.DoesUserHaveProjectAccess(
  207. auth.DoesUserHaveGCPIntegrationAccess(
  208. requestlog.NewHandler(a.HandleProvisionGCPGCRInfra, l),
  209. mw.URLParam,
  210. mw.BodyParam,
  211. true,
  212. ),
  213. mw.URLParam,
  214. mw.ReadAccess,
  215. ),
  216. )
  217. r.Method(
  218. "POST",
  219. "/projects/{project_id}/provision/gke",
  220. auth.DoesUserHaveProjectAccess(
  221. auth.DoesUserHaveGCPIntegrationAccess(
  222. requestlog.NewHandler(a.HandleProvisionGCPGKEInfra, l),
  223. mw.URLParam,
  224. mw.BodyParam,
  225. true,
  226. ),
  227. mw.URLParam,
  228. mw.ReadAccess,
  229. ),
  230. )
  231. r.Method(
  232. "GET",
  233. "/projects/{project_id}/provision/{kind}/{infra_id}/logs",
  234. auth.DoesUserHaveProjectAccess(
  235. auth.DoesUserHaveInfraAccess(
  236. requestlog.NewHandler(a.HandleGetProvisioningLogs, l),
  237. mw.URLParam,
  238. mw.URLParam,
  239. ),
  240. mw.URLParam,
  241. mw.ReadAccess,
  242. ),
  243. )
  244. r.Method(
  245. "POST",
  246. "/projects/{project_id}/provision/{kind}/{infra_id}/logs",
  247. auth.DoesUserHaveProjectAccess(
  248. auth.DoesUserHaveInfraAccess(
  249. requestlog.NewHandler(a.HandleGetProvisioningLogs, l),
  250. mw.URLParam,
  251. mw.URLParam,
  252. ),
  253. mw.URLParam,
  254. mw.ReadAccess,
  255. ),
  256. )
  257. r.Method(
  258. "POST",
  259. "/projects/{project_id}/infra/{infra_id}/ecr/destroy",
  260. auth.DoesUserHaveProjectAccess(
  261. auth.DoesUserHaveInfraAccess(
  262. requestlog.NewHandler(a.HandleDestroyAWSECRInfra, l),
  263. mw.URLParam,
  264. mw.URLParam,
  265. ),
  266. mw.URLParam,
  267. mw.ReadAccess,
  268. ),
  269. )
  270. r.Method(
  271. "POST",
  272. "/projects/{project_id}/infra/{infra_id}/eks/destroy",
  273. auth.DoesUserHaveProjectAccess(
  274. auth.DoesUserHaveInfraAccess(
  275. requestlog.NewHandler(a.HandleDestroyAWSEKSInfra, l),
  276. mw.URLParam,
  277. mw.URLParam,
  278. ),
  279. mw.URLParam,
  280. mw.ReadAccess,
  281. ),
  282. )
  283. r.Method(
  284. "POST",
  285. "/projects/{project_id}/infra/{infra_id}/gke/destroy",
  286. auth.DoesUserHaveProjectAccess(
  287. auth.DoesUserHaveInfraAccess(
  288. requestlog.NewHandler(a.HandleDestroyGCPGKEInfra, l),
  289. mw.URLParam,
  290. mw.URLParam,
  291. ),
  292. mw.URLParam,
  293. mw.ReadAccess,
  294. ),
  295. )
  296. // /api/projects/{project_id}/clusters routes
  297. r.Method(
  298. "GET",
  299. "/projects/{project_id}/clusters",
  300. auth.DoesUserHaveProjectAccess(
  301. requestlog.NewHandler(a.HandleListProjectClusters, l),
  302. mw.URLParam,
  303. mw.ReadAccess,
  304. ),
  305. )
  306. r.Method(
  307. "POST",
  308. "/projects/{project_id}/clusters",
  309. auth.DoesUserHaveProjectAccess(
  310. auth.DoesUserHaveAWSIntegrationAccess(
  311. auth.DoesUserHaveGCPIntegrationAccess(
  312. requestlog.NewHandler(a.HandleCreateProjectCluster, l),
  313. mw.URLParam,
  314. mw.BodyParam,
  315. true,
  316. ),
  317. mw.URLParam,
  318. mw.BodyParam,
  319. true,
  320. ),
  321. mw.URLParam,
  322. mw.WriteAccess,
  323. ),
  324. )
  325. r.Method(
  326. "GET",
  327. "/projects/{project_id}/clusters/{cluster_id}",
  328. auth.DoesUserHaveProjectAccess(
  329. auth.DoesUserHaveClusterAccess(
  330. requestlog.NewHandler(a.HandleReadProjectCluster, l),
  331. mw.URLParam,
  332. mw.URLParam,
  333. ),
  334. mw.URLParam,
  335. mw.ReadAccess,
  336. ),
  337. )
  338. r.Method(
  339. "POST",
  340. "/projects/{project_id}/clusters/{cluster_id}",
  341. auth.DoesUserHaveProjectAccess(
  342. auth.DoesUserHaveClusterAccess(
  343. requestlog.NewHandler(a.HandleUpdateProjectCluster, l),
  344. mw.URLParam,
  345. mw.URLParam,
  346. ),
  347. mw.URLParam,
  348. mw.WriteAccess,
  349. ),
  350. )
  351. r.Method(
  352. "DELETE",
  353. "/projects/{project_id}/clusters/{cluster_id}",
  354. auth.DoesUserHaveProjectAccess(
  355. auth.DoesUserHaveClusterAccess(
  356. requestlog.NewHandler(a.HandleDeleteProjectCluster, l),
  357. mw.URLParam,
  358. mw.URLParam,
  359. ),
  360. mw.URLParam,
  361. mw.WriteAccess,
  362. ),
  363. )
  364. // /api/projects/{project_id}/clusters/candidates routes
  365. r.Method(
  366. "POST",
  367. "/projects/{project_id}/clusters/candidates",
  368. auth.DoesUserHaveProjectAccess(
  369. requestlog.NewHandler(a.HandleCreateProjectClusterCandidates, l),
  370. mw.URLParam,
  371. mw.WriteAccess,
  372. ),
  373. )
  374. r.Method(
  375. "GET",
  376. "/projects/{project_id}/clusters/candidates",
  377. auth.DoesUserHaveProjectAccess(
  378. requestlog.NewHandler(a.HandleListProjectClusterCandidates, l),
  379. mw.URLParam,
  380. mw.WriteAccess,
  381. ),
  382. )
  383. r.Method(
  384. "POST",
  385. "/projects/{project_id}/clusters/candidates/{candidate_id}/resolve",
  386. auth.DoesUserHaveProjectAccess(
  387. requestlog.NewHandler(a.HandleResolveClusterCandidate, l),
  388. mw.URLParam,
  389. mw.WriteAccess,
  390. ),
  391. )
  392. // /api/projects/{project_id}/integrations routes
  393. r.Method(
  394. "POST",
  395. "/projects/{project_id}/integrations/gcp",
  396. auth.DoesUserHaveProjectAccess(
  397. requestlog.NewHandler(a.HandleCreateGCPIntegration, l),
  398. mw.URLParam,
  399. mw.WriteAccess,
  400. ),
  401. )
  402. r.Method(
  403. "POST",
  404. "/projects/{project_id}/integrations/aws",
  405. auth.DoesUserHaveProjectAccess(
  406. requestlog.NewHandler(a.HandleCreateAWSIntegration, l),
  407. mw.URLParam,
  408. mw.WriteAccess,
  409. ),
  410. )
  411. r.Method(
  412. "POST",
  413. "/projects/{project_id}/integrations/basic",
  414. auth.DoesUserHaveProjectAccess(
  415. requestlog.NewHandler(a.HandleCreateBasicAuthIntegration, l),
  416. mw.URLParam,
  417. mw.WriteAccess,
  418. ),
  419. )
  420. // /api/projects/{project_id}/helmrepos routes
  421. r.Method(
  422. "POST",
  423. "/projects/{project_id}/helmrepos",
  424. auth.DoesUserHaveProjectAccess(
  425. auth.DoesUserHaveAWSIntegrationAccess(
  426. auth.DoesUserHaveGCPIntegrationAccess(
  427. requestlog.NewHandler(a.HandleCreateHelmRepo, l),
  428. mw.URLParam,
  429. mw.BodyParam,
  430. true,
  431. ),
  432. mw.URLParam,
  433. mw.BodyParam,
  434. true,
  435. ),
  436. mw.URLParam,
  437. mw.WriteAccess,
  438. ),
  439. )
  440. r.Method(
  441. "GET",
  442. "/projects/{project_id}/helmrepos",
  443. auth.DoesUserHaveProjectAccess(
  444. requestlog.NewHandler(a.HandleListProjectHelmRepos, l),
  445. mw.URLParam,
  446. mw.WriteAccess,
  447. ),
  448. )
  449. r.Method(
  450. "GET",
  451. "/projects/{project_id}/helmrepos/{helm_id}/charts",
  452. auth.DoesUserHaveProjectAccess(
  453. requestlog.NewHandler(a.HandleListHelmRepoCharts, l),
  454. mw.URLParam,
  455. mw.WriteAccess,
  456. ),
  457. )
  458. // /api/projects/{project_id}/registries routes
  459. r.Method(
  460. "POST",
  461. "/projects/{project_id}/registries",
  462. auth.DoesUserHaveProjectAccess(
  463. auth.DoesUserHaveAWSIntegrationAccess(
  464. auth.DoesUserHaveGCPIntegrationAccess(
  465. requestlog.NewHandler(a.HandleCreateRegistry, l),
  466. mw.URLParam,
  467. mw.BodyParam,
  468. true,
  469. ),
  470. mw.URLParam,
  471. mw.BodyParam,
  472. true,
  473. ),
  474. mw.URLParam,
  475. mw.WriteAccess,
  476. ),
  477. )
  478. r.Method(
  479. "GET",
  480. "/projects/{project_id}/registries",
  481. auth.DoesUserHaveProjectAccess(
  482. requestlog.NewHandler(a.HandleListProjectRegistries, l),
  483. mw.URLParam,
  484. mw.WriteAccess,
  485. ),
  486. )
  487. r.Method(
  488. "POST",
  489. "/projects/{project_id}/registries/{registry_id}",
  490. auth.DoesUserHaveProjectAccess(
  491. auth.DoesUserHaveRegistryAccess(
  492. requestlog.NewHandler(a.HandleUpdateProjectRegistry, l),
  493. mw.URLParam,
  494. mw.URLParam,
  495. ),
  496. mw.URLParam,
  497. mw.WriteAccess,
  498. ),
  499. )
  500. r.Method(
  501. "GET",
  502. "/projects/{project_id}/registries/ecr/{region}/token",
  503. auth.DoesUserHaveProjectAccess(
  504. requestlog.NewHandler(a.HandleGetProjectRegistryECRToken, l),
  505. mw.URLParam,
  506. mw.WriteAccess,
  507. ),
  508. )
  509. r.Method(
  510. "GET",
  511. "/projects/{project_id}/registries/gcr/token",
  512. auth.DoesUserHaveProjectAccess(
  513. requestlog.NewHandler(a.HandleGetProjectRegistryGCRToken, l),
  514. mw.URLParam,
  515. mw.WriteAccess,
  516. ),
  517. )
  518. r.Method(
  519. "DELETE",
  520. "/projects/{project_id}/registries/{registry_id}",
  521. auth.DoesUserHaveProjectAccess(
  522. auth.DoesUserHaveRegistryAccess(
  523. requestlog.NewHandler(a.HandleDeleteProjectRegistry, l),
  524. mw.URLParam,
  525. mw.URLParam,
  526. ),
  527. mw.URLParam,
  528. mw.WriteAccess,
  529. ),
  530. )
  531. // /api/projects/{project_id}/registries/{registry_id}/repositories routes
  532. r.Method(
  533. "GET",
  534. "/projects/{project_id}/registries/{registry_id}/repositories",
  535. auth.DoesUserHaveProjectAccess(
  536. auth.DoesUserHaveRegistryAccess(
  537. requestlog.NewHandler(a.HandleListRepositories, l),
  538. mw.URLParam,
  539. mw.URLParam,
  540. ),
  541. mw.URLParam,
  542. mw.WriteAccess,
  543. ),
  544. )
  545. r.Method(
  546. "GET",
  547. // * is the repo name, which can itself be nested
  548. // for example, for GCR this is project-id/repo
  549. // need to use wildcard, see https://github.com/go-chi/chi/issues/243
  550. "/projects/{project_id}/registries/{registry_id}/repositories/*",
  551. auth.DoesUserHaveProjectAccess(
  552. auth.DoesUserHaveRegistryAccess(
  553. requestlog.NewHandler(a.HandleListImages, l),
  554. mw.URLParam,
  555. mw.URLParam,
  556. ),
  557. mw.URLParam,
  558. mw.WriteAccess,
  559. ),
  560. )
  561. // /api/projects/{project_id}/releases routes
  562. r.Method(
  563. "GET",
  564. "/projects/{project_id}/releases",
  565. auth.DoesUserHaveProjectAccess(
  566. auth.DoesUserHaveClusterAccess(
  567. requestlog.NewHandler(a.HandleListReleases, l),
  568. mw.URLParam,
  569. mw.QueryParam,
  570. ),
  571. mw.URLParam,
  572. mw.ReadAccess,
  573. ),
  574. )
  575. r.Method(
  576. "GET",
  577. "/projects/{project_id}/releases/{name}/{revision}/components",
  578. auth.DoesUserHaveProjectAccess(
  579. auth.DoesUserHaveClusterAccess(
  580. requestlog.NewHandler(a.HandleGetReleaseComponents, l),
  581. mw.URLParam,
  582. mw.QueryParam,
  583. ),
  584. mw.URLParam,
  585. mw.ReadAccess,
  586. ),
  587. )
  588. r.Method(
  589. "GET",
  590. "/projects/{project_id}/releases/{name}/{revision}/controllers",
  591. auth.DoesUserHaveProjectAccess(
  592. auth.DoesUserHaveClusterAccess(
  593. requestlog.NewHandler(a.HandleGetReleaseControllers, l),
  594. mw.URLParam,
  595. mw.QueryParam,
  596. ),
  597. mw.URLParam,
  598. mw.ReadAccess,
  599. ),
  600. )
  601. r.Method(
  602. "GET",
  603. "/projects/{project_id}/releases/{name}/history",
  604. auth.DoesUserHaveProjectAccess(
  605. auth.DoesUserHaveClusterAccess(
  606. requestlog.NewHandler(a.HandleListReleaseHistory, l),
  607. mw.URLParam,
  608. mw.QueryParam,
  609. ),
  610. mw.URLParam,
  611. mw.ReadAccess,
  612. ),
  613. )
  614. r.Method(
  615. "GET",
  616. "/projects/{project_id}/releases/{name}/webhook_token",
  617. auth.DoesUserHaveProjectAccess(
  618. auth.DoesUserHaveClusterAccess(
  619. requestlog.NewHandler(a.HandleGetReleaseToken, l),
  620. mw.URLParam,
  621. mw.QueryParam,
  622. ),
  623. mw.URLParam,
  624. mw.ReadAccess,
  625. ),
  626. )
  627. r.Method(
  628. "POST",
  629. "/projects/{project_id}/releases/{name}/upgrade",
  630. auth.DoesUserHaveProjectAccess(
  631. auth.DoesUserHaveClusterAccess(
  632. requestlog.NewHandler(a.HandleUpgradeRelease, l),
  633. mw.URLParam,
  634. mw.QueryParam,
  635. ),
  636. mw.URLParam,
  637. mw.ReadAccess,
  638. ),
  639. )
  640. r.Method(
  641. "GET",
  642. "/projects/{project_id}/releases/{name}/{revision}",
  643. auth.DoesUserHaveProjectAccess(
  644. auth.DoesUserHaveClusterAccess(
  645. requestlog.NewHandler(a.HandleGetRelease, l),
  646. mw.URLParam,
  647. mw.QueryParam,
  648. ),
  649. mw.URLParam,
  650. mw.ReadAccess,
  651. ),
  652. )
  653. r.Method(
  654. "POST",
  655. "/projects/{project_id}/releases/{name}/rollback",
  656. auth.DoesUserHaveProjectAccess(
  657. auth.DoesUserHaveClusterAccess(
  658. requestlog.NewHandler(a.HandleRollbackRelease, l),
  659. mw.URLParam,
  660. mw.QueryParam,
  661. ),
  662. mw.URLParam,
  663. mw.ReadAccess,
  664. ),
  665. )
  666. // r.Method(
  667. // "POST",
  668. // "/projects/{project_id}/releases/{name}/upgrade/hook",
  669. // requestlog.NewHandler(a.HandleReleaseDeployHook, l),
  670. // )
  671. r.Method(
  672. "POST",
  673. "/webhooks/deploy/{token}",
  674. requestlog.NewHandler(a.HandleReleaseDeployWebhook, l),
  675. )
  676. // /api/projects/{project_id}/gitrepos routes
  677. r.Method(
  678. "GET",
  679. "/projects/{project_id}/gitrepos",
  680. auth.DoesUserHaveProjectAccess(
  681. requestlog.NewHandler(a.HandleListProjectGitRepos, l),
  682. mw.URLParam,
  683. mw.ReadAccess,
  684. ),
  685. )
  686. r.Method(
  687. "GET",
  688. "/projects/{project_id}/gitrepos/{git_repo_id}/repos",
  689. auth.DoesUserHaveProjectAccess(
  690. auth.DoesUserHaveGitRepoAccess(
  691. requestlog.NewHandler(a.HandleListRepos, l),
  692. mw.URLParam,
  693. mw.QueryParam,
  694. ),
  695. mw.URLParam,
  696. mw.ReadAccess,
  697. ),
  698. )
  699. r.Method(
  700. "GET",
  701. "/projects/{project_id}/gitrepos/{git_repo_id}/repos/{kind}/{name}/branches",
  702. auth.DoesUserHaveProjectAccess(
  703. auth.DoesUserHaveGitRepoAccess(
  704. requestlog.NewHandler(a.HandleGetBranches, l),
  705. mw.URLParam,
  706. mw.QueryParam,
  707. ),
  708. mw.URLParam,
  709. mw.ReadAccess,
  710. ),
  711. )
  712. r.Method(
  713. "GET",
  714. "/projects/{project_id}/gitrepos/{git_repo_id}/repos/{kind}/{name}/{branch}/contents",
  715. auth.DoesUserHaveProjectAccess(
  716. auth.DoesUserHaveGitRepoAccess(
  717. requestlog.NewHandler(a.HandleGetBranchContents, l),
  718. mw.URLParam,
  719. mw.QueryParam,
  720. ),
  721. mw.URLParam,
  722. mw.ReadAccess,
  723. ),
  724. )
  725. // /api/projects/{project_id}/deploy routes
  726. r.Method(
  727. "POST",
  728. "/projects/{project_id}/deploy/{name}/{version}",
  729. auth.DoesUserHaveProjectAccess(
  730. auth.DoesUserHaveClusterAccess(
  731. requestlog.NewHandler(a.HandleDeployTemplate, l),
  732. mw.URLParam,
  733. mw.QueryParam,
  734. ),
  735. mw.URLParam,
  736. mw.ReadAccess,
  737. ),
  738. )
  739. // /api/projects/{project_id}/k8s routes
  740. r.Method(
  741. "GET",
  742. "/projects/{project_id}/k8s/namespaces",
  743. auth.DoesUserHaveProjectAccess(
  744. auth.DoesUserHaveClusterAccess(
  745. requestlog.NewHandler(a.HandleListNamespaces, l),
  746. mw.URLParam,
  747. mw.QueryParam,
  748. ),
  749. mw.URLParam,
  750. mw.ReadAccess,
  751. ),
  752. )
  753. r.Method(
  754. "GET",
  755. "/projects/{project_id}/k8s/{namespace}/pod/{name}/logs",
  756. auth.DoesUserHaveProjectAccess(
  757. auth.DoesUserHaveClusterAccess(
  758. requestlog.NewHandler(a.HandleGetPodLogs, l),
  759. mw.URLParam,
  760. mw.QueryParam,
  761. ),
  762. mw.URLParam,
  763. mw.ReadAccess,
  764. ),
  765. )
  766. r.Method(
  767. "GET",
  768. "/projects/{project_id}/k8s/{namespace}/ingress/{name}",
  769. auth.DoesUserHaveProjectAccess(
  770. auth.DoesUserHaveClusterAccess(
  771. requestlog.NewHandler(a.HandleGetIngress, l),
  772. mw.URLParam,
  773. mw.QueryParam,
  774. ),
  775. mw.URLParam,
  776. mw.ReadAccess,
  777. ),
  778. )
  779. r.Method(
  780. "GET",
  781. "/projects/{project_id}/k8s/{kind}/status",
  782. auth.DoesUserHaveProjectAccess(
  783. auth.DoesUserHaveClusterAccess(
  784. requestlog.NewHandler(a.HandleStreamControllerStatus, l),
  785. mw.URLParam,
  786. mw.QueryParam,
  787. ),
  788. mw.URLParam,
  789. mw.ReadAccess,
  790. ),
  791. )
  792. r.Method(
  793. "GET",
  794. "/projects/{project_id}/k8s/pods",
  795. auth.DoesUserHaveProjectAccess(
  796. auth.DoesUserHaveClusterAccess(
  797. requestlog.NewHandler(a.HandleListPods, l),
  798. mw.URLParam,
  799. mw.QueryParam,
  800. ),
  801. mw.URLParam,
  802. mw.ReadAccess,
  803. ),
  804. )
  805. })
  806. staticFilePath := a.ServerConf.StaticFilePath
  807. fs := http.FileServer(http.Dir(staticFilePath))
  808. r.Get("/*", func(w http.ResponseWriter, r *http.Request) {
  809. if _, err := os.Stat(staticFilePath + r.RequestURI); os.IsNotExist(err) {
  810. http.StripPrefix(r.URL.Path, fs).ServeHTTP(w, r)
  811. } else {
  812. fs.ServeHTTP(w, r)
  813. }
  814. })
  815. return r
  816. }