Cloudflare Workers AI API client for ruby
Cloudflare is testing its Workers AI API.
Hopefully this project makes it easier for ruby-first developers to consume
Cloudflare's latest and greatest.
I'm really interested in applying retrieval-augmented
generation to make legal services more accessible. Email me.
If you're looking for legal help, it's best to book a slot via https://www.krishnan.ca.
Supported features
Table of Contents
Installation
Install the gem and add to the application's Gemfile by executing:
bundle add cloudflare-ai
If bundler is not being used to manage dependencies, install the gem by executing:
gem install cloudflare-ai
Usage
require "cloudflare/ai"
Cloudflare Workers AI
Please visit the Cloudflare Workers AI website for more details.
Thiis gem provides a client that wraps around Cloudflare's REST API.
Client
client = Cloudflare::AI::Client.new(account_id: ENV["CLOUDFLARE_ACCOUNT_ID"], api_token: ENV["CLOUDFLARE_API_TOKEN"])
Model selection
The model name is an optional parameter to every one of the client methods described below.
For example, if an example is documented as
result = client.complete(prompt: "Hello my name is")
this is implicitly the same as
result = client.complete(prompt: "Hello my name is", model: "@cf/meta/llama-2-7b-chat-fp16")
The full list of supported models is available here: models.rb.
More information is available in the cloudflare documentation.
The default model used is the first enumerated model in the applicable set in models.rb.
Text generation
(chat / scoped prompt)
messages = [
Cloudflare::AI::Message.new(role: "system", content: "You are a big fan of Cloudflare and Ruby."),
Cloudflare::AI::Message.new(role: "user", content: "What is your favourite tech stack?"),
Cloudflare::AI::Message.new(role: "assistant", content: "I love building with Ruby on Rails and Cloudflare!"),
Cloudflare::AI::Message.new(role: "user", content: "Really? You like Cloudflare even though there isn't great support for Ruby?"),
]
result = client.chat(messages: messages)
puts result.response
(string prompt)
result = client.complete(prompt: "What is your name?", max_tokens: 512)
puts result.response
Streaming responses
Responses will be streamed back to the client using Server Side Events (SSE) if a block is passed to the chat
or complete
method.
result = client.complete(prompt: "Hi!") { |data| puts data}
Token limits
Invocations of the prompt
and chat
can take an optional max_tokens
argument that defaults to 256.
Result object
All invocations of the prompt
and chat
methods return a Cloudflare::AI::Results::TextGeneration
object. This object's serializable JSON output is
based on the raw response from the Cloudflare API.
result = client.complete(prompt: "What is your name?")
puts result.response
puts result.success?
puts result.failure?
puts result.to_json
puts result.response
puts result.success?
puts result.failure?
puts result.to_json
Text embedding
result = client.embed(text: "Hello")
p result.shape
p result.embedding
The input can be either a string (as above) or an array of strings:
result = client.embed(text: ["Hello", "World"])
Result object
All invocations of the embed
methods return a Cloudflare::AI::Results::TextEmbedding
.
Text classification
result = client.classify(text: "You meanie!")
p result.result
Result object
All invocations of the classify
methods return a Cloudflare::AI::Results::TextClassification
.
Image classification
The image classification endpoint accepts either a path to a file or a file stream.
result = client.classify(image: "/path/to/cat.jpg")
p result.result
result = client.classify(image: File.open("/path/to/cat.jpg"))
p result.result
Result object
All invocations of the classify
method returns a Cloudflare::AI::Results::TextClassification
.
Text to Image
result = client.draw(prompt: "robot with blue eyes")
p result.result
Result object
All invocations of the draw
method returns a Cloudflare::AI::Results::TextToImage
.
Translation
result = client.translate(text: "Hello Jello", source_lang: "en", target_lang: "fr")
p result.translated_text
Result object
All invocations of the translate
method returns a Cloudflare::AI::Results::Translate
.
Automatic speech recognition
You can pass either a URL (source_url:) or a file (audio:) to the transcribe
method.
result = client.transcribe(source_url: "http://example.org/path/to/audio.wav")
p result.text
p result.word_count
p result.to_json
result = client.transcribe(audio: File.open("/path/to/audio.wav"))
Result object
All invocations of the transcribe
method returns a Cloudflare::AI::Results::Transcribe
.
Summarization
result = client.summarize(text: "This text should be a lot longer.")
p result.summary
Result object
All invocations of the summarize
method returns a Cloudflare::AI::Results::Summarization
object.
Object detection
The object detection endpoint accepts either a path to a file or a file stream.
result = client.detect_objects(image: "/path/to/cat.jpg")
result = client.classify(image: File.open("/path/to/cat.jpg"))
Result object
All invocations of the detect_objects
method returns a Cloudflare::AI::Results::ObjectDetection
object.
Image-to-text
The captioning endpoint accepts either a path to a file or a file stream.
client.caption(image: "/path/to/cat.jpg").description
client.caption(image: File.open("/path/to/cat.jpg")).description
Result object
All invocations of the caption
method returns a Cloudflare::AI::Results::ImageToText
object.
Logging
This gem uses standard logging mechanisms and defaults to :warn
level. Most messages are at info level, but we will add debug or warn statements as needed.
To show all log messages:
Cloudflare::AI.logger.level = :debug
You can use this logger as you would the default ruby logger. For example:
Cloudflare::AI.logger = Logger.new($stdout)
Development
git clone https://github.com/ajaynomics/cloudflare-ai.git
bundle exec rake
to ensure that the tests pass and to run standardrb
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/ajaynomics/cloudflare-ai.
License
The gem is available as open source under the terms of the MIT License. A special thanks to the team at langchainrb – I learnt a lot reading your codebase as I muddled my way through the initial effort.