All Downloads are FREE. Search and download functionalities are using the official Maven repository.

cn.vertxup.erp.api.EmployeeAgent Maven / Gradle / Ivy

There is a newer version: 0.9.0
Show newest version
package cn.vertxup.erp.api;

import io.vertx.core.json.JsonObject;
import io.vertx.tp.erp.cv.Addr;
import io.vertx.up.annotations.Address;
import io.vertx.up.annotations.EndPoint;

import javax.ws.rs.*;

/*
 * Employee update here: Employee information ADD / DELETE / UPDATE
 * 1) ADD
 * -- 1.1)If `userId` set, call Nexus to update `modelKey` and `modelId`
 * -- 1.2)Otherwise add employee record directly.
 * 2)UPDATE
 * -- `userId` changed double check
 * -- 2.1)Remove, update original S_USER to set null
 * -- 2.2)Add, update the latest S_USER `modelKey` and `modelId`
 * -- 2.3)Change, update original S_USER to set null / update the latest S_USER
 * 3) DELETE
 * -- Update original S_USER to set null
 */
@EndPoint
@Path("/api")
public interface EmployeeAgent {
    /*
     * Get by id finished,
     * append `userId` that related to S_USER account here.
     */
    @GET
    @Path("employee/:key")
    @Address(Addr.Employee.BY_ID)
    JsonObject fetchEmployee(@PathParam("key") String key);

    @POST
    @Path("employee")
    @Address(Addr.Employee.ADD)
    JsonObject add(@BodyParam JsonObject params);

    @PUT
    @Path("employee/:key")
    @Address(Addr.Employee.EDIT)
    JsonObject update(@PathParam("key") String key, @BodyParam JsonObject params);

    @DELETE
    @Path("employee/:key")
    @Address(Addr.Employee.DELETE)
    JsonObject remove(@PathParam("key") String key);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy