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

kalix.scalasdk.action.ActionContext.scala Maven / Gradle / Ivy

/*
 * Copyright 2024 Lightbend Inc.
 *
 * 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 kalix.scalasdk.action

import kalix.scalasdk.Metadata
import kalix.scalasdk.MetadataContext

trait ActionContext extends MetadataContext {

  /**
   * Get the metadata associated with this call.
   *
   * 

Note, this only returns call level associated metadata. For unary calls, this will be the same as the message * metadata, but for streamed calls, it will contain metadata associated with the whole stream, so for example if this * was a gRPC call, it will contain the HTTP headers for that gRPC call. * * @return * The call level metadata. */ def metadata: Metadata /** * The origin subject of the {{{CloudEvent}}}. For example, the entity id when the event was emitted from an entity. */ def eventSubject: Option[String] /** * Get an Akka gRPC client for the given service name. The same client instance is shared across components in the * application. The lifecycle of the client is managed by the SDK and it should not be stopped by user code. * * @tparam T * The "service" interface generated for the service by Akka gRPC * @param clientClass * The class of a gRPC service generated by Akka gRPC * @param service * The name of the service to connect to, either a name of another Kalix service or an external service where * connection details are configured under `akka.grpc.client.[service-name]` in `application.conf`. */ def getGrpcClient[T](clientClass: Class[T], service: String): T }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy