Skip to content

anasfik/openai

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

πŸš€ Dart OpenAI

GitHub commit activity GitHub contributors GitHub Repo stars GitHub Workflow Status GitHub Workflow Status GitHub Pub Version Pub Likes Pub Points Pub Popularity

A comprehensive Dart/Flutter client for OpenAI's powerful AI models

Quick Start β€’ Documentation β€’ Examples β€’ API Coverage β€’ Contributing


✨ Overview

Dart OpenAI is an unofficial but comprehensive client package that allows developers to easily integrate OpenAI's state-of-the-art AI models into their Dart/Flutter applications. The package provides simple, intuitive methods for making requests to OpenAI's various APIs, including GPT models, DALL-E image generation, Whisper audio processing, and more.

⚠️ Note: This is an unofficial package. OpenAI does not have an official Dart library.

🎯 Key Features

  • πŸš€ Easy Integration - Simple, intuitive API that mirrors OpenAI's documentation
  • πŸ” Secure Authentication - One-time setup, use anywhere in your application
  • πŸ“‘ Streaming Support - Real-time streaming for completions, chat, and fine-tune events
  • πŸ› οΈ Developer Friendly - Comprehensive error handling and logging
  • πŸ“š Rich Examples - Ready-to-use examples for every implemented feature
  • 🎨 Modern UI Support - Optimized for Flutter applications
  • πŸ”„ Custom APIs - Additional custom endpoints for enhanced functionality

πŸš€ Quick Start

Installation

Add the package to your pubspec.yaml:

dependencies:
  dart_openai: ^6.0.0

Basic Setup

import 'package:dart_openai/dart_openai.dart';

void main() {
  // Set your API key
  OpenAI.apiKey = "your-api-key-here";
  
  // Optional: Set organization ID
  OpenAI.organization = "your-org-id";
  
  // Optional: Configure timeout
  OpenAI.requestsTimeOut = Duration(seconds: 60);
  
  // Optional: Enable logging
  OpenAI.showLogs = true;
  
  runApp(MyApp());
}

Your First API Call

// Simple chat completion
final chatCompletion = await OpenAI.instance.chat.create(
  model: "gpt-3.5-turbo",
  messages: [
    OpenAIChatCompletionChoiceMessageModel(
      role: OpenAIChatMessageRole.user,
      content: "Hello, how are you?",
    ),
  ],
);

print(chatCompletion.choices.first.message.content);

πŸ“Š API Coverage

βœ… Fully Implemented (100%)

API Category Status Features
πŸ€– Models βœ… Complete List, Retrieve, Delete fine-tuned models
πŸ’¬ Chat Completions βœ… Complete Create, Stream, Tools/Functions, Vision, JSON Mode
πŸ“ Completions βœ… Complete Create, Stream, Log probabilities
🎨 Images βœ… Complete Generate, Edit, Variations
🎡 Audio βœ… Complete Speech, Transcription, Translation
πŸ“ Files βœ… Complete Upload, List, Retrieve, Delete, Content
πŸ”§ Fine-tunes (Legacy) βœ… Complete Create, List, Retrieve, Cancel, Events, Stream
πŸ›‘οΈ Moderation βœ… Complete Content policy classification
✏️ Edits βœ… Complete Text editing (deprecated by OpenAI)

πŸ”§ Additional APIs (100% Implemented)

API Category Status Description
πŸ“‹ Responses βœ… Complete OpenAI Responses API with input-items support
πŸ’­ Conversations βœ… Complete Custom conversation handling system
πŸ“Š Graders βœ… Complete Custom grading system
πŸ“€ Uploads βœ… Complete Custom upload management system

⚠️ Stub Implementations (Need Real Implementation)

API Category Status Priority
πŸ“Š Evals ⚠️ Stub High - All methods throw UnimplementedError
πŸ“¦ Batch ⚠️ Stub High - All methods throw UnimplementedError
πŸ—ƒοΈ Vector Stores ⚠️ Stub High - All methods throw UnimplementedError

❌ Missing APIs (Not Implemented)

API Category Status Priority
πŸ€– Assistants ❌ Missing Critical - Core AI assistant functionality
🧡 Threads ❌ Missing Critical - Conversation management
πŸ’¬ Messages ❌ Missing Critical - Message handling within threads
πŸƒ Runs ❌ Missing Critical - Assistant execution
πŸ”§ Fine-tuning (New) ❌ Missing High - New fine-tuning API
πŸ› οΈ Tools ❌ Missing Medium - Tool management
πŸ“‹ Run Steps ❌ Missing Medium - Run step tracking
πŸ“Ž Message Files ❌ Missing Medium - File attachments in messages

πŸ“š Documentation

Core APIs

πŸ€– Models

// List all available models
List<OpenAIModelModel> models = await OpenAI.instance.model.list();

// Retrieve specific model
OpenAIModelModel model = await OpenAI.instance.model.retrieve("gpt-3.5-turbo");

// Delete fine-tuned model
bool deleted = await OpenAI.instance.model.delete("fine-tuned-model-id");

πŸ’¬ Chat Completions

// Basic chat completion
OpenAIChatCompletionModel chat = await OpenAI.instance.chat.create(
  model: "gpt-3.5-turbo",
  messages: [
    OpenAIChatCompletionChoiceMessageModel(
      role: OpenAIChatMessageRole.user,
      content: "Hello, how can you help me?",
    ),
  ],
  temperature: 0.7,
  maxTokens: 150,
);

// Streaming chat completion
Stream<OpenAIStreamChatCompletionModel> chatStream = OpenAI.instance.chat.createStream(
  model: "gpt-3.5-turbo",
  messages: [
    OpenAIChatCompletionChoiceMessageModel(
      role: OpenAIChatMessageRole.user,
      content: "Tell me a story",
    ),
  ],
);

chatStream.listen((event) {
  print(event.choices.first.delta.content);
});

🎨 Images

// Generate image
OpenAIImageModel image = await OpenAI.instance.image.create(
  prompt: "A beautiful sunset over mountains",
  n: 1,
  size: OpenAIImageSize.size1024,
  responseFormat: OpenAIImageResponseFormat.url,
);

// Edit image
OpenAIImageModel editedImage = await OpenAI.instance.image.edit(
  prompt: "Add a rainbow to the sky",
  image: File("path/to/image.png"),
  mask: File("path/to/mask.png"),
  n: 1,
  size: OpenAIImageSize.size1024,
);

// Create variation
OpenAIImageModel variation = await OpenAI.instance.image.variation(
  image: File("path/to/image.png"),
  n: 3,
  size: OpenAIImageSize.size512,
);

🎡 Audio

// Create speech
File speechFile = await OpenAI.instance.audio.createSpeech(
  model: "tts-1",
  input: "Hello, this is a test",
  voice: "nova",
  responseFormat: OpenAIAudioSpeechResponseFormat.mp3,
  outputDirectory: Directory("output"),
  outputFileName: "speech",
);

// Transcribe audio
OpenAIAudioModel transcription = await OpenAI.instance.audio.createTranscription(
  file: File("path/to/audio.mp3"),
  model: "whisper-1",
  responseFormat: OpenAIAudioResponseFormat.json,
);

// Translate audio
OpenAIAudioModel translation = await OpenAI.instance.audio.createTranslation(
  file: File("path/to/audio.mp3"),
  model: "whisper-1",
  responseFormat: OpenAIAudioResponseFormat.text,
);

Additional APIs

πŸ“‹ Responses API (Official OpenAI)

// Create response
OpenAIResponseModel response = await OpenAI.instance.responses.create(
  // ... response parameters
);

// List responses
List<OpenAIResponseModel> responses = await OpenAI.instance.responses.list();

// Retrieve response
OpenAIResponseModel response = await OpenAI.instance.responses.retrieve("response-id");

// Update response
OpenAIResponseModel updatedResponse = await OpenAI.instance.responses.update(
  "response-id",
  // ... update parameters
);

// Delete response
bool deleted = await OpenAI.instance.responses.delete("response-id");

πŸ’­ Conversations API (Custom)

// Create conversation
OpenAIConversationModel conversation = await OpenAI.instance.conversations.create(
  // ... conversation parameters
);

// List conversations
List<OpenAIConversationModel> conversations = await OpenAI.instance.conversations.list();

// Retrieve conversation
OpenAIConversationModel conversation = await OpenAI.instance.conversations.retrieve("conversation-id");

πŸ“Š Graders API (Custom)

// Create grader
OpenAIGraderModel grader = await OpenAI.instance.graders.create(
  // ... grader parameters
);

// List graders
List<OpenAIGraderModel> graders = await OpenAI.instance.graders.list();

πŸ“€ Uploads API (Custom)

// Create upload
OpenAIUploadModel upload = await OpenAI.instance.uploads.create(
  // ... upload parameters
);

// List uploads
List<OpenAIUploadModel> uploads = await OpenAI.instance.uploads.list();

πŸ› οΈ Advanced Features

Tools/Functions Calling

// Define a tool
final weatherTool = OpenAIToolModel(
  type: "function",
  function: OpenAIFunctionModel.withParameters(
    name: "get_weather",
    parameters: [
      OpenAIFunctionProperty.string(
        name: "location",
        description: "The city to get weather for",
      ),
    ],
  ),
);

// Use tool in chat
final chat = await OpenAI.instance.chat.create(
  model: "gpt-3.5-turbo",
  messages: [
    OpenAIChatCompletionChoiceMessageModel(
      role: OpenAIChatMessageRole.user,
      content: "What's the weather like in New York?",
    ),
  ],
  tools: [weatherTool],
);

Vision Support

final chat = await OpenAI.instance.chat.create(
  model: "gpt-4-vision-preview",
  messages: [
    OpenAIChatCompletionChoiceMessageModel(
      role: OpenAIChatMessageRole.user,
      content: [
        OpenAIChatCompletionChoiceMessageContentItemModel.text("What's in this image?"),
        OpenAIChatCompletionChoiceMessageContentItemModel.imageUrl("https://example.com/image.jpg"),
      ],
    ),
  ],
);

JSON Mode

final chat = await OpenAI.instance.chat.create(
  model: "gpt-3.5-turbo",
  messages: [
    OpenAIChatCompletionChoiceMessageModel(
      role: OpenAIChatMessageRole.user,
      content: "Return user data as JSON",
    ),
  ],
  responseFormat: {"type": "json_object"},
);

πŸ”§ Configuration

Environment Variables

// Using envied package
@Envied(path: ".env")
abstract class Env {
  @EnviedField(varName: 'OPEN_AI_API_KEY')
  static const apiKey = _Env.apiKey;
}

void main() {
  OpenAI.apiKey = Env.apiKey;
  runApp(MyApp());
}

Custom Configuration

void main() {
  // Set API key
  OpenAI.apiKey = "your-api-key";
  
  // Set organization (optional)
  OpenAI.organization = "your-org-id";
  
  // Set custom base URL (optional)
  OpenAI.baseUrl = "https://api.openai.com/v1";
  
  // Set request timeout (optional)
  OpenAI.requestsTimeOut = Duration(seconds: 60);
  
  // Enable logging (optional)
  OpenAI.showLogs = true;
  OpenAI.showResponsesLogs = true;
  
  runApp(MyApp());
}

🚨 Error Handling

try {
  final chat = await OpenAI.instance.chat.create(
    model: "gpt-3.5-turbo",
    messages: [
      OpenAIChatCompletionChoiceMessageModel(
        role: OpenAIChatMessageRole.user,
        content: "Hello",
      ),
    ],
  );
} on RequestFailedException catch (e) {
  print("Request failed: ${e.message}");
  print("Status code: ${e.statusCode}");
} on MissingApiKeyException catch (e) {
  print("API key not set: ${e.message}");
} on UnexpectedException catch (e) {
  print("Unexpected error: ${e.message}");
}

πŸ“ˆ Implementation Status

Overall Progress: 67% Complete

  • βœ… Core APIs: 100% Complete
  • βœ… Legacy APIs: 100% Complete
  • ⚠️ Newer APIs: 20% Complete (stub implementations)
  • ❌ Latest APIs: 0% Complete (missing)
  • πŸ”§ Custom APIs: 100% Complete

Priority Implementation Roadmap

  1. πŸ”₯ Critical: Implement Assistants, Threads, Messages, Runs APIs
  2. 🚨 High: Complete Batch, Vector Stores, Evals implementations
  3. ⚠️ Medium: Add new Fine-tuning API, Tools management
  4. πŸ“ Low: Add Run Steps, Message Files, Fine-tuning Checkpoints

🀝 Contributing

We welcome contributions! Here's how you can help:

πŸ› Bug Reports

  • Use GitHub Issues to report bugs
  • Include reproduction steps and environment details

πŸ’‘ Feature Requests

  • Suggest new features via GitHub Issues
  • Check existing issues before creating new ones

πŸ”§ Code Contributions

  • Fork the repository
  • Create a feature branch
  • Make your changes
  • Add tests if applicable
  • Submit a pull request

πŸ“š Documentation

  • Help improve documentation
  • Add examples for missing features
  • Fix typos and improve clarity

πŸ’° Sponsoring


πŸ“œ License

This project is licensed under the MIT License - see the LICENSE file for details.


πŸ™ Acknowledgments

  • OpenAI for providing the amazing AI models and APIs
  • Contributors who help maintain and improve this package
  • Sponsors who support the project financially
  • Community for feedback and suggestions

πŸ“ž Support


Made with ❀️ by the Dart OpenAI community

⭐ Star this repo β€’ πŸ› Report Bug β€’ πŸ’‘ Request Feature β€’ πŸ“– Documentation