langchain_google 0.2.3+3  langchain_google: ^0.2.3+3 copied to clipboard
langchain_google: ^0.2.3+3 copied to clipboard
LangChain.dart integration module for Google (VertexAI, PaLM, Matching Engine, etc.).
example/langchain_google_example.dart
// ignore_for_file: avoid_print, unused_element
import 'dart:convert';
import 'dart:io';
import 'package:googleapis_auth/auth_io.dart';
import 'package:langchain/langchain.dart';
import 'package:langchain_google/langchain_google.dart';
void main() async {
  // Uncomment the example you want to run:
  await _example1();
  // await _example2();
}
/// The most basic building block of LangChain is calling an LLM on some input.
Future<void> _example1() async {
  final openai = VertexAI(
    httpClient: await _getAuthHttpClient(),
    project: _getProjectId(),
    defaultOptions: const VertexAIOptions(
      temperature: 0.9,
    ),
  );
  final result = await openai('Tell me a joke');
  print(result);
}
/// The most frequent use case is to create a chat-bot.
/// This is the most basic one.
Future<void> _example2() async {
  final chat = ChatVertexAI(
    httpClient: await _getAuthHttpClient(),
    project: _getProjectId(),
    defaultOptions: const ChatVertexAIOptions(
      temperature: 0,
    ),
  );
  while (true) {
    stdout.write('> ');
    final usrMsg = ChatMessage.humanText(stdin.readLineSync() ?? '');
    final aiMsg = await chat([usrMsg]);
    print(aiMsg.content);
  }
}
Future<AuthClient> _getAuthHttpClient() async {
  final serviceAccountCredentials = ServiceAccountCredentials.fromJson(
    json.decode(Platform.environment['VERTEX_AI_SERVICE_ACCOUNT']!),
  );
  return clientViaServiceAccount(
    serviceAccountCredentials,
    [VertexAI.cloudPlatformScope],
  );
}
String _getProjectId() {
  return Platform.environment['VERTEX_AI_PROJECT_ID']!;
}