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

commonMain.tool.computer.Computer.kt Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2024 Kazimierz Pogoda / Xemantic
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.xemantic.ai.anthropic.tool.computer

import com.xemantic.ai.anthropic.cache.CacheControl
import com.xemantic.ai.anthropic.content.Image
import com.xemantic.ai.anthropic.tool.BuiltInTool
import com.xemantic.ai.anthropic.tool.ToolInput
import kotlinx.serialization.ExperimentalSerializationApi
import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable
import kotlinx.serialization.Transient

@Serializable
@SerialName("computer")
@OptIn(ExperimentalSerializationApi::class)
data class Computer(
  override val cacheControl: CacheControl? = null,
  @SerialName("display_width_px")
  val displayWidthPx: Int,
  @SerialName("display_height_px")
  val displayHeightPx: Int,
  @SerialName("display_number")
  val displayNumber: Int? = null
) : BuiltInTool(
  name = "computer",
  type = "computer_20241022"
) {

  init {
    inputSerializer = Input.serializer()
  }

  @Serializable
  data class Input(
    val action: Action,
    val coordinate: Coordinate?,
    val text: String
  ) : ToolInput() {

    @Transient
    lateinit var service: ComputerService

    init {
      use {
        when (action) {
          Action.SCREENSHOT -> +service.screenshot()
          else -> TODO("Not implemented yet")
        }
      }
    }

  }

}

enum class Action {
  @SerialName("key")
  KEY,
  @SerialName("type")
  TYPE,
  @SerialName("mouse_move")
  MOUSE_MOVE,
  @SerialName("left_click")
  LEFT_CLICK,
  @SerialName("left_click_drag")
  LEFT_CLICK_DRAG,
  @SerialName("right_click")
  RIGHT_CLICK,
  @SerialName("middle_click")
  MIDDLE_CLICK,
  @SerialName("double_click")
  DOUBLE_CLICK,
  @SerialName("screenshot")
  SCREENSHOT,
  @SerialName("cursor_position")
  CURSOR_POSITION,
}

@Serializable
data class Resolution(val width: Int, val height: Int)

@Serializable
data class Coordinate(val x: Int, val y: Int)

interface ComputerService {

  fun screenshot(): Image

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy