|
11 | 11 | import jakarta.inject.Inject; |
12 | 12 | import jakarta.ws.rs.NotFoundException; |
13 | 13 | import org.accounting.system.beans.RequestUserContext; |
| 14 | +import org.accounting.system.dtos.project.UpdateProjectRequest; |
14 | 15 | import org.accounting.system.entities.HierarchicalRelation; |
15 | 16 | import org.accounting.system.entities.MetricDefinition; |
16 | 17 | import org.accounting.system.entities.acl.RoleAccessControl; |
|
32 | 33 | import org.accounting.system.repositories.metric.MetricRepository; |
33 | 34 | import org.accounting.system.repositories.provider.ProviderRepository; |
34 | 35 | import org.accounting.system.services.authorization.RoleService; |
| 36 | +import org.apache.commons.lang3.StringUtils; |
35 | 37 | import org.bson.Document; |
36 | 38 | import org.bson.conversions.Bson; |
37 | 39 |
|
@@ -281,6 +283,46 @@ public ProjectProjection fetchById(String projectId){ |
281 | 283 | .first(); |
282 | 284 | } |
283 | 285 |
|
| 286 | + public ProjectProjection updateProject(UpdateProjectRequest request, String id) { |
| 287 | + |
| 288 | + var eq = Filters.eq("_id", id); |
| 289 | + |
| 290 | + var list = new ArrayList<Bson>(); |
| 291 | + |
| 292 | + if(StringUtils.isNotEmpty(request.acronym)){ |
| 293 | + |
| 294 | + list.add(Updates.set("acronym", request.acronym)); |
| 295 | + } |
| 296 | + |
| 297 | + if(StringUtils.isNotEmpty(request.title)){ |
| 298 | + |
| 299 | + list.add(Updates.set("title", request.title)); |
| 300 | + } |
| 301 | + |
| 302 | + if(StringUtils.isNotEmpty(request.startDate)){ |
| 303 | + |
| 304 | + list.add(Updates.set("startDate", request.startDate)); |
| 305 | + } |
| 306 | + |
| 307 | + if(StringUtils.isNotEmpty(request.endDate)){ |
| 308 | + |
| 309 | + list.add(Updates.set("endDate", request.endDate)); |
| 310 | + } |
| 311 | + |
| 312 | + if(StringUtils.isNotEmpty(request.callIdentifier)){ |
| 313 | + |
| 314 | + list.add(Updates.set("callIdentifier", request.callIdentifier)); |
| 315 | + } |
| 316 | + |
| 317 | + var update = Updates.combine( |
| 318 | + list |
| 319 | + ); |
| 320 | + |
| 321 | + getMongoCollection().updateOne(eq, update); |
| 322 | + |
| 323 | + return fetchById(id); |
| 324 | + } |
| 325 | + |
284 | 326 | public boolean accessibility(String projectId, Collection collection, Operation operation){ |
285 | 327 |
|
286 | 328 | var roleAccessControls = fetchRoleAccessControl(projectId, requestUserContext.getId()); |
|
0 commit comments