2021-01-31 09:08:52 +01:00
|
|
|
# Photoprism Client Go
|
|
|
|
|
|
|
|
Go client for the Photoprism Application.
|
2021-02-12 03:11:05 +01:00
|
|
|
|
2021-05-13 19:01:10 +02:00
|
|
|
**Author**: [Kris Nóva](https://github.com/kris-nova) <kris@nivenly.com>
|
2021-01-31 09:08:52 +01:00
|
|
|
|
2021-02-12 03:04:53 +01:00
|
|
|
---
|
|
|
|
|
|
|
|
# Install
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
2021-05-05 16:18:05 +02:00
|
|
|
go get github.com/astravexton/photoprism-client-go
|
2021-02-12 03:04:53 +01:00
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
# Supported Methods
|
|
|
|
|
|
|
|
```go
|
2021-02-12 03:11:05 +01:00
|
|
|
|
|
|
|
func New(connURL *url.URL, token, downloadToken string) *V1Client
|
|
|
|
func (v1 *V1Client) AddPhotosToAlbum(albumUUID string, photoIDs []string) error
|
|
|
|
func (v1 *V1Client) ApprovePhoto(uuid string) error
|
|
|
|
func (v1 *V1Client) CancelIndex() error
|
|
|
|
func (v1 *V1Client) CloneAlbum(album Album) (Album, error)
|
2021-02-12 03:04:53 +01:00
|
|
|
func (v1 *V1Client) CreateAlbum(album Album) (Album, error)
|
|
|
|
func (v1 *V1Client) DeleteAlbums(albumUUIDs []string) error
|
2021-02-12 03:11:05 +01:00
|
|
|
func (v1 *V1Client) DELETE(payload interface{}, endpointFormat string, a ...interface{}) *V1Response
|
2021-02-12 03:04:53 +01:00
|
|
|
func (v1 *V1Client) DeletePhotosFromAlbum(albumUUID string, photoIDs []string) error
|
2021-02-12 03:11:05 +01:00
|
|
|
func (v1 *V1Client) DislikeAlbum(uuid string) error
|
|
|
|
func (v1 *V1Client) DislikePhoto(uuid string) error
|
|
|
|
func (v1 *V1Client) Endpoint(str string) string
|
2021-02-12 03:04:53 +01:00
|
|
|
func (v1 *V1Client) GetAlbumDownload(uuid string) ([]byte, error)
|
2021-02-12 03:11:05 +01:00
|
|
|
func (v1 *V1Client) GetAlbums(options *AlbumOptions) ([]Album, error)
|
|
|
|
func (v1 *V1Client) GetAlbum(uuid string) (Album, error)
|
2021-02-12 03:04:53 +01:00
|
|
|
func (v1 *V1Client) GET(endpointFormat string, a ...interface{}) *V1Response
|
|
|
|
func (v1 *V1Client) GetPhotoDownload(uuid string) ([]byte, error)
|
2021-02-12 03:11:05 +01:00
|
|
|
func (v1 *V1Client) GetPhotos(options *PhotoOptions) ([]Photo, error)
|
|
|
|
func (v1 *V1Client) GetPhoto(uuid string) (Photo, error)
|
2021-02-12 03:04:53 +01:00
|
|
|
func (v1 *V1Client) GetPhotoYaml(uuid string) ([]byte, error)
|
2021-02-12 03:11:05 +01:00
|
|
|
func (v1 *V1Client) Index() error
|
|
|
|
func (v1 *V1Client) LikeAlbum(uuid string) error
|
2021-02-12 03:04:53 +01:00
|
|
|
func (v1 *V1Client) LikePhoto(uuid string) error
|
|
|
|
func (v1 *V1Client) PhotoPrimary(uuid, fileuuid string) error
|
2021-02-12 03:11:05 +01:00
|
|
|
func (v1 *V1Client) POST(payload interface{}, endpointFormat string, a ...interface{}) *V1Response
|
|
|
|
func (v1 *V1Client) PUT(payload interface{}, endpointFormat string, a ...interface{}) *V1Response
|
|
|
|
func (v1 *V1Client) SetToken(token string)
|
|
|
|
func (v1 *V1Client) UpdateAlbum(album Album) (Album, error)
|
|
|
|
func (v1 *V1Client) UpdatePhoto(photo Photo) (Photo, error)
|
2021-02-12 03:04:53 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
# Example Usage
|
|
|
|
|
|
|
|
```go
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
|
|
|
"path"
|
|
|
|
|
2021-05-05 16:18:05 +02:00
|
|
|
photoprism "github.com/astravexton/photoprism-client-go"
|
|
|
|
"github.com/astravexton/logger"
|
2021-02-12 03:04:53 +01:00
|
|
|
)
|
|
|
|
|
2021-02-12 03:11:05 +01:00
|
|
|
func main()
|
2021-02-12 03:04:53 +01:00
|
|
|
logger.Level = 4
|
|
|
|
|
|
|
|
uuid := "pqnzigq351j2fqgn" // This is a known ID
|
|
|
|
client := photoprism.New("http://localhost:8080")
|
|
|
|
err := client.Auth(photoprism.NewClientAuthLogin("admin", "missy"))
|
2021-02-12 03:11:05 +01:00
|
|
|
if err != nil
|
2021-02-12 03:04:53 +01:00
|
|
|
logger.Critical("Error logging into API: %v", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----------------
|
|
|
|
// GetPhoto()
|
|
|
|
//
|
|
|
|
photo, err := client.V1().GetPhoto(uuid)
|
2021-02-12 03:11:05 +01:00
|
|
|
if err != nil
|
2021-02-12 03:04:53 +01:00
|
|
|
logger.Critical("Error fetching photo: %v", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----------------
|
|
|
|
// UpdatePhoto()
|
|
|
|
//
|
|
|
|
photo.PhotoTitle = "A really great photo!"
|
|
|
|
photo, err = client.V1().UpdatePhoto(photo)
|
2021-02-12 03:11:05 +01:00
|
|
|
if err != nil
|
2021-02-12 03:04:53 +01:00
|
|
|
logger.Critical("Error updating photo: %v", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----------------
|
|
|
|
// GetPhotoDownload()
|
|
|
|
//
|
|
|
|
file, err := client.V1().GetPhotoDownload(photo.UUID)
|
2021-02-12 03:11:05 +01:00
|
|
|
if err != nil
|
2021-02-12 03:04:53 +01:00
|
|
|
logger.Critical("Error getting photo download: %v", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
2021-02-12 03:11:05 +01:00
|
|
|
for _, f := range photo.Files
|
2021-02-12 03:04:53 +01:00
|
|
|
fileName := fmt.Sprintf("/tmp/%s", path.Base(f.FileName))
|
|
|
|
logger.Always(fileName)
|
|
|
|
ioutil.WriteFile(fileName, file, 0666)
|
|
|
|
}
|
|
|
|
os.Exit(0)
|
|
|
|
}
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
# Pipeline
|
|
|
|
|
|
|
|
- [ ] Upload photo methods/tests
|
|
|
|
- [ ] Code generation
|
2021-05-13 19:01:10 +02:00
|
|
|
- [ ] Finish the remaining methods
|