OpenIDM обновляет атрибуты пользователей через пользовательскую конечную точку

Я пытаюсь разработать пользовательскую конечную точку js в OpenIDM, в которой я обновляю пользователя, которого искали, двумя атрибутами, которые я генерирую (otpexpiry а также otpvalue) в моем сценарии.

Я добавил JSON Conf в openidm/conf/endpoint-otp.json связывать:

{
 "context" : "endpoint/otp/*",
 "type" : "text/javascript",
 "file" : "script/otp.js"
}

И это мой сценарий openidm/script/otp.js:

(function() {
 if(request.method === "update") {
  var five_minutes = 5 * 60 * 1000;
  var timestamp = new Date().getTime();
  var otpexpiry = timestamp + five_minutes;
  var otpvalue = Math.floor(Math.random() * 9999);


  /* Not sure of this code below I have to update the user searched with " otpdate : otpexpiry " and "otp : otpvalue "*/
  var u = request.value;
  var id = "managed/user/" + u._id;
  if (id != null) {
    openidm['update']( ... );
  }

  return {
       method: "update",
       resourceName: request.resourcePath,
       revision: request.revision,
       parameters: request.additionalParameters,
       patch: request.patchpperations,
       context: context.current
       };
  } else {
       throw { code: 500, message: "Unknown request type " + request.method};
  }
})();

Как я могу обновить две переменные пользователя, которого искали?

1 ответ

Решение

Для тех, кто заинтересован в том, как я этого добился, ниже приведен мой код. Я просто передаю данные из POST, я запрашиваю пользователя, а затем использую openidm.patch метод для обновления атрибутов.

(function(){
    var content = request.content;
        java.lang.System.out.println(content);

        var userID = content.id;
        var userEmail = content.email;
        java.lang.System.out.println("User ID: " + userID);
        java.lang.System.out.println("User Email: " + userEmail);

        var qry = {
                '_queryFilter' : '/mail eq "' + userEmail + '"'
        };
        var userFound = openidm.query("managed/user", qry);

        if (userFound != null) {
                java.lang.System.out.println(userFound);

                /*Generate OTP and Expiry */
                var five_minutes = 5 * 60 * 1000;
                var timestamp = new Date().getTime();
                var otpexpiry = timestamp + five_minutes;
                var otpvalue = Math.floor(Math.random() * 9999);

                java.lang.System.out.println("OTP Valore: " + otpvalue);
                java.lang.System.out.println("Scadenza: " + otpexpiry);

                var patch = [{ "operation" : "replace", "field" : "/otp", "value" : otpvalue },{ "operation" : "replace", "field" : "/otpdate" , "value" : otpexpiry }];

                openidm.patch("managed/user/" + userID, null, patch);

                return true;

        }

})();

Вы можете запустить эту конечную точку с помощью метода POST:

curl -k \
--header "X-OpenIDM-Username: xxx" \
--header "X-OpenIDM-Password: xxx" \
--header "Content-Type: application/json" \
--header "Accept: application/json" \
--data '{ \
"id" : "2d141539-50b6-4637-bfe8-24a1d61fa556", \
"email" : "jdoe@example.com" }' \
--request POST "https://localhost:8443/openidm/endpoint/otp"
Другие вопросы по тегам