LwGenericOpenIdConnectLambdaFunction.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. /*
  2. * Copyright (c) Contributors to the Open 3D Engine Project.
  3. * For complete copyright and license terms please see the LICENSE at the root of this distribution.
  4. *
  5. * SPDX-License-Identifier: Apache-2.0 OR MIT
  6. *
  7. */
  8. var http = require("https");
  9. var clientID = "{{clientID}}";
  10. var clientSecret = "{{clientSecret}}";
  11. var redirectUrl = "{{redirectUrl}}";
  12. var getRefreshToken = function(code, callback)
  13. {
  14. var options = {
  15. hostname: '{{hostname}}',
  16. path: '{{path}}',
  17. port: {{port}},
  18. method : "POST",
  19. headers : {'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'}
  20. };
  21. var body = "grant_type=authorization_code&";
  22. body += "client_id=" + clientID + "&";
  23. body += "redirect_uri=" + redirectUrl + "&";
  24. body += "client_secret=" + clientSecret + "&";
  25. body += "code=" + code;
  26. console.log(body);
  27. var req = http.request(options, function(res) {
  28. res.setEncoding('utf8');
  29. var store = "";
  30. res.on('data', function (chunk) {
  31. console.log(chunk);
  32. store += chunk;
  33. });
  34. res.on('end', function() {
  35. var response = JSON.parse(store);
  36. var data = {
  37. access_token : response.access_token,
  38. expires_in : response.expires_in,
  39. refresh_token : response.refresh_token,
  40. id_token : response.id_token
  41. };
  42. console.log(data);
  43. callback(null, data);
  44. });
  45. req.on('error', function(e) {
  46. console.log('problem with request: ' + e.message);
  47. callback(e);
  48. });
  49. });
  50. req.write(body);
  51. req.end();
  52. };
  53. var refreshAccessToken = function(refreshToken, callback)
  54. {
  55. var options = {
  56. hostname: '{{hostname}}',
  57. path: '{{path}}',
  58. port: {{port}},
  59. method : "POST",
  60. headers : {'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'}
  61. };
  62. var body = "grant_type=refresh_token&";
  63. body += "refresh_token=" + refreshToken + "&";
  64. body += "client_id=" + clientID + "&";
  65. body += "client_secret=" + clientSecret;
  66. console.log(body);
  67. var req = http.request(options, function(res) {
  68. res.setEncoding('utf8');
  69. var store = "";
  70. res.on('data', function (chunk) {
  71. console.log(chunk);
  72. store += chunk;
  73. });
  74. res.on('end', function() {
  75. var response = JSON.parse(store);
  76. var data = {
  77. access_token : response.access_token,
  78. expires_in : response.expires_in
  79. };
  80. console.log(data);
  81. callback(null, data);
  82. });
  83. req.on('error', function(e) {
  84. console.log('problem with request: ' + e.message);
  85. callback(e);
  86. });
  87. });
  88. req.write(body);
  89. req.end();
  90. };
  91. exports.{{handlerName}} = function(event, context) {
  92. if(typeof event.code != 'undefined') {
  93. var code = event.code;
  94. console.log(code);
  95. getRefreshToken(code, function(err, data)
  96. {
  97. if(err)
  98. {
  99. context.fail(err);
  100. }
  101. else
  102. {
  103. context.succeed (data);
  104. }
  105. });
  106. }
  107. else if(typeof event.refresh_token != 'undefined') {
  108. var refresh_token = event.refresh_token;
  109. console.log(refresh_token);
  110. refreshAccessToken(refresh_token, function(err, data)
  111. {
  112. if(err)
  113. {
  114. context.fail(err);
  115. }
  116. else
  117. {
  118. context.succeed (data);
  119. }
  120. });
  121. }
  122. };