| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
- // SPDX-License-Identifier: Apache-2.0
- package espial // import "miniflux.app/v2/internal/integration/espial"
- import (
- "fmt"
- "miniflux.app/v2/internal/http/client"
- "miniflux.app/v2/internal/urllib"
- )
- // Document structure of an Espial document
- type Document struct {
- Title string `json:"title,omitempty"`
- Url string `json:"url,omitempty"`
- ToRead bool `json:"toread,omitempty"`
- Tags string `json:"tags,omitempty"`
- }
- // Client represents an Espial client.
- type Client struct {
- baseURL string
- apiKey string
- }
- // NewClient returns a new Espial client.
- func NewClient(baseURL, apiKey string) *Client {
- return &Client{baseURL: baseURL, apiKey: apiKey}
- }
- // AddEntry sends an entry to Espial.
- func (c *Client) AddEntry(link, title, content, tags string) error {
- if c.baseURL == "" || c.apiKey == "" {
- return fmt.Errorf("espial: missing base URL or API key")
- }
- doc := &Document{
- Title: title,
- Url: link,
- ToRead: true,
- Tags: tags,
- }
- apiEndpoint, err := urllib.JoinBaseURLAndPath(c.baseURL, "/api/add")
- if err != nil {
- return fmt.Errorf(`espial: invalid API endpoint: %v`, err)
- }
- clt := client.New(apiEndpoint)
- clt.WithAuthorization("ApiKey " + c.apiKey)
- response, err := clt.PostJSON(doc)
- if err != nil {
- return fmt.Errorf("espial: unable to send entry: %v", err)
- }
- if response.HasServerFailure() {
- return fmt.Errorf("espial: unable to send entry, status=%d", response.StatusCode)
- }
- return nil
- }
|