
com.blazebit.query.connector.kandji.model.GetDeviceDetails200ResponseKandjiAgentLastCheckIn Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of blaze-query-connector-kandji-jersey3 Show documentation
Show all versions of blaze-query-connector-kandji-jersey3 Show documentation
A multi-platform querying library
The newest version!
/*
* Kandji API
* # Welcome to the Kandji API Documentation You can find your API URL in Settings > Access. The API URL will follow the below formats. - US - `https://SubDomain.api.kandji.io` - EU - `https://SubDomain.api.eu.kandji.io` For information on how to obtain an API token, please refer to the following support article. [https://support.kandji.io/api](https://support.kandji.io/api) #### Rate Limit The Kandji API currently has an API rate limit of 10,000 requests per hour per customer. #### Request Methods HTTP request methods supported by the Kandji API. | Method | Definition | | --- | --- | | GET | The `GET` method requests a representation of the specified resource. | | POST | The `POST` method submits an entity to the specified resource. | | PATCH | The `PATCH` method applies partial modifications to a resource. | | DELETE | The `DELETE` method deletes the specified resource. | #### Response codes Not all response codes apply to every endpoint. | Code | Response | | --- | --- | | 200 | OK | | 201 | Created | | 204 | No content | | | Typical response when sending the DELETE method. | | 400 | Bad Request | | | \"Command already running\" - The command may already be running in a _Pending_ state waiting on the device. | | | \"Command is not allowed for current device\" - The command may not be compatible with the target device. | | | \"JSON parse error - Expecting ',' delimiter: line 3 column 2 (char 65)\" | | 401 | Unauthorized | | | This error can occur if the token is incorrect, was revoked, or the token has expired. | | 403 | Forbidden | | | The request was understood but cannot be authorized. | | 404 | Not found | | | Unable to locate the resource in the Kandji tenant. | | 415 | Unsupported Media Type | | | The request contains a media type which the server or resource does not support. | | 500 | Internal server error | | 503 | Service unavailable | | | This error can occur if a file upload is still being processed via the custom apps API. | #### Data structure The API returns all structured responses in JSON schema format. #### Examples Code examples using the API can be found in the Kandji support [GitHub](https://github.com/kandji-inc/support/tree/main/api-tools).
*
* The version of the OpenAPI document: 1.0.0
*
*
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
package com.blazebit.query.connector.kandji.model;
import java.util.Objects;
import java.util.Map;
import java.util.HashMap;
import com.fasterxml.jackson.annotation.JsonTypeName;
import java.time.OffsetDateTime;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import com.blazebit.query.connector.kandji.invoker.JSON;
import jakarta.ws.rs.core.GenericType;
import jakarta.ws.rs.core.Response;
import java.io.IOException;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.DeserializationContext;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.SerializerProvider;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
import com.blazebit.query.connector.kandji.invoker.JSON;
@jakarta.annotation.Generated(value = "org.openapitools.codegen.languages.JavaClientCodegen", date = "2025-04-30T07:19:31.168100307Z[Etc/UTC]", comments = "Generator version: 7.10.0")
@JsonDeserialize(using=GetDeviceDetails200ResponseKandjiAgentLastCheckIn.GetDeviceDetails200ResponseKandjiAgentLastCheckInDeserializer.class)
@JsonSerialize(using = GetDeviceDetails200ResponseKandjiAgentLastCheckIn.GetDeviceDetails200ResponseKandjiAgentLastCheckInSerializer.class)
public class GetDeviceDetails200ResponseKandjiAgentLastCheckIn extends AbstractOpenApiSchema {
private static final Logger log = Logger.getLogger(GetDeviceDetails200ResponseKandjiAgentLastCheckIn.class.getName());
public static class GetDeviceDetails200ResponseKandjiAgentLastCheckInSerializer extends StdSerializer {
public GetDeviceDetails200ResponseKandjiAgentLastCheckInSerializer(Class t) {
super(t);
}
public GetDeviceDetails200ResponseKandjiAgentLastCheckInSerializer() {
this(null);
}
@Override
public void serialize(GetDeviceDetails200ResponseKandjiAgentLastCheckIn value, JsonGenerator jgen, SerializerProvider provider) throws IOException, JsonProcessingException {
jgen.writeObject(value.getActualInstance());
}
}
public static class GetDeviceDetails200ResponseKandjiAgentLastCheckInDeserializer extends StdDeserializer {
public GetDeviceDetails200ResponseKandjiAgentLastCheckInDeserializer() {
this(GetDeviceDetails200ResponseKandjiAgentLastCheckIn.class);
}
public GetDeviceDetails200ResponseKandjiAgentLastCheckInDeserializer(Class> vc) {
super(vc);
}
@Override
public GetDeviceDetails200ResponseKandjiAgentLastCheckIn deserialize(JsonParser jp, DeserializationContext ctxt) throws IOException, JsonProcessingException {
JsonNode tree = jp.readValueAsTree();
Object deserialized = null;
// deserialize String
try {
deserialized = tree.traverse(jp.getCodec()).readValueAs(String.class);
GetDeviceDetails200ResponseKandjiAgentLastCheckIn ret = new GetDeviceDetails200ResponseKandjiAgentLastCheckIn();
ret.setActualInstance(deserialized);
return ret;
} catch (Exception e) {
// deserialization failed, continue, log to help debugging
log.log(Level.FINER, "Input data does not match 'GetDeviceDetails200ResponseKandjiAgentLastCheckIn'", e);
}
// deserialize OffsetDateTime
try {
deserialized = tree.traverse(jp.getCodec()).readValueAs(OffsetDateTime.class);
GetDeviceDetails200ResponseKandjiAgentLastCheckIn ret = new GetDeviceDetails200ResponseKandjiAgentLastCheckIn();
ret.setActualInstance(deserialized);
return ret;
} catch (Exception e) {
// deserialization failed, continue, log to help debugging
log.log(Level.FINER, "Input data does not match 'GetDeviceDetails200ResponseKandjiAgentLastCheckIn'", e);
}
throw new IOException(String.format("Failed deserialization for GetDeviceDetails200ResponseKandjiAgentLastCheckIn: no match found"));
}
/**
* Handle deserialization of the 'null' value.
*/
@Override
public GetDeviceDetails200ResponseKandjiAgentLastCheckIn getNullValue(DeserializationContext ctxt) throws JsonMappingException {
throw new JsonMappingException(ctxt.getParser(), "GetDeviceDetails200ResponseKandjiAgentLastCheckIn cannot be null");
}
}
// store a list of schema names defined in anyOf
public static final Map> schemas = new HashMap<>();
public GetDeviceDetails200ResponseKandjiAgentLastCheckIn() {
super("anyOf", Boolean.FALSE);
}
public GetDeviceDetails200ResponseKandjiAgentLastCheckIn(String o) {
super("anyOf", Boolean.FALSE);
setActualInstance(o);
}
public GetDeviceDetails200ResponseKandjiAgentLastCheckIn(OffsetDateTime o) {
super("anyOf", Boolean.FALSE);
setActualInstance(o);
}
static {
schemas.put("OffsetDateTime", new GenericType() {
});
schemas.put("String", new GenericType() {
});
JSON.registerDescendants(GetDeviceDetails200ResponseKandjiAgentLastCheckIn.class, Collections.unmodifiableMap(schemas));
}
@Override
public Map> getSchemas() {
return GetDeviceDetails200ResponseKandjiAgentLastCheckIn.schemas;
}
/**
* Set the instance that matches the anyOf child schema, check
* the instance parameter is valid against the anyOf child schemas:
* OffsetDateTime, String
*
* It could be an instance of the 'anyOf' schemas.
* The anyOf child schemas may themselves be a composed schema (allOf, anyOf, anyOf).
*/
@Override
public void setActualInstance(Object instance) {
if (JSON.isInstanceOf(String.class, instance, new HashSet<>())) {
super.setActualInstance(instance);
return;
}
if (JSON.isInstanceOf(OffsetDateTime.class, instance, new HashSet<>())) {
super.setActualInstance(instance);
return;
}
throw new RuntimeException("Invalid instance type. Must be OffsetDateTime, String");
}
/**
* Get the actual instance, which can be the following:
* OffsetDateTime, String
*
* @return The actual instance (OffsetDateTime, String)
*/
@Override
public Object getActualInstance() {
return super.getActualInstance();
}
/**
* Get the actual instance of `String`. If the actual instance is not `String`,
* the ClassCastException will be thrown.
*
* @return The actual instance of `String`
* @throws ClassCastException if the instance is not `String`
*/
public String getString() throws ClassCastException {
return (String)super.getActualInstance();
}
/**
* Get the actual instance of `OffsetDateTime`. If the actual instance is not `OffsetDateTime`,
* the ClassCastException will be thrown.
*
* @return The actual instance of `OffsetDateTime`
* @throws ClassCastException if the instance is not `OffsetDateTime`
*/
public OffsetDateTime getOffsetDateTime() throws ClassCastException {
return (OffsetDateTime)super.getActualInstance();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy