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

com.blazebit.query.connector.kandji.model.GetDeviceDetails200ResponseKandjiAgentLastCheckIn Maven / Gradle / Ivy

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