Skip to content

Commit

Permalink
feat: add by similarity
Browse files Browse the repository at this point in the history
  • Loading branch information
luigibarbato committed Mar 9, 2024
1 parent a436059 commit cfe91aa
Show file tree
Hide file tree
Showing 10 changed files with 151 additions and 77 deletions.
16 changes: 3 additions & 13 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ ARG GO_VERSION=1.21

FROM alpine:${ALPINE_VERSION} AS certificator
RUN apk --update add --no-cache ca-certificates openssl git tzdata && \
update-ca-certificates
update-ca-certificates

FROM golang:${GO_VERSION}-alpine AS builder
WORKDIR /app
Expand All @@ -26,22 +26,18 @@ WORKDIR /data
COPY --from=builder /app/main /app/main

ARG UNCONDITIONAL_API_SOURCE_REPO
ARG UNCONDITIONAL_API_SOURCE_CLIENT_KEY
ARG UNCONDITIONAL_API_FEED_REPO_INDEX
ARG UNCONDITIONAL_API_FEED_REPO_HOST
ARG UNCONDITIONAL_API_FEED_REPO_KEY
ARG UNCONDITIONAL_API_LOG_ENV

ENV UNCONDITIONAL_API_SOURCE_REPO=${UNCONDITIONAL_API_SOURCE_REPO}
ENV UNCONDITIONAL_API_SOURCE_CLIENT_KEY=${UNCONDITIONAL_API_SOURCE_CLIENT_KEY}
ENV UNCONDITIONAL_API_FEED_REPO_INDEX=${UNCONDITIONAL_API_FEED_REPO_INDEX}
ENV UNCONDITIONAL_API_FEED_REPO_HOST=${UNCONDITIONAL_API_FEED_REPO_HOST}
ENV UNCONDITIONAL_API_FEED_REPO_KEY=${UNCONDITIONAL_API_FEED_REPO_KEY}
ENV UNCONDITIONAL_API_LOG_ENV=${UNCONDITIONAL_API_LOG_ENV}

RUN --mount=type=secret,id=UNCONDITIONAL_API_SOURCE_CLIENT_KEY \
--mount=type=secret,id=UNCONDITIONAL_API_FEED_REPO_HOST \
--mount=type=secret,id=UNCONDITIONAL_API_FEED_REPO_KEY \
UNCONDITIONAL_API_SOURCE_CLIENT_KEY="$(cat /run/secrets/UNCONDITIONAL_API_SOURCE_CLIENT_KEY)" \
UNCONDITIONAL_API_FEED_REPO_HOST="$(cat /run/secrets/UNCONDITIONAL_API_FEED_REPO_HOST)" \
UNCONDITIONAL_API_FEED_REPO_KEY="$(cat /run/secrets/UNCONDITIONAL_API_FEED_REPO_KEY)" \
/app/main index create --name feeds

Expand All @@ -54,20 +50,14 @@ ARG UNCONDITIONAL_API_ADDRESS
ARG UNCONDITIONAL_API_ALLOWED_ORIGINS
ARG UNCONDITIONAL_API_PORT
ARG UNCONDITIONAL_API_SOURCE_REPO
ARG UNCONDITIONAL_API_SOURCE_CLIENT_KEY
ARG UNCONDITIONAL_API_LOG_ENV
ARG UNCONDITIONAL_API_FEED_REPO_INDEX
ARG UNCONDITIONAL_API_FEED_REPO_HOST
ARG UNCONDITIONAL_API_FEED_REPO_KEY

ENV UNCONDITIONAL_API_ADDRESS=${UNCONDITIONAL_API_ADDRESS}
ENV UNCONDITIONAL_API_ALLOWED_ORIGINS=${UNCONDITIONAL_API_ALLOWED_ORIGINS}
ENV UNCONDITIONAL_API_PORT=${UNCONDITIONAL_API_PORT}
ENV UNCONDITIONAL_API_SOURCE_REPO=${UNCONDITIONAL_API_SOURCE_REPO}
ENV UNCONDITIONAL_API_SOURCE_CLIENT_KEY=${UNCONDITIONAL_API_SOURCE_CLIENT_KEY}
ENV UNCONDITIONAL_API_LOG_ENV=${UNCONDITIONAL_API_LOG_ENV}
ENV UNCONDITIONAL_API_FEED_REPO_INDEX=${UNCONDITIONAL_API_FEED_REPO_INDEX}
ENV UNCONDITIONAL_API_FEED_REPO_HOST=${UNCONDITIONAL_API_FEED_REPO_HOST}
ENV UNCONDITIONAL_API_FEED_REPO_KEY=${UNCONDITIONAL_API_FEED_REPO_KEY}

ENTRYPOINT ["./app/main","serve", "--address", "0.0.0.0", "--port","8080"]
5 changes: 5 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,11 @@ test-integration:
build:
@go build --tags=release -o ${_PROJECT_DIRECTORY}/bin/unconditional-server

.PHONY: deploy

deploy:
@sh ./scripts/deploy.sh

# Helpers
check-variable-%: # detection of undefined variables.
@[[ "${${*}}" ]] || (echo '*** Please define variable `${*}` ***' && exit 1)
50 changes: 32 additions & 18 deletions api/api.gen.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

