Skip to content

Commit

Permalink
server: Add bookmarks endpoint support
Browse files Browse the repository at this point in the history
Using bookmarks, user can save custom data points where each corresponds to a specific time range.
Each bookmark contains "name", "start", "end", and an optional "payload".

The following endpoints are introduced:
- [GET] Get all the bookmarks of an experiment
- [GET] Get a specific bookmark of an experiment
- [POST] Create a new bookmark for an experiment
- [PUT] Update an old bookmark of an experiment
- [DELETE] Delete a bookmark of an experiment

[Added] Corresponding endpoints for bookmarks in trace server

Signed-off-by: Kaveh Shahedi <[email protected]>
  • Loading branch information
kavehshahedi committed Nov 25, 2024
1 parent a3a0358 commit a4e77bf
Show file tree
Hide file tree
Showing 7 changed files with 797 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
/*******************************************************************************
* Copyright (c) 2024 Ericsson
*
* All rights reserved. This program and the accompanying materials are
* made available under the terms of the Eclipse Public License 2.0 which
* accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*******************************************************************************/

package org.eclipse.tracecompass.incubator.internal.trace.server.jersey.rest.core.model;

import java.util.UUID;

import org.eclipse.jdt.annotation.NonNull;

import com.fasterxml.jackson.annotation.JsonProperty;

import io.swagger.v3.oas.annotations.media.Schema;

/**
* Contributes to the model used for TSP swagger-core annotations.
*
* @author Kaveh Shahedi
* @since 10.1
*/
public interface Bookmark {

/**
* @return The bookmark UUID.
*/
@JsonProperty("UUID")
@Schema(description = "The bookmark's unique identifier")
UUID getUUID();

/**
* @return The bookmark name.
*/
@NonNull
@Schema(description = "User defined name for the bookmark")
String getName();

/**
* @return The experiment ID.
*/
@NonNull
@Schema(description = "The experiment's unique identifier this bookmark belongs to")
String getExperimentId();

/**
* @return The start time.
*/
@Schema(description = "The bookmark's start time")
long getStart();

/**
* @return The end time.
*/
@Schema(description = "The bookmark's end time")
long getEnd();

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
/*******************************************************************************
* Copyright (c) 2024 Ericsson
*
* All rights reserved. This program and the accompanying materials are
* made available under the terms of the Eclipse Public License 2.0 which
* accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*******************************************************************************/
package org.eclipse.tracecompass.incubator.internal.trace.server.jersey.rest.core.model;

import com.fasterxml.jackson.annotation.JsonProperty;

import io.swagger.v3.oas.annotations.media.Schema;
import io.swagger.v3.oas.annotations.media.Schema.RequiredMode;

/**
* Parameters for bookmark creation and update operations
*
* @author Kaveh Shahedi
* @since 10.1
*/
public interface BookmarkQueryParameters {

/**
* @return The bookmark parameters
*/
@JsonProperty("parameters")
@Schema(description = "The bookmark parameters", requiredMode = RequiredMode.REQUIRED)
BookmarkParameters getParameters();


interface BookmarkParameters {
/**
* @return The bookmark name
*/
@JsonProperty("name")
@Schema(description = "The name to give this bookmark", requiredMode = RequiredMode.REQUIRED)
String getName();

/**
* @return The start time
*/
@JsonProperty("start")
@Schema(description = "The bookmark's start time", requiredMode = RequiredMode.REQUIRED)
long getStart();

/**
* @return The end time
*/
@JsonProperty("end")
@Schema(description = "The bookmark's end time", requiredMode = RequiredMode.REQUIRED)
long getEnd();
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,136 @@
package org.eclipse.tracecompass.incubator.internal.trace.server.jersey.rest.core.services;

import java.io.Serializable;
import java.util.UUID;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;

/**
* Bookmark model for TSP
*
* @author Kaveh Shahedi
* @since 10.1
*/
public class Bookmark implements Serializable {
private static final long serialVersionUID = -3626414315455912960L;
private static final ObjectMapper MAPPER = new ObjectMapper();

private final UUID fUUID;
private final String fName;
private final String fExperimentId;
private final long fStart;
private final long fEnd;
private final JsonNode fPayload;

/**
* {@link JsonCreator} Constructor for final fields
*
* @param uuid
* the stub's UUID
* @param name
* bookmark name
* @param experimentId
* experiment id
* @param start
* start time
* @param end
* end time
* @param payload
* additional JSON data associated with the bookmark (optional)
*/
@JsonCreator
public Bookmark(
@JsonProperty("UUID") UUID uuid,
@JsonProperty("name") String name,
@JsonProperty("experimentId") String experimentId,
@JsonProperty("start") long start,
@JsonProperty("end") long end,
@JsonProperty(value = "payload", required = false) JsonNode payload) {
fUUID = uuid;
fName = name;
fExperimentId = experimentId;
fStart = start;
fEnd = end;
fPayload = (payload != null) ? payload : MAPPER.createObjectNode();
}

/**
* Constructor without payload
*
* @param uuid
* the stub's UUID
* @param name
* bookmark name
* @param experimentId
* experiment id
* @param start
* start time
* @param end
* end time
*/
public Bookmark(UUID uuid, String name, String experimentId, long start, long end) {
this(uuid, name, experimentId, start, end, MAPPER.createObjectNode());
}

/**
* Get the UUID
*
* @return the UUID
*/
public UUID getUUID() {
return fUUID;
}

/**
* Get the bookmark name
*
* @return the bookmark name
*/
public String getName() {
return fName;
}

/**
* Get the experiment id
*
* @return the experiment id
*/
public String getExperimentId() {
return fExperimentId;
}

/**
* Get the start time
*
* @return the start time
*/
public long getStart() {
return fStart;
}

/**
* Get the end time
*
* @return the end time
*/
public long getEnd() {
return fEnd;
}

/**
* Get the payload
*
* @return the JSON payload, empty JSON object if no payload was set
*/
public JsonNode getPayload() {
return fPayload;
}

@Override
public String toString() {
return "Bookmark [fUUID=" + fUUID + ", fName=" + fName + ", fExperimentId=" + fExperimentId //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
+ ", fStart=" + fStart + ", fEnd=" + fEnd + ", fPayload=" + fPayload + "]"; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$
}
}
Loading

0 comments on commit a4e77bf

Please sign in to comment.