| rev | 
   line source | 
| 
bsw/jbe@1309
 | 
     1 slot.set_layout(nil, "application/json")
 | 
| 
bsw/jbe@1309
 | 
     2 
 | 
| 
bsw/jbe@1309
 | 
     3 local r = json.object{}
 | 
| 
bsw/jbe@1309
 | 
     4 
 | 
| 
bsw/jbe@1309
 | 
     5 if request.is_post() then
 | 
| 
bsw/jbe@1309
 | 
     6   if not app.scopes.update_profile then
 | 
| 
bsw/jbe@1309
 | 
     7     return util.api_error(403, "Forbidden", "insufficient_scope", "Scope update_profile required")
 | 
| 
bsw/jbe@1309
 | 
     8   end
 | 
| 
bsw/jbe@1309
 | 
     9   local profile = app.access_token.member.profile
 | 
| 
bsw/jbe@1309
 | 
    10   local fields = json.import(param.get("update"))
 | 
| 
bsw/jbe@1309
 | 
    11   if not fields then
 | 
| 
bsw/jbe@1309
 | 
    12     return util.api_error(400, "Bad Request", "profile_data_expected", "JSON object with updated profile data expected")
 | 
| 
bsw/jbe@1309
 | 
    13   end
 | 
| 
bsw/jbe@1309
 | 
    14   for i, field in ipairs(config.member_profile_fields) do
 | 
| 
bsw/jbe@1309
 | 
    15     if json.type(fields, field.id) ~= "nil" then
 | 
| 
bsw/jbe@1309
 | 
    16       local value = fields[field.id]
 | 
| 
bsw/jbe@1309
 | 
    17       if value ~= nil and (field.type == "string" or field.type == "text") and json.type(value) ~= "string" then
 | 
| 
bsw/jbe@1309
 | 
    18         return util.api_error(400, "Bad Request", "string_expected", "JSON encoded string value expected")
 | 
| 
bsw/jbe@1309
 | 
    19       end
 | 
| 
bsw@1817
 | 
    20       if field.validate_func then
 | 
| 
bsw@1817
 | 
    21         local success = field.validate_func(field, fields)
 | 
| 
bsw@1817
 | 
    22         if not success then
 | 
| 
bsw@1817
 | 
    23           return util.api_error(403, "Forbidden", "validation_failure", "Request could not be validated")
 | 
| 
bsw@1817
 | 
    24         end
 | 
| 
bsw@1817
 | 
    25       end
 | 
| 
bsw/jbe@1309
 | 
    26       profile.profile[field.id] = value
 | 
| 
bsw/jbe@1309
 | 
    27     end
 | 
| 
bsw/jbe@1309
 | 
    28   end
 | 
| 
bsw/jbe@1309
 | 
    29   profile:save()
 | 
| 
bsw/jbe@1309
 | 
    30   r.status = 'ok'
 | 
| 
bsw/jbe@1309
 | 
    31   slot.put_into("data", json.export(r))
 | 
| 
bsw/jbe@1309
 | 
    32   slot.put_into("data", "\n")
 | 
| 
bsw/jbe@1309
 | 
    33 else
 | 
| 
bsw/jbe@1309
 | 
    34   local member_id = tonumber(param.get("member_id"))
 | 
| 
bsw/jbe@1309
 | 
    35   local profile
 | 
| 
bsw/jbe@1309
 | 
    36   if member_id then
 | 
| 
bsw/jbe@1309
 | 
    37     if not app.scopes.read_profiles then
 | 
| 
bsw/jbe@1309
 | 
    38       return util.api_error(403, "Forbidden", "insufficient_scope", "Scope profile required")
 | 
| 
bsw/jbe@1309
 | 
    39     end
 | 
| 
bsw/jbe@1309
 | 
    40     local member = Member:by_id(member_id)
 | 
| 
bsw/jbe@1309
 | 
    41     if not member then
 | 
| 
bsw/jbe@1309
 | 
    42       return util.api_error(400, "Bad Request", "member_not_found", "No member with requested member_id")
 | 
| 
bsw/jbe@1309
 | 
    43     end
 | 
| 
bsw/jbe@1309
 | 
    44     profile = member.profile
 | 
| 
bsw/jbe@1309
 | 
    45   elseif app.access_token then
 | 
| 
bsw/jbe@1309
 | 
    46     if not app.scopes.profile and not app.scopes.read_profiles then
 | 
| 
bsw/jbe@1309
 | 
    47       return util.api_error(403, "Forbidden", "insufficient_scope", "Scope profile required")
 | 
| 
bsw/jbe@1309
 | 
    48     end
 | 
| 
bsw/jbe@1309
 | 
    49     profile = app.access_token.member.profile
 | 
| 
bsw/jbe@1309
 | 
    50   else
 | 
| 
bsw/jbe@1309
 | 
    51     return util.api_error(400, "Bad Request", "no_member_id", "No member_id requested")
 | 
| 
bsw/jbe@1309
 | 
    52   end
 | 
| 
bsw/jbe@1309
 | 
    53   if profile then
 | 
| 
bsw/jbe@1309
 | 
    54     r = execute.chunk{ module = "api", chunk = "_profile", params = { profile = profile } }
 | 
| 
bsw/jbe@1309
 | 
    55   end
 | 
| 
bsw/jbe@1309
 | 
    56   slot.put_into("data", json.export(json.object{ result = r }))
 | 
| 
bsw/jbe@1309
 | 
    57   slot.put_into("data", "\n")
 | 
| 
bsw/jbe@1309
 | 
    58 end
 | 
| 
bsw/jbe@1309
 | 
    59 
 |