UIWindowRequestPermission.js 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. import UIWindow from './UIWindow.js'
  2. async function UIWindowRequestPermission(options){
  3. options = options ?? {};
  4. options.reload_on_success = options.reload_on_success ?? false;
  5. return new Promise(async (resolve) => {
  6. let drivers = [
  7. {
  8. name: 'puter-chat-completion',
  9. human_name: 'AI Chat Completion',
  10. description: 'This app wants to generate text using AI. This may incur costs on your behalf.',
  11. },
  12. {
  13. name: 'puter-image-generation',
  14. human_name: 'AI Image Generation',
  15. description: 'This app wants to generate images using AI. This may incur costs on your behalf.',
  16. },
  17. {
  18. name: 'puter-kvstore',
  19. human_name: 'Puter Storage',
  20. description: 'This app wants to securely store data in your Puter account. This app will not be able to access your personal data or data stored by other apps.',
  21. }
  22. ]
  23. let parts = options.permission.split(":");
  24. let driver_name = parts[1];
  25. let action_name = parts[2];
  26. function findDriverByName(driverName) {
  27. return drivers.find(driver => driver.name === driverName);
  28. }
  29. let driver = findDriverByName(driver_name);
  30. if(driver === undefined){
  31. resolve(false);
  32. return;
  33. }
  34. let h = ``;
  35. h += `<div>`;
  36. h += `<div style="padding: 20px; width: 100%; box-sizing: border-box;">`;
  37. // title
  38. h += `<h1 class="perm-title">"<span style="word-break: break-word;">${html_encode(options.app_uid ?? options.origin)}</span>" would Like to use ${html_encode(driver.human_name)}</h1>`;
  39. // todo show the real description of action
  40. h += `<p class="perm-description">${html_encode(driver.description)}</p>`;
  41. // Allow/Don't Allow
  42. h += `<button type="button" class="app-auth-allow button button-primary button-block" style="margin-top: 10px;">Allow</button>`;
  43. h += `<button type="button" class="app-auth-dont-allow button button-default button-block" style="margin-top: 10px;">Don't Allow</button>`;
  44. h += `</div>`;
  45. h += `</div>`;
  46. const el_window = await UIWindow({
  47. title: null,
  48. app: 'request-authorization',
  49. single_instance: true,
  50. icon: null,
  51. uid: null,
  52. is_dir: false,
  53. body_content: h,
  54. draggable_body: false,
  55. has_head: true,
  56. selectable_body: false,
  57. draggable_body: true,
  58. allow_context_menu: false,
  59. is_draggable: true,
  60. is_droppable: false,
  61. is_resizable: false,
  62. stay_on_top: false,
  63. allow_native_ctxmenu: true,
  64. allow_user_select: true,
  65. ...options.window_options,
  66. width: 350,
  67. dominant: true,
  68. on_close: ()=>{
  69. resolve(false)
  70. },
  71. onAppend: function(this_window){
  72. },
  73. window_class: 'window-login',
  74. window_css:{
  75. height: 'initial',
  76. },
  77. body_css: {
  78. width: 'initial',
  79. padding: '0',
  80. 'background-color': 'rgba(231, 238, 245, .95)',
  81. 'backdrop-filter': 'blur(3px)',
  82. }
  83. })
  84. $(el_window).find('.app-auth-allow').on('click', async function(e){
  85. $(this).addClass('disabled');
  86. try{
  87. const res = await fetch( window.api_origin + "/auth/grant-user-app", {
  88. "headers": {
  89. "Content-Type": "application/json",
  90. "Authorization": "Bearer " + window.auth_token,
  91. },
  92. "body": JSON.stringify({
  93. app_uid: options.app_uid,
  94. origin: options.origin,
  95. permission: options.permission
  96. }),
  97. "method": "POST",
  98. });
  99. }catch(err){
  100. console.error(err);
  101. resolve(err);
  102. }
  103. resolve(true);
  104. })
  105. $(el_window).find('.app-auth-dont-allow').on('click', function(e){
  106. $(this).addClass('disabled');
  107. $(el_window).close();
  108. resolve(false);
  109. })
  110. })
  111. }
  112. export default UIWindowRequestPermission