KevinStephenson
Adding in weaviate code
b110593
raw
history blame
2.92 kB
// _ _
// __ _____ __ ___ ___ __ _| |_ ___
// \ \ /\ / / _ \/ _` \ \ / / |/ _` | __/ _ \
// \ V V / __/ (_| |\ V /| | (_| | || __/
// \_/\_/ \___|\__,_| \_/ |_|\__,_|\__\___|
//
// Copyright © 2016 - 2024 Weaviate B.V. All rights reserved.
//
// CONTACT: [email protected]
//
package modrerankertransformers
import (
"context"
"net/http"
"os"
"time"
"github.com/pkg/errors"
"github.com/sirupsen/logrus"
"github.com/weaviate/weaviate/entities/modulecapabilities"
"github.com/weaviate/weaviate/entities/moduletools"
client "github.com/weaviate/weaviate/modules/reranker-transformers/clients"
additionalprovider "github.com/weaviate/weaviate/usecases/modulecomponents/additional"
"github.com/weaviate/weaviate/usecases/modulecomponents/ent"
)
const Name = "reranker-transformers"
func New() *ReRankerModule {
return &ReRankerModule{}
}
type ReRankerModule struct {
reranker ReRankerClient
additionalPropertiesProvider modulecapabilities.AdditionalProperties
}
type ReRankerClient interface {
Rank(ctx context.Context, query string, documents []string, cfg moduletools.ClassConfig) (*ent.RankResult, error)
MetaInfo() (map[string]interface{}, error)
}
func (m *ReRankerModule) Name() string {
return Name
}
func (m *ReRankerModule) Type() modulecapabilities.ModuleType {
return modulecapabilities.Text2TextReranker
}
func (m *ReRankerModule) Init(ctx context.Context,
params moduletools.ModuleInitParams,
) error {
if err := m.initAdditional(ctx, params.GetConfig().ModuleHttpClientTimeout, params.GetLogger()); err != nil {
return errors.Wrap(err, "init re encoder")
}
return nil
}
func (m *ReRankerModule) initAdditional(ctx context.Context, timeout time.Duration,
logger logrus.FieldLogger,
) error {
uri := os.Getenv("RERANKER_INFERENCE_API")
if uri == "" {
return errors.Errorf("required variable RERANKER_INFERENCE_API is not set")
}
client := client.New(uri, timeout, logger)
m.reranker = client
if err := client.WaitForStartup(ctx, 1*time.Second); err != nil {
return errors.Wrap(err, "init remote sum module")
}
m.additionalPropertiesProvider = additionalprovider.NewRankerProvider(client)
return nil
}
func (m *ReRankerModule) MetaInfo() (map[string]interface{}, error) {
return m.reranker.MetaInfo()
}
func (m *ReRankerModule) RootHandler() http.Handler {
// TODO: remove once this is a capability interface
return nil
}
func (m *ReRankerModule) AdditionalProperties() map[string]modulecapabilities.AdditionalProperty {
return m.additionalPropertiesProvider.AdditionalProperties()
}
// verify we implement the modules.Module interface
var (
_ = modulecapabilities.Module(New())
_ = modulecapabilities.AdditionalProperties(New())
_ = modulecapabilities.MetaProvider(New())
)