Class: Legion::Extensions::Llm::Ollama::Provider

Inherits:
Provider
  • Object
show all
Defined in:
lib/legion/extensions/llm/ollama/provider.rb

Overview

Ollama provider implementation for the Legion::Extensions::Llm base provider contract.

Defined Under Namespace

Modules: Capabilities

Class Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Class Attribute Details

.registry_publisherObject



20
21
22
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 20

def registry_publisher
  @registry_publisher ||= RegistryPublisher.new
end

Class Method Details

.capabilitiesObject



18
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 18

def capabilities = Capabilities

.configuration_optionsObject



16
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 16

def configuration_options = %i[ollama_api_base ollama_keep_alive]

.configuration_requirementsObject



17
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 17

def configuration_requirements = []

.local?Boolean

Returns:

  • (Boolean)


15
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 15

def local? = true

.slugObject



14
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 14

def slug = 'ollama'

Instance Method Details

#api_baseObject



36
37
38
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 36

def api_base
  config.ollama_api_base || 'http://localhost:11434'
end

#completion_urlObject



40
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 40

def completion_url = '/api/chat'

#embedding_urlObject



45
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 45

def embedding_url(**) = '/api/embed'

#list_modelsObject



64
65
66
67
68
69
70
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 64

def list_models
  log.info { "discovering models from #{api_base}#{models_url}" }
  super.tap do |models|
    log.info { "discovered #{models.size} model(s) from Ollama" }
    self.class.registry_publisher.publish_models_async(models, readiness: readiness(live: false))
  end
end

#list_running_modelsObject



49
50
51
52
53
54
55
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 49

def list_running_models
  log.info { "listing running models from #{api_base}#{running_models_url}" }
  connection.get(running_models_url).body.fetch('models', [])
rescue StandardError => e
  handle_exception(e, level: :error, handled: true, operation: 'ollama.list_running_models')
  []
end

#models_urlObject



42
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 42

def models_url = '/api/tags'

#pull_model(model, stream: false) ⇒ Object



80
81
82
83
84
85
86
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 80

def pull_model(model, stream: false)
  log.info { "pulling model #{model} stream=#{stream}" }
  connection.post(pull_url, { model: model, stream: stream }).body
rescue StandardError => e
  handle_exception(e, level: :error, handled: true, operation: 'ollama.pull_model')
  raise
end

#pull_urlObject



46
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 46

def pull_url = '/api/pull'

#readiness(live: false) ⇒ Object



57
58
59
60
61
62
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 57

def readiness(live: false)
  log.info { "checking readiness live=#{live} at #{api_base}" }
  super.tap do ||
    self.class.registry_publisher.publish_readiness_async() if live
  end
end

#running_models_urlObject



43
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 43

def running_models_url = '/api/ps'

#show_model(model) ⇒ Object



72
73
74
75
76
77
78
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 72

def show_model(model)
  log.info { "fetching model details for #{model}" }
  connection.post(show_model_url, { model: model }).body
rescue StandardError => e
  handle_exception(e, level: :error, handled: true, operation: 'ollama.show_model')
  raise
end

#show_model_urlObject



44
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 44

def show_model_url = '/api/show'

#stream_urlObject



41
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 41

def stream_url = '/api/chat'

#version_urlObject



47
# File 'lib/legion/extensions/llm/ollama/provider.rb', line 47

def version_url = '/api/version'