87 changes: 46 additions & 41 deletions api/swagger.yaml
Original file line number Diff line number Diff line change
@@ -1,80 +1,85 @@
openapi: 3.0.2
x-stoplight:
id: 44w9u0405b53e
id: g0km90jnbo4i0
info:
title: Unconditional
version: "1.0"
version: '1.0'
servers:
- url: "https://api.unconditional.day/v1"
- url: "http://localhost:8080"
- url: "127.0.0.1:8080"
- url: 'https://api.unconditional.day/v1'
- url: 'http://localhost:8080'
- url: '127.0.0.1:8080'
paths:
"/v1/search/feed/{query}":
'/v1/search/feed/{query}':
get:
responses:
"200":
'200':
description: OK
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/FeedItem"
"500":
$ref: '#/components/schemas/FeedItem'
'500':
description: Internal Server Error
content:
application/json:
schema:
type: object
$ref: "#/components/schemas/Error"
parameters:
- name: query
in: path
required: true
schema:
type: string
$ref: '#/components/schemas/Error'
x-stoplight:
id: wosl2fd4xhhrd
"/v1/search/context/{query}":
id: e6uenhk2m21k5
parameters:
- schema:
type: boolean
in: query
name: bySimilarity
parameters:
- schema:
type: string
name: query
in: path
required: true
'/v1/search/context/{query}':
get:
responses:
"200":
'200':
description: OK
content:
application/json:
schema:
type: object
$ref: "#/components/schemas/SearchContextDetails"
"500":
$ref: '#/components/schemas/SearchContextDetails'
'500':
description: Internal Server Error
content:
application/json:
schema:
type: object
$ref: "#/components/schemas/Error"
$ref: '#/components/schemas/Error'
parameters:
- name: query
in: path
required: true
schema:
type: string
x-stoplight:
id: idoe8qr80ebxd
"/v1/version":
id: 7c394v6kr5tff
/v1/version:
get:
summary: Your GET endpoint
tags: []
responses:
"200":
'200':
description: OK
content:
application/json:
schema:
type: object
$ref: "#/components/schemas/ServerVersion"
$ref: '#/components/schemas/ServerVersion'
operationId: get-v1-version
x-stoplight:
id: q4lvzczpgn9wh
id: oucep4v9ubq2z
requestBody:
content:
application/json:
Expand All @@ -98,7 +103,7 @@ components:
type: string
image:
type: object
$ref: "#/components/schemas/FeedImage"
$ref: '#/components/schemas/FeedImage'
date:
type: string
format: date-time
Expand All @@ -110,7 +115,7 @@ components:
- language
- date
x-stoplight:
id: xa4xmb6bpguaf
id: kwewfmf4xgq3e
FeedImage:
type: object
properties:
Expand All @@ -122,11 +127,11 @@ components:
- url
- title
x-stoplight:
id: cmmybtqamyqiy
id: albynchitcqzu
SearchContextDetails:
type: object
x-stoplight:
id: 2bea7d1686f73
id: fhfrlaebk9ask
properties:
title:
type: string
Expand Down Expand Up @@ -156,51 +161,51 @@ components:
- message
- code
x-stoplight:
id: ugjrjhvkdmen2
id: mffsjrkb81ot5
ServerVersion:
title: ServerVersion
x-stoplight:
id: 24qo1fm939bg5
id: 4m4ndcimoercb
type: object
properties:
source:
$ref: "#/components/schemas/SourceReleaseVersion"
$ref: '#/components/schemas/SourceReleaseVersion'
build:
$ref: "#/components/schemas/ServerBuildVersion"
$ref: '#/components/schemas/ServerBuildVersion'
required:
- source
- build
SourceReleaseVersion:
title: SourceReleaseVersion
x-stoplight:
id: ufsclw4vu3qp5
id: qrni9cae7qsr6
type: object
properties:
version:
type: string
x-stoplight:
id: t6xp7ev3nprdj
id: g42kpmf59e9sb
lastUpdatedAt:
type: string
x-stoplight:
id: 26hfi8gtj9bdi
id: ozgly07pllzwb
required:
- version
- lastUpdatedAt
ServerBuildVersion:
title: ServerBuildVersion
x-stoplight:
id: p7byzats6s3zt
id: a6g4vsjso6ozw
type: object
properties:
commit:
type: string
x-stoplight:
id: eoik296b0ddt3
id: 48tl37vuwu47p
version:
type: string
x-stoplight:
id: jup15zjavkg3a
id: mwqxrg5t0vvst
required:
- commit
- version
2 changes: 2 additions & 0 deletions internal/app/feed.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ import (
type FeedRepository interface {
// Search returns the results of a search query.
Find(query string) ([]Feed, error)
// Search returns the results of a search query by similarity.
FindBySimilarity(query string) ([]Feed, error)
// Index indexes a document.
Save(doc Feed) error
// Update a document in index.
Expand Down
12 changes: 11 additions & 1 deletion internal/container/container.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
package container

import (
"context"
"net/http"
"time"

"go.uber.org/zap"

Expand Down Expand Up @@ -120,9 +122,17 @@ func (c *Container) GetTypesenseClient() *typesense.Client {
return c.typesenseClient
}

typesenseConnTimeout := 30 * time.Second

// TODO: Export it in a x/typesense pkg as wrapper with check config logic
client := typesense.NewClient(
typesense.WithServer(c.FeedRepositoryHost),
typesense.WithAPIKey(c.FeedRepositoryKey))
typesense.WithAPIKey(c.FeedRepositoryKey),
typesense.WithConnectionTimeout(typesenseConnTimeout))

if _, err := client.Health(context.Background(), typesenseConnTimeout); err != nil {
panic(err)
}

c.typesenseClient = client

Expand Down
Loading

0 comments on commit cfe91aa

Please sign in to comment.