2017-06-07 5 views
0

J'essaie de développer un point de terminaison js personnalisé dans OpenIDM dans lequel je mets à jour l'utilisateur recherché avec deux attributs que je génère (otpexpiry et otpvalue) dans mon script.OpenIDM met à jour les attributs utilisateur sur le noeud final personnalisé

J'ai ajouté un JSON en openidm/conf/endpoint-otp.json à conf lien:

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

Et ceci est mon script 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}; 
    } 
})(); 

Comment puis-je mettre à jour deux variables de l'utilisateur recherché?

Répondre

0

Pour ceux qui s'intéressent à la façon dont j'ai réalisé ceci, voici mon code. Je passe simplement les données d'un POST, je demande à l'utilisateur, puis j'utilise la méthode openidm.patch pour mettre à jour les attributs.

(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; 

     } 

})(); 

Vous pouvez déclencher ce paramètre avec une méthode 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" : "[email protected]" }' \ 
--request POST "https://localhost:8443/openidm/endpoint/otp"