88 lines
3.8 KiB
Org Mode
88 lines
3.8 KiB
Org Mode
:PROPERTIES:
|
|
:ID: 52799ee8-693f-49da-97bc-2c02bc6a7ef7
|
|
:CREATED: [2026-03-30 Mon 21:16]
|
|
:EDITED: [2026-04-07 Tue 13:42]
|
|
:END:
|
|
#+TITLE: SKILL: Gemini Provider Agent (Universal Literate Note)
|
|
#+STARTUP: content
|
|
#+FILETAGS: :llm:provider:gemini:google:psf:
|
|
|
|
* Overview
|
|
The *Gemini Provider Agent* provides a dual-path interface to Google's neural models. It supports both the low-latency Developer API and the high-fidelity Web/Pro interface.
|
|
|
|
* Phase A: Demand (PRD)
|
|
:PROPERTIES:
|
|
:STATUS: SIGNED
|
|
:END:
|
|
|
|
** 1. Purpose
|
|
Enable a hybrid cost/performance strategy for Google's models.
|
|
|
|
** 2. User Needs
|
|
- *API Path:* Reliable, programmatic access for system reflexes.
|
|
- *Web Path:* Zero-cost access to Pro-tier reasoning via browser session bridging.
|
|
|
|
* Phase B: Blueprint (PROTOCOL)
|
|
:PROPERTIES:
|
|
:STATUS: SIGNED
|
|
:END:
|
|
|
|
** 1. Architectural Intent
|
|
Expose two distinct backends to the kernel: =:gemini-api= and =:gemini-web=.
|
|
|
|
** 2. Semantic Interfaces
|
|
|
|
*** `execute-gemini-api-request`
|
|
:signature `(execute-gemini-api-request prompt system-prompt &key model) :string`
|
|
:description "Direct call to the Google AI Studio API."
|
|
|
|
*** `execute-gemini-web-request`
|
|
:signature `(execute-gemini-web-request prompt system-prompt) :string`
|
|
:description "Routes the request through the Web Research browser proxy."
|
|
|
|
* Phase D: Build (Implementation)
|
|
|
|
** API Implementation
|
|
#+begin_src lisp :tangle ../projects/org-skill-provider-gemini/src/provider-logic.lisp
|
|
(in-package :org-agent)
|
|
|
|
(defun execute-gemini-request (prompt system-prompt &key model)
|
|
(let* ((auth (get-provider-auth :gemini)) (api-key (getf auth :api-key)) (bearer-token (getf auth :bearer-token))
|
|
(endpoint-base (if model (format nil "https://generativelanguage.googleapis.com/v1/models/~a:generateContent" model)
|
|
"https://generativelanguage.googleapis.com/v1/models/gemini-1.5-flash-latest:generateContent")))
|
|
(unless (or api-key bearer-token) (return-from execute-gemini-request "(:type :LOG :payload (:text \"Authentication missing\"))"))
|
|
(let* ((url (if api-key (format nil "~a?key=~a" endpoint-base api-key) endpoint-base))
|
|
(headers `(("Content-Type" . "application/json") ,@(when bearer-token `(("Authorization" . ,(format nil "Bearer ~a" bearer-token))))))
|
|
(body (cl-json:encode-json-to-string `((contents . ((parts . ((text . ,(format nil "~a~%~%Prompt: ~a" system-prompt prompt))))))))))
|
|
(handler-case (let* ((response (dex:post url :headers headers :content body :connect-timeout 10 :read-timeout 30)) (json (cl-json:decode-json-from-string response)))
|
|
(cdr (assoc :text (cdr (assoc :parts (car (cdr (assoc :parts (car (cdr (assoc :candidates json)))))))))))
|
|
(error (c) (format nil "(:type :LOG :payload (:text \"Neural Engine Failure: ~a\"))" c))))))
|
|
|
|
(defun execute-gemini-api-request (prompt system-prompt &key model)
|
|
"Implementation uses the standard kernel execute-gemini-request logic."
|
|
(execute-gemini-request prompt system-prompt :model model))
|
|
#+end_src
|
|
|
|
** Web Implementation
|
|
#+begin_src lisp :tangle ../projects/org-skill-provider-gemini/src/provider-logic.lisp
|
|
(defun execute-gemini-web-request (prompt system-prompt &key model)
|
|
(declare (ignore model))
|
|
"Dispatches to the browser-based Web Research skill."
|
|
(let ((full-prompt (format nil "~a~%~%Prompt: ~a" system-prompt prompt)))
|
|
(uiop:symbol-call :org-agent.skills.org-skill-web-research :ask-gemini-web full-prompt)))
|
|
#+end_src
|
|
|
|
* Registration
|
|
#+begin_src lisp
|
|
(progn
|
|
(org-agent:register-neuro-backend :gemini #'execute-gemini-request)
|
|
(org-agent:register-neuro-backend :gemini-api #'execute-gemini-api-request)
|
|
(org-agent:register-neuro-backend :gemini-web #'execute-gemini-web-request)
|
|
|
|
(defskill :skill-provider-gemini
|
|
:priority 90
|
|
:trigger (lambda (context) nil)
|
|
:neuro (lambda (context) nil)
|
|
:symbolic (lambda (action context) action)))
|
|
#+end_src
|