github.js 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * Copyright 2010-2020 Gildas Lormeau
  3. * contact : gildas.lormeau <at> gmail.com
  4. *
  5. * This file is part of SingleFile.
  6. *
  7. * The code in this file is free software: you can redistribute it and/or
  8. * modify it under the terms of the GNU Affero General Public License
  9. * (GNU AGPL) as published by the Free Software Foundation, either version 3
  10. * of the License, or (at your option) any later version.
  11. *
  12. * The code in this file is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero
  15. * General Public License for more details.
  16. *
  17. * As additional permission under GNU AGPL version 3 section 7, you may
  18. * distribute UNMODIFIED VERSIONS OF THIS file without the copy of the GNU
  19. * AGPL normally required by section 4, provided you include this license
  20. * notice and a URL through which recipients can access the Corresponding
  21. * Source.
  22. */
  23. /* global fetch, btoa */
  24. export { pushGitHub };
  25. let pendingPush;
  26. async function pushGitHub(token, userName, repositoryName, branchName, path, content) {
  27. while (pendingPush) {
  28. await pendingPush;
  29. }
  30. pendingPush = async () => {
  31. try {
  32. await createContent({ path, content });
  33. } finally {
  34. pendingPush = null;
  35. }
  36. };
  37. await pendingPush();
  38. async function createContent({ path, content, message = "" }) {
  39. const response = await fetch(`https://api.github.com/repos/${userName}/${repositoryName}/contents/${path}`, {
  40. method: "PUT",
  41. headers: new Map([
  42. ["Authorization", `token ${token}`],
  43. ["Accept", "application/vnd.github.v3+json"]
  44. ]),
  45. body: JSON.stringify({ content: btoa(content), message, branch: branchName })
  46. });
  47. const responseData = await response.json();
  48. if (response.status < 400) {
  49. return responseData;
  50. } else {
  51. throw new Error(responseData.message);
  52. }
  53. }
  54. }