Add vk bridge (#1372)
* Add vk bridge * Vk bridge attachments * Vk bridge forwarded messages * Vk bridge sample config and code cleanup * Vk bridge add vendor * Vk bridge message edit * Vk bridge: fix fetching names of other bots * Vk bridge: code cleanup * Vk bridge: fix shadows declaration * Vk bridge: remove UseFileURLpull/1384/head
parent
5dd15ef8e7
commit
8764be7461
@ -0,0 +1,327 @@
|
||||
package bvk
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"context"
|
||||
"regexp"
|
||||
"strconv"
|
||||
"strings"
|
||||
"time"
|
||||
|
||||
"github.com/42wim/matterbridge/bridge"
|
||||
"github.com/42wim/matterbridge/bridge/config"
|
||||
"github.com/42wim/matterbridge/bridge/helper"
|
||||
|
||||
"github.com/SevereCloud/vksdk/v2/api"
|
||||
"github.com/SevereCloud/vksdk/v2/events"
|
||||
longpoll "github.com/SevereCloud/vksdk/v2/longpoll-bot"
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
const (
|
||||
audioMessage = "audio_message"
|
||||
document = "doc"
|
||||
photo = "photo"
|
||||
video = "video"
|
||||
graffiti = "graffiti"
|
||||
sticker = "sticker"
|
||||
wall = "wall"
|
||||
)
|
||||
|
||||
type user struct {
|
||||
lastname, firstname, avatar string
|
||||
}
|
||||
|
||||
type Bvk struct {
|
||||
c *api.VK
|
||||
usernamesMap map[int]user // cache of user names and avatar URLs
|
||||
*bridge.Config
|
||||
}
|
||||
|
||||
func New(cfg *bridge.Config) bridge.Bridger {
|
||||
return &Bvk{usernamesMap: make(map[int]user), Config: cfg}
|
||||
}
|
||||
|
||||
func (b *Bvk) Connect() error {
|
||||
b.Log.Info("Connecting")
|
||||
b.c = api.NewVK(b.GetString("Token"))
|
||||
lp, err := longpoll.NewLongPoll(b.c, b.GetInt("GroupID"))
|
||||
if err != nil {
|
||||
b.Log.Debugf("%#v", err)
|
||||
|
||||
return err
|
||||
}
|
||||
|
||||
lp.MessageNew(func(ctx context.Context, obj events.MessageNewObject) {
|
||||
b.handleMessage(obj.Message, false)
|
||||
})
|
||||
|
||||
b.Log.Info("Connection succeeded")
|
||||
|
||||
go func() {
|
||||
err := lp.Run()
|
||||
if err != nil {
|
||||
b.Log.Fatal("Enable longpoll in group management")
|
||||
}
|
||||
}()
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (b *Bvk) Disconnect() error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (b *Bvk) JoinChannel(channel config.ChannelInfo) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (b *Bvk) Send(msg config.Message) (string, error) {
|
||||
b.Log.Debugf("=> Receiving %#v", msg)
|
||||
|
||||
peerID, err := strconv.Atoi(msg.Channel)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
|
||||
params := api.Params{}
|
||||
|
||||
text := msg.Username + msg.Text
|
||||
|
||||
if msg.Extra != nil {
|
||||
if len(msg.Extra["file"]) > 0 {
|
||||
// generate attachments string
|
||||
attachment, urls := b.uploadFiles(msg.Extra, peerID)
|
||||
params["attachment"] = attachment
|
||||
text += urls
|
||||
}
|
||||
}
|
||||
|
||||
params["message"] = text
|
||||
|
||||
if msg.ID == "" {
|
||||
// New message
|
||||
params["random_id"] = time.Now().Unix()
|
||||
params["peer_ids"] = msg.Channel
|
||||
|
||||
res, e := b.c.MessagesSendPeerIDs(params)
|
||||
if e != nil {
|
||||
return "", err
|
||||
}
|
||||
|
||||
return strconv.Itoa(res[0].ConversationMessageID), nil
|
||||
}
|
||||
// Edit message
|
||||
messageID, err := strconv.ParseInt(msg.ID, 10, 64)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
|
||||
params["peer_id"] = peerID
|
||||
params["conversation_message_id"] = messageID
|
||||
|
||||
_, err = b.c.MessagesEdit(params)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
|
||||
return msg.ID, nil
|
||||
}
|
||||
|
||||
func (b *Bvk) getUser(id int) user {
|
||||
u, found := b.usernamesMap[id]
|
||||
if !found {
|
||||
b.Log.Debug("Fetching username for ", id)
|
||||
|
||||
if id >= 0 {
|
||||
result, _ := b.c.UsersGet(api.Params{
|
||||
"user_ids": id,
|
||||
"fields": "photo_200",
|
||||
})
|
||||
|
||||
resUser := result[0]
|
||||
u = user{lastname: resUser.LastName, firstname: resUser.FirstName, avatar: resUser.Photo200}
|
||||
b.usernamesMap[id] = u
|
||||
} else {
|
||||
result, _ := b.c.GroupsGetByID(api.Params{
|
||||
"group_id": id * -1,
|
||||
})
|
||||
|
||||
resGroup := result[0]
|
||||
u = user{lastname: resGroup.Name, avatar: resGroup.Photo200}
|
||||
}
|
||||
}
|
||||
|
||||
return u
|
||||
}
|
||||
|
||||
func (b *Bvk) handleMessage(msg object.MessagesMessage, isFwd bool) {
|
||||
b.Log.Debug("ChatID: ", msg.PeerID)
|
||||
// fetch user info
|
||||
u := b.getUser(msg.FromID)
|
||||
|
||||
rmsg := config.Message{
|
||||
Text: msg.Text,
|
||||
Username: u.firstname + " " + u.lastname,
|
||||
Avatar: u.avatar,
|
||||
Channel: strconv.Itoa(msg.PeerID),
|
||||
Account: b.Account,
|
||||
UserID: strconv.Itoa(msg.FromID),
|
||||
ID: strconv.Itoa(msg.ConversationMessageID),
|
||||
Extra: make(map[string][]interface{}),
|
||||
}
|
||||
|
||||
if msg.ReplyMessage != nil {
|
||||
ur := b.getUser(msg.ReplyMessage.FromID)
|
||||
rmsg.Text = "Re: " + ur.firstname + " " + ur.lastname + "\n" + rmsg.Text
|
||||
}
|
||||
|
||||
if isFwd {
|
||||
rmsg.Username = "Fwd: " + rmsg.Username
|
||||
}
|
||||
|
||||
if len(msg.Attachments) > 0 {
|
||||
urls, text := b.getFiles(msg.Attachments)
|
||||
|
||||
if text != "" {
|
||||
rmsg.Text += "\n" + text
|
||||
}
|
||||
|
||||
// download
|
||||
b.downloadFiles(&rmsg, urls)
|
||||
}
|
||||
|
||||
if len(msg.FwdMessages) > 0 {
|
||||
rmsg.Text += strconv.Itoa(len(msg.FwdMessages)) + " forwarded messages"
|
||||
}
|
||||
|
||||
b.Remote <- rmsg
|
||||
|
||||
if len(msg.FwdMessages) > 0 {
|
||||
// recursive processing of forwarded messages
|
||||
for _, m := range msg.FwdMessages {
|
||||
m.PeerID = msg.PeerID
|
||||
b.handleMessage(m, true)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func (b *Bvk) uploadFiles(extra map[string][]interface{}, peerID int) (string, string) {
|
||||
var attachments []string
|
||||
text := ""
|
||||
|
||||
for _, f := range extra["file"] {
|
||||
fi := f.(config.FileInfo)
|
||||
|
||||
if fi.Comment != "" {
|
||||
text += fi.Comment + "\n"
|
||||
}
|
||||
a, err := b.uploadFile(fi, peerID)
|
||||
if err != nil {
|
||||
b.Log.Error("File upload error ", fi.Name)
|
||||
}
|
||||
|
||||
attachments = append(attachments, a)
|
||||
}
|
||||
|
||||
return strings.Join(attachments, ","), text
|
||||
}
|
||||
|
||||
func (b *Bvk) uploadFile(file config.FileInfo, peerID int) (string, error) {
|
||||
r := bytes.NewReader(*file.Data)
|
||||
|
||||
photoRE := regexp.MustCompile(".(jpg|jpe|png)$")
|
||||
if photoRE.MatchString(file.Name) {
|
||||
p, err := b.c.UploadMessagesPhoto(peerID, r)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
|
||||
return photo + strconv.Itoa(p[0].OwnerID) + "_" + strconv.Itoa(p[0].ID), nil
|
||||
}
|
||||
|
||||
var doctype string
|
||||
if strings.Contains(file.Name, ".ogg") {
|
||||
doctype = audioMessage
|
||||
} else {
|
||||
doctype = document
|
||||
}
|
||||
|
||||
doc, err := b.c.UploadMessagesDoc(peerID, doctype, file.Name, "", r)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
|
||||
switch doc.Type {
|
||||
case audioMessage:
|
||||
return document + strconv.Itoa(doc.AudioMessage.OwnerID) + "_" + strconv.Itoa(doc.AudioMessage.ID), nil
|
||||
case document:
|
||||
return document + strconv.Itoa(doc.Doc.OwnerID) + "_" + strconv.Itoa(doc.Doc.ID), nil
|
||||
}
|
||||
|
||||
return "", nil
|
||||
}
|
||||
|
||||
func (b *Bvk) getFiles(attachments []object.MessagesMessageAttachment) ([]string, string) {
|
||||
var urls []string
|
||||
var text []string
|
||||
|
||||
for _, a := range attachments {
|
||||
switch a.Type {
|
||||
case photo:
|
||||
var resolution float64 = 0
|
||||
url := a.Photo.Sizes[0].URL
|
||||
for _, size := range a.Photo.Sizes {
|
||||
r := size.Height * size.Width
|
||||
if resolution < r {
|
||||
resolution = r
|
||||
url = size.URL
|
||||
}
|
||||
}
|
||||
|
||||
urls = append(urls, url)
|
||||
|
||||
case document:
|
||||
urls = append(urls, a.Doc.URL)
|
||||
|
||||
case graffiti:
|
||||
urls = append(urls, a.Graffiti.URL)
|
||||
|
||||
case audioMessage:
|
||||
urls = append(urls, a.AudioMessage.DocsDocPreviewAudioMessage.LinkOgg)
|
||||
|
||||
case sticker:
|
||||
var resolution float64 = 0
|
||||
url := a.Sticker.Images[0].URL
|
||||
for _, size := range a.Sticker.Images {
|
||||
r := size.Height * size.Width
|
||||
if resolution < r {
|
||||
resolution = r
|
||||
url = size.URL
|
||||
}
|
||||
}
|
||||
urls = append(urls, url+".png")
|
||||
case video:
|
||||
text = append(text, "https://vk.com/video"+strconv.Itoa(a.Video.OwnerID)+"_"+strconv.Itoa(a.Video.ID))
|
||||
|
||||
case wall:
|
||||
text = append(text, "https://vk.com/wall"+strconv.Itoa(a.Wall.FromID)+"_"+strconv.Itoa(a.Wall.ID))
|
||||
|
||||
default:
|
||||
text = append(text, "This attachment is not supported ("+a.Type+")")
|
||||
}
|
||||
}
|
||||
|
||||
return urls, strings.Join(text, "\n")
|
||||
}
|
||||
|
||||
func (b *Bvk) downloadFiles(rmsg *config.Message, urls []string) {
|
||||
for _, url := range urls {
|
||||
data, err := helper.DownloadFile(url)
|
||||
if err == nil {
|
||||
urlPart := strings.Split(url, "/")
|
||||
name := strings.Split(urlPart[len(urlPart)-1], "?")[0]
|
||||
helper.HandleDownloadData(b.Log, rmsg, name, "", url, data, b.General)
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,11 @@
|
||||
// +build !novk
|
||||
|
||||
package bridgemap
|
||||
|
||||
import (
|
||||
bvk "github.com/42wim/matterbridge/bridge/vk"
|
||||
)
|
||||
|
||||
func init() {
|
||||
FullMap["vk"] = bvk.New
|
||||
}
|
@ -0,0 +1,5 @@
|
||||
_vendor/
|
||||
vendor/
|
||||
*.out
|
||||
coverage.txt
|
||||
*.test
|
@ -0,0 +1,84 @@
|
||||
---
|
||||
linters:
|
||||
disable-all: true
|
||||
enable:
|
||||
- bodyclose
|
||||
- deadcode
|
||||
- errcheck
|
||||
- gochecknoglobals
|
||||
- goconst
|
||||
- gocritic
|
||||
- gofmt
|
||||
- goimports
|
||||
- golint
|
||||
- goprintffuncname
|
||||
- gosec
|
||||
- gosimple
|
||||
- govet
|
||||
- ineffassign
|
||||
- interfacer
|
||||
- maligned
|
||||
- misspell
|
||||
- nakedret
|
||||
- prealloc
|
||||
- staticcheck
|
||||
- structcheck
|
||||
- stylecheck
|
||||
- typecheck
|
||||
- unconvert
|
||||
- unparam
|
||||
- unused
|
||||
- varcheck
|
||||
- whitespace
|
||||
- wsl
|
||||
- godot
|
||||
- asciicheck
|
||||
- nolintlint
|
||||
- gofumpt
|
||||
- goerr113
|
||||
- tparallel
|
||||
- errorlint
|
||||
- paralleltest
|
||||
|
||||
# - wrapcheck # TODO: v3 Fix
|
||||
# - testpackage # TODO: Fix testpackage
|
||||
# - nestif # TODO: Fix nestif
|
||||
|
||||
# don't enable:
|
||||
# - depguard
|
||||
# - dogsled
|
||||
# - dupl
|
||||
# - funlen
|
||||
# - gochecknoinits
|
||||
# - gocognit
|
||||
# - gocyclo
|
||||
# - godox
|
||||
# - gomnd
|
||||
# - lll
|
||||
# - rowserrcheck
|
||||
# - scopelint
|
||||
# - gomodguard
|
||||
# - exhaustive
|
||||
# - nlreturn
|
||||
# - gci
|
||||
# - exhaustivestruct
|
||||
|
||||
issues:
|
||||
exclude-rules:
|
||||
- path: _test\.go
|
||||
linters:
|
||||
- gocyclo
|
||||
- errcheck
|
||||
- dupl
|
||||
- gosec
|
||||
|
||||
- linters:
|
||||
- errcheck
|
||||
source: ".((os\\.)?std(out|err)\\..*|.*Close|.*Flush|os\\.Remove(All)?|
|
||||
.*printf?|os\\.(Un)?Setenv)."
|
||||
|
||||
- linters:
|
||||
- stylecheck
|
||||
text: "ST1003:.*(Ts|ts).*TS"
|
||||
|
||||
exclude-use-default: false
|
@ -0,0 +1,2 @@
|
||||
---
|
||||
no-hard-tabs: false
|
@ -0,0 +1,20 @@
|
||||
---
|
||||
language: go
|
||||
|
||||
cache:
|
||||
directories:
|
||||
- $HOME/.cache/go-build
|
||||
- $HOME/gopath/pkg/mod
|
||||
|
||||
go:
|
||||
- 1.x
|
||||
|
||||
before_script:
|
||||
- git fetch --depth=1 origin +refs/tags/*:refs/tags/*
|
||||
- git describe --tags $(git rev-list --tags --max-count=1) --always
|
||||
|
||||
script:
|
||||
- go test -v -race -coverprofile=coverage.txt -covermode=atomic -p=1 ./...
|
||||
|
||||
after_success:
|
||||
- bash <(curl -s https://codecov.io/bash)
|
@ -0,0 +1,21 @@
|
||||
The MIT License (MIT)
|
||||
|
||||
Copyright (c) 2020 Daniil Suvorov
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
@ -0,0 +1,121 @@
|
||||
# VK SDK for Golang
|
||||
|
||||
[![Build Status](https://travis-ci.com/SevereCloud/vksdk.svg?branch=master)](https://travis-ci.com/SevereCloud/vksdk)
|
||||
[![PkgGoDev](https://pkg.go.dev/badge/github.com/SevereCloud/vksdk/v2/v2)](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2?tab=subdirectories)
|
||||
[![VK Developers](https://img.shields.io/badge/developers-%234a76a8.svg?logo=VK&logoColor=white)](https://vk.com/dev/)
|
||||
[![codecov](https://codecov.io/gh/SevereCloud/vksdk/branch/master/graph/badge.svg)](https://codecov.io/gh/SevereCloud/vksdk)
|
||||
[![VK chat](https://img.shields.io/badge/VK%20chat-%234a76a8.svg?logo=VK&logoColor=white)](https://vk.me/join/AJQ1d6Or8Q00Y_CSOESfbqGt)
|
||||
[![release](https://img.shields.io/github/v/tag/SevereCloud/vksdk?label=release)](https://github.com/SevereCloud/vksdk/releases)
|
||||
[![license](https://img.shields.io/github/license/SevereCloud/vksdk.svg?maxAge=2592000)](https://github.com/SevereCloud/vksdk/blob/master/LICENSE)
|
||||
|
||||
**VK SDK for Golang** ready implementation of the main VK API functions for Go.
|
||||
|
||||
[Russian documentation](https://github.com/SevereCloud/vksdk/wiki)
|
||||
|
||||
## Features
|
||||
|
||||
Version API 5.126.
|
||||
|
||||
- [API](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2/api)
|
||||
- 400+ methods
|
||||
- Ability to change the request handler
|
||||
- Ability to modify HTTP client
|
||||
- Request Limiter
|
||||
- Token pool
|
||||
- [Callback API](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2/callback)
|
||||
- Tracking tool for users activity in your VK communities
|
||||
- Supports all events
|
||||
- Auto setting callback
|
||||
- [Bots Long Poll API](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2/longpoll-bot)
|
||||
- Allows you to work with community events in real time
|
||||
- Supports all events
|
||||
- Ability to modify HTTP client
|
||||
- [User Long Poll API](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2/longpoll-user)
|
||||
- Allows you to work with user events in real time
|
||||
- Ability to modify HTTP client
|
||||
- [Streaming API](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2/streaming)
|
||||
- Receiving public data from VK by specified keywords
|
||||
- Ability to modify HTTP client
|
||||
- [FOAF](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2/foaf)
|
||||
- Machine-readable ontology describing persons
|
||||
- Works with users and groups
|
||||
- The only place to get page creation date
|
||||
- [VK Mini Apps](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2/vkapps)
|
||||
- Checking launch parameters
|
||||
- Intermediate http handler
|
||||
- [Payments API](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2/payments)
|
||||
- Processes payment notifications
|
||||
- [Marusia Skills](https://pkg.go.dev/github.com/SevereCloud/vksdk/v2/marusia)
|
||||
- For creating Marusia Skills
|
||||
|
||||
## Install
|
||||
|
||||
```bash
|
||||
# go mod init mymodulename
|
||||
go get github.com/SevereCloud/vksdk/v2@latest
|
||||
```
|
||||
|
||||
## Use by
|
||||
|
||||
- [Joe](https://github.com/go-joe/joe) adapter: <https://github.com/tdakkota/joe-vk-adapter>
|
||||
- [Logrus](https://github.com/sirupsen/logrus) hook: <https://github.com/SevereCloud/vkrus>
|
||||
|
||||
### Example
|
||||
|
||||
```go
|
||||
package main
|
||||
|
||||
import (
|
||||
"context"
|
||||
"log"
|
||||
|
||||
"github.com/SevereCloud/vksdk/v2/api"
|
||||
"github.com/SevereCloud/vksdk/v2/api/params"
|
||||
"github.com/SevereCloud/vksdk/v2/events"
|
||||
"github.com/SevereCloud/vksdk/v2/longpoll-bot"
|
||||
)
|
||||
|
||||
func main() {
|
||||
token := "<TOKEN>" // use os.Getenv("TOKEN")
|
||||
vk := api.NewVK(token)
|
||||
|
||||
// get information about the group
|
||||
group, err := vk.GroupsGetByID(nil)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// Initializing Long Poll
|
||||
lp, err := longpoll.NewLongPoll(vk, group[0].ID)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
// New message event
|
||||
lp.MessageNew(func(_ context.Context, obj events.MessageNewObject) {
|
||||
log.Printf("%d: %s", obj.Message.PeerID, obj.Message.Text)
|
||||
|
||||
if obj.Message.Text == "ping" {
|
||||
b := params.NewMessagesSendBuilder()
|
||||
b.Message("pong")
|
||||
b.RandomID(0)
|
||||
b.PeerID(obj.Message.PeerID)
|
||||
|
||||
_, err := vk.MessagesSend(b.Params)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
// Run Bots Long Poll
|
||||
log.Println("Start Long Poll")
|
||||
if err := lp.Run(); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
## LICENSE
|
||||
|
||||
[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2FSevereCloud%2Fvksdk.svg?type=large)](https://app.fossa.io/projects/git%2Bgithub.com%2FSevereCloud%2Fvksdk?ref=badge_large)
|
@ -0,0 +1,196 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// AccountBan account.ban.
|
||||
//
|
||||
// https://vk.com/dev/account.ban
|
||||
func (vk *VK) AccountBan(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.ban", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountChangePasswordResponse struct.
|
||||
type AccountChangePasswordResponse struct {
|
||||
Token string `json:"token"`
|
||||
}
|
||||
|
||||
// AccountChangePassword changes a user password after access is successfully restored with the auth.restore method.
|
||||
//
|
||||
// https://vk.com/dev/account.changePassword
|
||||
func (vk *VK) AccountChangePassword(params Params) (response AccountChangePasswordResponse, err error) {
|
||||
err = vk.RequestUnmarshal("account.changePassword", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountGetActiveOffersResponse struct.
|
||||
type AccountGetActiveOffersResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.AccountOffer `json:"items"`
|
||||
}
|
||||
|
||||
// AccountGetActiveOffers returns a list of active ads (offers).
|
||||
// If the user fulfill their conditions, he will be able to get
|
||||
// the appropriate number of votes to his balance.
|
||||
//
|
||||
// https://vk.com/dev/account.getActiveOffers
|
||||
func (vk *VK) AccountGetActiveOffers(params Params) (response AccountGetActiveOffersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("account.getActiveOffers", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountGetAppPermissions gets settings of the user in this application.
|
||||
//
|
||||
// https://vk.com/dev/account.getAppPermissions
|
||||
func (vk *VK) AccountGetAppPermissions(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.getAppPermissions", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountGetBannedResponse struct.
|
||||
type AccountGetBannedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// AccountGetBanned returns a user's blacklist.
|
||||
//
|
||||
// https://vk.com/dev/account.getBanned
|
||||
func (vk *VK) AccountGetBanned(params Params) (response AccountGetBannedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("account.getBanned", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountGetCountersResponse struct.
|
||||
type AccountGetCountersResponse object.AccountAccountCounters
|
||||
|
||||
// AccountGetCounters returns non-null values of user counters.
|
||||
//
|
||||
// https://vk.com/dev/account.getCounters
|
||||
func (vk *VK) AccountGetCounters(params Params) (response AccountGetCountersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("account.getCounters", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountGetInfoResponse struct.
|
||||
type AccountGetInfoResponse object.AccountInfo
|
||||
|
||||
// AccountGetInfo returns current account info.
|
||||
//
|
||||
// https://vk.com/dev/account.getInfo
|
||||
func (vk *VK) AccountGetInfo(params Params) (response AccountGetInfoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("account.getInfo", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountGetProfileInfoResponse struct.
|
||||
type AccountGetProfileInfoResponse object.AccountUserSettings
|
||||
|
||||
// AccountGetProfileInfo returns the current account info.
|
||||
//
|
||||
// https://vk.com/dev/account.getProfileInfo
|
||||
func (vk *VK) AccountGetProfileInfo(params Params) (response AccountGetProfileInfoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("account.getProfileInfo", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountGetPushSettingsResponse struct.
|
||||
type AccountGetPushSettingsResponse object.AccountPushSettings
|
||||
|
||||
// AccountGetPushSettings account.getPushSettings Gets settings of push notifications.
|
||||
//
|
||||
// https://vk.com/dev/account.getPushSettings
|
||||
func (vk *VK) AccountGetPushSettings(params Params) (response AccountGetPushSettingsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("account.getPushSettings", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountRegisterDevice subscribes an iOS/Android/Windows/Mac based device to receive push notifications.
|
||||
//
|
||||
// https://vk.com/dev/account.registerDevice
|
||||
func (vk *VK) AccountRegisterDevice(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.registerDevice", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountSaveProfileInfoResponse struct.
|
||||
type AccountSaveProfileInfoResponse struct {
|
||||
Changed object.BaseBoolInt `json:"changed"`
|
||||
NameRequest object.AccountNameRequest `json:"name_request"`
|
||||
}
|
||||
|
||||
// AccountSaveProfileInfo edits current profile info.
|
||||
//
|
||||
// https://vk.com/dev/account.saveProfileInfo
|
||||
func (vk *VK) AccountSaveProfileInfo(params Params) (response AccountSaveProfileInfoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("account.saveProfileInfo", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountSetInfo allows to edit the current account info.
|
||||
//
|
||||
// https://vk.com/dev/account.setInfo
|
||||
func (vk *VK) AccountSetInfo(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.setInfo", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountSetNameInMenu sets an application screen name
|
||||
// (up to 17 characters), that is shown to the user in the left menu.
|
||||
//
|
||||
// https://vk.com/dev/account.setNameInMenu
|
||||
func (vk *VK) AccountSetNameInMenu(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.setNameInMenu", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountSetOffline marks a current user as offline.
|
||||
//
|
||||
// https://vk.com/dev/account.setOffline
|
||||
func (vk *VK) AccountSetOffline(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.setOffline", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountSetOnline marks the current user as online for 5 minutes.
|
||||
//
|
||||
// https://vk.com/dev/account.setOnline
|
||||
func (vk *VK) AccountSetOnline(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.setOnline", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountSetPushSettings change push settings.
|
||||
//
|
||||
// https://vk.com/dev/account.setPushSettings
|
||||
func (vk *VK) AccountSetPushSettings(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.setPushSettings", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountSetSilenceMode mutes push notifications for the set period of time.
|
||||
//
|
||||
// https://vk.com/dev/account.setSilenceMode
|
||||
func (vk *VK) AccountSetSilenceMode(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.setSilenceMode", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountUnban account.unban.
|
||||
//
|
||||
// https://vk.com/dev/account.unban
|
||||
func (vk *VK) AccountUnban(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.unban", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AccountUnregisterDevice unsubscribes a device from push notifications.
|
||||
//
|
||||
// https://vk.com/dev/account.unregisterDevice
|
||||
func (vk *VK) AccountUnregisterDevice(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("account.unregisterDevice", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,581 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// AdsAddOfficeUsersItem struct.
|
||||
type AdsAddOfficeUsersItem struct {
|
||||
OK object.BaseBoolInt
|
||||
Error AdsError
|
||||
}
|
||||
|
||||
// UnmarshalJSON func.
|
||||
func (r *AdsAddOfficeUsersItem) UnmarshalJSON(data []byte) (err error) {
|
||||
if r.OK.UnmarshalJSON(data) != nil {
|
||||
return json.Unmarshal(data, &r.Error)
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// AdsAddOfficeUsersResponse struct.
|
||||
type AdsAddOfficeUsersResponse []AdsAddOfficeUsersItem
|
||||
|
||||
// AdsAddOfficeUsers adds managers and/or supervisors to advertising account.
|
||||
//
|
||||
// https://vk.com/dev/ads.addOfficeUsers
|
||||
func (vk *VK) AdsAddOfficeUsers(params Params) (response AdsAddOfficeUsersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.addOfficeUsers", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsCheckLinkResponse struct.
|
||||
type AdsCheckLinkResponse struct {
|
||||
// link status
|
||||
Status object.AdsLinkStatus `json:"status"`
|
||||
|
||||
// (if status = disallowed) — description of the reason
|
||||
Description string `json:"description,omitempty"`
|
||||
|
||||
// (if the end link differs from original and status = allowed) — end link.
|
||||
RedirectURL string `json:"redirect_url,omitempty"`
|
||||
}
|
||||
|
||||
// AdsCheckLink allows to check the ad link.
|
||||
//
|
||||
// https://vk.com/dev/ads.checkLink
|
||||
func (vk *VK) AdsCheckLink(params Params) (response AdsCheckLinkResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.checkLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsCreateAdsResponse struct.
|
||||
type AdsCreateAdsResponse []struct {
|
||||
ID int `json:"id"`
|
||||
AdsError
|
||||
}
|
||||
|
||||
// AdsCreateAds creates ads.
|
||||
//
|
||||
// Please note! Maximum allowed number of ads created in one request is 5.
|
||||
// Minimum size of ad audience is 50 people.
|
||||
//
|
||||
// https://vk.com/dev/ads.createAds
|
||||
func (vk *VK) AdsCreateAds(params Params) (response AdsCreateAdsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.createAds", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsCreateCampaignsResponse struct.
|
||||
type AdsCreateCampaignsResponse []struct {
|
||||
ID int `json:"id"`
|
||||
AdsError
|
||||
}
|
||||
|
||||
// AdsCreateCampaigns creates advertising campaigns.
|
||||
//
|
||||
// Please note! Allowed number of campaigns created in one request is 50.
|
||||
//
|
||||
// https://vk.com/dev/ads.createCampaigns
|
||||
func (vk *VK) AdsCreateCampaigns(params Params) (response AdsCreateCampaignsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.createCampaigns", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsCreateClientsResponse struct.
|
||||
type AdsCreateClientsResponse []struct {
|
||||
ID int `json:"id"`
|
||||
AdsError
|
||||
}
|
||||
|
||||
// AdsCreateClients creates clients of an advertising agency.
|
||||
//
|
||||
// Available only for advertising agencies.
|
||||
//
|
||||
// Please note! Allowed number of clients created in one request is 50.
|
||||
//
|
||||
// https://vk.com/dev/ads.createClients
|
||||
func (vk *VK) AdsCreateClients(params Params) (response AdsCreateClientsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.createClients", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsCreateLookalikeRequestResponse struct.
|
||||
type AdsCreateLookalikeRequestResponse struct {
|
||||
RequestID int `json:"request_id"`
|
||||
}
|
||||
|
||||
// AdsCreateLookalikeRequest creates a request to find a similar audience.
|
||||
//
|
||||
// https://vk.com/dev/ads.createLookalikeRequest
|
||||
func (vk *VK) AdsCreateLookalikeRequest(params Params) (response AdsCreateLookalikeRequestResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.createLookalikeRequest", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsCreateTargetGroupResponse struct.
|
||||
type AdsCreateTargetGroupResponse struct {
|
||||
ID int `json:"id"`
|
||||
}
|
||||
|
||||
// AdsCreateTargetGroup Creates a group to re-target ads for users who visited
|
||||
// advertiser's site (viewed information about the product, registered, etc.).
|
||||
//
|
||||
// When executed successfully this method returns user accounting code on
|
||||
// advertiser's site. You shall add this code to the site page, so users
|
||||
// registered in VK will be added to the created target group after they visit
|
||||
// this page.
|
||||
//
|
||||
// Use ads.importTargetContacts method to import existing user contacts to
|
||||
// the group.
|
||||
//
|
||||
// Please note! Maximum allowed number of groups for one advertising
|
||||
// account is 100.
|
||||
//
|
||||
// https://vk.com/dev/ads.createTargetGroup
|
||||
func (vk *VK) AdsCreateTargetGroup(params Params) (response AdsCreateTargetGroupResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.createTargetGroup", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsCreateTargetPixelResponse struct.
|
||||
type AdsCreateTargetPixelResponse struct {
|
||||
ID int `json:"id"`
|
||||
Pixel string `json:"pixel"`
|
||||
}
|
||||
|
||||
// AdsCreateTargetPixel Creates retargeting pixel.
|
||||
//
|
||||
// Method returns pixel code for users accounting on the advertiser site.
|
||||
// Authorized VK users who visited the page with pixel code on it will be
|
||||
// added to retargeting audience with corresponding rules. You can also use
|
||||
// Open API, ads.importTargetContacts method and loading from file.
|
||||
//
|
||||
// Maximum pixels number per advertising account is 25.
|
||||
//
|
||||
// https://vk.com/dev/ads.createTargetPixel
|
||||
func (vk *VK) AdsCreateTargetPixel(params Params) (response AdsCreateTargetPixelResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.createTargetPixel", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsDeleteAdsResponse struct.
|
||||
//
|
||||
// Each response is 0 — deleted successfully, or an error code.
|
||||
type AdsDeleteAdsResponse []ErrorType
|
||||
|
||||
// AdsDeleteAds archives ads.
|
||||
//
|
||||
// Warning! Maximum allowed number of ads archived in one request is 100.
|
||||
//
|
||||
// https://vk.com/dev/ads.deleteAds
|
||||
func (vk *VK) AdsDeleteAds(params Params) (response AdsDeleteAdsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.deleteAds", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsDeleteCampaignsResponse struct.
|
||||
//
|
||||
// Each response is 0 — deleted successfully, or an error code.
|
||||
type AdsDeleteCampaignsResponse []ErrorType
|
||||
|
||||
// AdsDeleteCampaigns archives advertising campaigns.
|
||||
//
|
||||
//
|
||||
// Warning! Maximum allowed number of campaigns archived in one request is 100.
|
||||
//
|
||||
// https://vk.com/dev/ads.deleteCampaigns
|
||||
func (vk *VK) AdsDeleteCampaigns(params Params) (response AdsDeleteCampaignsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.deleteCampaigns", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsDeleteClientsResponse struct.
|
||||
//
|
||||
// Each response is 0 — deleted successfully, or an error code.
|
||||
type AdsDeleteClientsResponse []ErrorType
|
||||
|
||||
// AdsDeleteClients archives clients of an advertising agency.
|
||||
//
|
||||
// Available only for advertising agencies.
|
||||
//
|
||||
// Please note! Maximum allowed number of clients edited in one request is 10.
|
||||
//
|
||||
// https://vk.com/dev/ads.deleteClients
|
||||
func (vk *VK) AdsDeleteClients(params Params) (response AdsDeleteClientsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.deleteClients", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsDeleteTargetGroup deletes target group.
|
||||
//
|
||||
// https://vk.com/dev/ads.deleteTargetGroup
|
||||
func (vk *VK) AdsDeleteTargetGroup(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("ads.deleteTargetGroup", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsDeleteTargetPixel deletes target pixel.
|
||||
//
|
||||
// https://vk.com/dev/ads.deleteTargetPixel
|
||||
func (vk *VK) AdsDeleteTargetPixel(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("ads.deleteTargetPixel", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsGetAccountsResponse struct.
|
||||
type AdsGetAccountsResponse []object.AdsAccount
|
||||
|
||||
// AdsGetAccounts returns a list of advertising accounts.
|
||||
//
|
||||
// https://vk.com/dev/ads.getAccounts
|
||||
func (vk *VK) AdsGetAccounts(params Params) (response AdsGetAccountsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.getAccounts", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsGetAdsResponse struct.
|
||||
type AdsGetAdsResponse []object.AdsAd
|
||||
|
||||
// AdsGetAds returns a list of ads.
|
||||
//
|
||||
// https://vk.com/dev/ads.getAds
|
||||
func (vk *VK) AdsGetAds(params Params) (response AdsGetAdsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.getAds", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsGetAdsLayoutResponse struct.
|
||||
type AdsGetAdsLayoutResponse []object.AdsAdLayout
|
||||
|
||||
// AdsGetAdsLayout returns descriptions of ad layouts.
|
||||
//
|
||||
// https://vk.com/dev/ads.getAdsLayout
|
||||
func (vk *VK) AdsGetAdsLayout(params Params) (response AdsGetAdsLayoutResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.getAdsLayout", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// TODO: AdsGetAdsTargetingResponse struct.
|
||||
// type AdsGetAdsTargetingResponse struct{}
|
||||
|
||||
// TODO: AdsGetAdsTargeting ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getAdsTargeting
|
||||
// func (vk *VK) AdsGetAdsTargeting(params Params) (response AdsGetAdsTargetingResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getAdsTargeting", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetBudgetResponse struct.
|
||||
// type AdsGetBudgetResponse struct{}
|
||||
|
||||
// TODO: AdsGetBudget ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getBudget
|
||||
// func (vk *VK) AdsGetBudget(params Params) (response AdsGetBudgetResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getBudget", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetCampaignsResponse struct.
|
||||
// type AdsGetCampaignsResponse struct{}
|
||||
|
||||
// TODO: AdsGetCampaigns ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getCampaigns
|
||||
// func (vk *VK) AdsGetCampaigns(params Params) (response AdsGetCampaignsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getCampaigns", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetCategoriesResponse struct.
|
||||
// type AdsGetCategoriesResponse struct{}
|
||||
|
||||
// TODO: AdsGetCategories ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getCategories
|
||||
// func (vk *VK) AdsGetCategories(params Params) (response AdsGetCategoriesResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getCategories", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetClientsResponse struct.
|
||||
// type AdsGetClientsResponse struct{}
|
||||
|
||||
// TODO: AdsGetClients ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getClients
|
||||
// func (vk *VK) AdsGetClients(params Params) (response AdsGetClientsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getClients", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetDemographicsResponse struct.
|
||||
// type AdsGetDemographicsResponse struct{}
|
||||
|
||||
// TODO: AdsGetDemographics ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getDemographics
|
||||
// func (vk *VK) AdsGetDemographics(params Params) (response AdsGetDemographicsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getDemographics", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetFloodStatsResponse struct.
|
||||
// type AdsGetFloodStatsResponse struct{}
|
||||
|
||||
// TODO: AdsGetFloodStats ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getFloodStats
|
||||
// func (vk *VK) AdsGetFloodStats(params Params) (response AdsGetFloodStatsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getFloodStats", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetLookalikeRequestsResponse struct.
|
||||
// type AdsGetLookalikeRequestsResponse struct{}
|
||||
|
||||
// TODO: AdsGetLookalikeRequests ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getLookalikeRequests
|
||||
// func (vk *VK) AdsGetLookalikeRequests(params Params) (response AdsGetLookalikeRequestsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getLookalikeRequests", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// AdsGetMusiciansResponse struct.
|
||||
type AdsGetMusiciansResponse struct {
|
||||
Items []object.BaseObjectWithName
|
||||
}
|
||||
|
||||
// AdsGetMusicians returns a list of musicians.
|
||||
//
|
||||
// https://vk.com/dev/ads.getMusicians
|
||||
func (vk *VK) AdsGetMusicians(params Params) (response AdsGetMusiciansResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.getMusicians", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// TODO: AdsGetOfficeUsersResponse struct.
|
||||
// type AdsGetOfficeUsersResponse struct{}
|
||||
|
||||
// TODO: AdsGetOfficeUsers ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getOfficeUsers
|
||||
// func (vk *VK) AdsGetOfficeUsers(params Params) (response AdsGetOfficeUsersResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getOfficeUsers", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetPostsReachResponse struct.
|
||||
// type AdsGetPostsReachResponse struct{}
|
||||
|
||||
// TODO: AdsGetPostsReach ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getPostsReach
|
||||
// func (vk *VK) AdsGetPostsReach(params Params) (response AdsGetPostsReachResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getPostsReach", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetRejectionReasonResponse struct.
|
||||
// type AdsGetRejectionReasonResponse struct{}
|
||||
|
||||
// TODO: AdsGetRejectionReason ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getRejectionReason
|
||||
// func (vk *VK) AdsGetRejectionReason(params Params) (response AdsGetRejectionReasonResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getRejectionReason", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetStatisticsResponse struct.
|
||||
// type AdsGetStatisticsResponse struct{}
|
||||
|
||||
// TODO: AdsGetStatistics ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getStatistics
|
||||
// func (vk *VK) AdsGetStatistics(params Params) (response AdsGetStatisticsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getStatistics", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetSuggestionsResponse struct.
|
||||
// type AdsGetSuggestionsResponse struct{}
|
||||
|
||||
// TODO: AdsGetSuggestions ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getSuggestions
|
||||
// func (vk *VK) AdsGetSuggestions(params Params) (response AdsGetSuggestionsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getSuggestions", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// AdsGetTargetGroupsResponse struct.
|
||||
type AdsGetTargetGroupsResponse []object.AdsTargetGroup
|
||||
|
||||
// AdsGetTargetGroups returns a list of target groups.
|
||||
//
|
||||
// https://vk.com/dev/ads.getTargetGroups
|
||||
func (vk *VK) AdsGetTargetGroups(params Params) (response AdsGetTargetGroupsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("ads.getTargetGroups", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// TODO: AdsGetTargetPixelsResponse struct.
|
||||
// type AdsGetTargetPixelsResponse struct{}
|
||||
|
||||
// TODO: AdsGetTargetPixels ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getTargetPixels
|
||||
// func (vk *VK) AdsGetTargetPixels(params Params) (response AdsGetTargetPixelsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getTargetPixels", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetTargetingStatsResponse struct.
|
||||
// type AdsGetTargetingStatsResponse struct{}
|
||||
|
||||
// TODO: AdsGetTargetingStats ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getTargetingStats
|
||||
// func (vk *VK) AdsGetTargetingStats(params Params) (response AdsGetTargetingStatsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getTargetingStats", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetUploadURLResponse struct.
|
||||
// type AdsGetUploadURLResponse struct{}
|
||||
|
||||
// TODO: AdsGetUploadURL ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getUploadURL
|
||||
// func (vk *VK) AdsGetUploadURL(params Params) (response AdsGetUploadURLResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getUploadURL", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsGetVideoUploadURLResponse struct.
|
||||
// type AdsGetVideoUploadURLResponse struct{}
|
||||
|
||||
// TODO: AdsGetVideoUploadURL ...
|
||||
//
|
||||
// https://vk.com/dev/ads.getVideoUploadURL
|
||||
// func (vk *VK) AdsGetVideoUploadURL(params Params) (response AdsGetVideoUploadURLResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.getVideoUploadURL", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsImportTargetContactsResponse struct.
|
||||
// type AdsImportTargetContactsResponse struct{}
|
||||
|
||||
// TODO: AdsImportTargetContacts ...
|
||||
//
|
||||
// https://vk.com/dev/ads.importTargetContacts
|
||||
// func (vk *VK) AdsImportTargetContacts(params Params) (response AdsImportTargetContactsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.importTargetContacts", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsRemoveOfficeUsersResponse struct.
|
||||
// type AdsRemoveOfficeUsersResponse struct{}
|
||||
|
||||
// TODO: AdsRemoveOfficeUsers ...
|
||||
//
|
||||
// https://vk.com/dev/ads.removeOfficeUsers
|
||||
// func (vk *VK) AdsRemoveOfficeUsers(params Params) (response AdsRemoveOfficeUsersResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.removeOfficeUsers", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// AdsRemoveTargetContacts accepts the request to exclude the advertiser's
|
||||
// contacts from the retargeting audience.
|
||||
//
|
||||
// The maximum allowed number of contacts to be excluded by a single
|
||||
// request is 1000.
|
||||
//
|
||||
// Contacts are excluded within a few hours of the request.
|
||||
//
|
||||
// https://vk.com/dev/ads.removeTargetContacts
|
||||
func (vk *VK) AdsRemoveTargetContacts(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("ads.removeTargetContacts", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// TODO: AdsSaveLookalikeRequestResultResponse struct.
|
||||
// type AdsSaveLookalikeRequestResultResponse struct{}
|
||||
|
||||
// TODO: AdsSaveLookalikeRequestResult ...
|
||||
//
|
||||
// https://vk.com/dev/ads.saveLookalikeRequestResult
|
||||
// func (vk *VK) AdsSaveLookalikeRequestResult(params Params) (
|
||||
// response AdsSaveLookalikeRequestResultResponse,
|
||||
// err error,
|
||||
// ) {
|
||||
// err = vk.RequestUnmarshal("ads.saveLookalikeRequestResult", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsShareTargetGroupResponse struct.
|
||||
// type AdsShareTargetGroupResponse struct{}
|
||||
|
||||
// TODO: AdsShareTargetGroup ...
|
||||
//
|
||||
// https://vk.com/dev/ads.shareTargetGroup
|
||||
// func (vk *VK) AdsShareTargetGroup(params Params) (response AdsShareTargetGroupResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.shareTargetGroup", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsUpdateAdsResponse struct.
|
||||
// type AdsUpdateAdsResponse struct{}
|
||||
|
||||
// TODO: AdsUpdateAds ...
|
||||
//
|
||||
// https://vk.com/dev/ads.updateAds
|
||||
// func (vk *VK) AdsUpdateAds(params Params) (response AdsUpdateAdsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.updateAds", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsUpdateCampaignsResponse struct.
|
||||
// type AdsUpdateCampaignsResponse struct{}
|
||||
|
||||
// TODO: AdsUpdateCampaigns ...
|
||||
//
|
||||
// https://vk.com/dev/ads.updateCampaigns
|
||||
// func (vk *VK) AdsUpdateCampaigns(params Params) (response AdsUpdateCampaignsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.updateCampaigns", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// TODO: AdsUpdateClientsResponse struct.
|
||||
// type AdsUpdateClientsResponse struct{}
|
||||
|
||||
// TODO: AdsUpdateClients ...
|
||||
//
|
||||
// https://vk.com/dev/ads.updateClients
|
||||
// func (vk *VK) AdsUpdateClients(params Params) (response AdsUpdateClientsResponse, err error) {
|
||||
// err = vk.RequestUnmarshal("ads.updateClients", &response, params)
|
||||
// return
|
||||
// }
|
||||
|
||||
// AdsUpdateTargetGroup edits target group.
|
||||
//
|
||||
// https://vk.com/dev/ads.updateTargetGroup
|
||||
func (vk *VK) AdsUpdateTargetGroup(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("ads.updateTargetGroup", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AdsUpdateTargetPixel edits target pixel.
|
||||
//
|
||||
// https://vk.com/dev/ads.updateTargetPixel
|
||||
func (vk *VK) AdsUpdateTargetPixel(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("ads. updateTargetPixel", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,149 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// AppsDeleteAppRequests deletes all request notifications from the current app.
|
||||
//
|
||||
// https://vk.com/dev/apps.deleteAppRequests
|
||||
func (vk *VK) AppsDeleteAppRequests(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("apps.deleteAppRequests", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppsGetResponse struct.
|
||||
type AppsGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.AppsApp `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// AppsGet returns applications data.
|
||||
//
|
||||
// https://vk.com/dev/apps.get
|
||||
func (vk *VK) AppsGet(params Params) (response AppsGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("apps.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppsGetCatalogResponse struct.
|
||||
type AppsGetCatalogResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.AppsApp `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// AppsGetCatalog returns a list of applications (apps) available to users in the App Catalog.
|
||||
//
|
||||
// https://vk.com/dev/apps.getCatalog
|
||||
func (vk *VK) AppsGetCatalog(params Params) (response AppsGetCatalogResponse, err error) {
|
||||
err = vk.RequestUnmarshal("apps.getCatalog", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppsGetFriendsListResponse struct.
|
||||
type AppsGetFriendsListResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// AppsGetFriendsList creates friends list for requests and invites in current app.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/apps.getFriendsList
|
||||
func (vk *VK) AppsGetFriendsList(params Params) (response AppsGetFriendsListResponse, err error) {
|
||||
err = vk.RequestUnmarshal("apps.getFriendsList", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// AppsGetFriendsListExtendedResponse struct.
|
||||
type AppsGetFriendsListExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// AppsGetFriendsListExtended creates friends list for requests and invites in current app.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/apps.getFriendsList
|
||||
func (vk *VK) AppsGetFriendsListExtended(params Params) (response AppsGetFriendsListExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("apps.getFriendsList", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// AppsGetLeaderboardResponse struct.
|
||||
type AppsGetLeaderboardResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.AppsLeaderboard `json:"items"`
|
||||
}
|
||||
|
||||
// AppsGetLeaderboard returns players rating in the game.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/apps.getLeaderboard
|
||||
func (vk *VK) AppsGetLeaderboard(params Params) (response AppsGetLeaderboardResponse, err error) {
|
||||
err = vk.RequestUnmarshal("apps.getLeaderboard", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// AppsGetLeaderboardExtendedResponse struct.
|
||||
type AppsGetLeaderboardExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []struct {
|
||||
Score int `json:"score"`
|
||||
UserID int `json:"user_id"`
|
||||
} `json:"items"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
}
|
||||
|
||||
// AppsGetLeaderboardExtended returns players rating in the game.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/apps.getLeaderboard
|
||||
func (vk *VK) AppsGetLeaderboardExtended(params Params) (response AppsGetLeaderboardExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("apps.getLeaderboard", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// AppsGetScopesResponse struct.
|
||||
type AppsGetScopesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.AppsScope `json:"items"`
|
||||
}
|
||||
|
||||
// AppsGetScopes ...
|
||||
//
|
||||
// TODO: write docs.
|
||||
//
|
||||
// https://vk.com/dev/apps.getScopes
|
||||
func (vk *VK) AppsGetScopes(params Params) (response AppsGetScopesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("apps.getScopes", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppsGetScore returns user score in app.
|
||||
//
|
||||
// NOTE: vk wtf!?
|
||||
//
|
||||
// https://vk.com/dev/apps.getScore
|
||||
func (vk *VK) AppsGetScore(params Params) (response string, err error) {
|
||||
err = vk.RequestUnmarshal("apps.getScore", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppsSendRequest sends a request to another user in an app that uses VK authorization.
|
||||
//
|
||||
// https://vk.com/dev/apps.sendRequest
|
||||
func (vk *VK) AppsSendRequest(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("apps.sendRequest", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,100 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// AppWidgetsGetAppImageUploadServerResponse struct.
|
||||
type AppWidgetsGetAppImageUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// AppWidgetsGetAppImageUploadServer returns a URL for uploading a
|
||||
// photo to the app collection for community app widgets.
|
||||
//
|
||||
// https://vk.com/dev/appWidgets.getAppImageUploadServer
|
||||
func (vk *VK) AppWidgetsGetAppImageUploadServer(params Params) (
|
||||
response AppWidgetsGetAppImageUploadServerResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("appWidgets.getAppImageUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppWidgetsGetAppImagesResponse struct.
|
||||
type AppWidgetsGetAppImagesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.AppWidgetsImage `json:"items"`
|
||||
}
|
||||
|
||||
// AppWidgetsGetAppImages returns an app collection of images for community app widgets.
|
||||
//
|
||||
// https://vk.com/dev/appWidgets.getAppImages
|
||||
func (vk *VK) AppWidgetsGetAppImages(params Params) (response AppWidgetsGetAppImagesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("appWidgets.getAppImages", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppWidgetsGetGroupImageUploadServerResponse struct.
|
||||
type AppWidgetsGetGroupImageUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// AppWidgetsGetGroupImageUploadServer returns a URL for uploading
|
||||
// a photo to the community collection for community app widgets.
|
||||
//
|
||||
// https://vk.com/dev/appWidgets.getGroupImageUploadServer
|
||||
func (vk *VK) AppWidgetsGetGroupImageUploadServer(params Params) (
|
||||
response AppWidgetsGetGroupImageUploadServerResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("appWidgets.getGroupImageUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppWidgetsGetGroupImagesResponse struct.
|
||||
type AppWidgetsGetGroupImagesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.AppWidgetsImage `json:"items"`
|
||||
}
|
||||
|
||||
// AppWidgetsGetGroupImages returns a community collection of images for community app widgets.
|
||||
//
|
||||
// https://vk.com/dev/appWidgets.getGroupImages
|
||||
func (vk *VK) AppWidgetsGetGroupImages(params Params) (response AppWidgetsGetGroupImagesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("appWidgets.getGroupImages", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppWidgetsGetImagesByID returns an image for community app widgets by its ID.
|
||||
//
|
||||
// https://vk.com/dev/appWidgets.getImagesById
|
||||
func (vk *VK) AppWidgetsGetImagesByID(params Params) (response object.AppWidgetsImage, err error) {
|
||||
err = vk.RequestUnmarshal("appWidgets.getImagesById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppWidgetsSaveAppImage allows to save image into app collection for community app widgets.
|
||||
//
|
||||
// https://vk.com/dev/appWidgets.saveAppImage
|
||||
func (vk *VK) AppWidgetsSaveAppImage(params Params) (response object.AppWidgetsImage, err error) {
|
||||
err = vk.RequestUnmarshal("appWidgets.saveAppImage", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppWidgetsSaveGroupImage allows to save image into community collection for community app widgets.
|
||||
//
|
||||
// https://vk.com/dev/appWidgets.saveGroupImage
|
||||
func (vk *VK) AppWidgetsSaveGroupImage(params Params) (response object.AppWidgetsImage, err error) {
|
||||
err = vk.RequestUnmarshal("appWidgets.saveGroupImage", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AppWidgetsUpdate allows to update community app widget.
|
||||
//
|
||||
// https://vk.com/dev/appWidgets.update
|
||||
func (vk *VK) AppWidgetsUpdate(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("appWidgets.update", &response, params)
|
||||
|
||||
return
|
||||
}
|
@ -0,0 +1,26 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
// AuthCheckPhone checks a user's phone number for correctness.
|
||||
//
|
||||
// https://vk.com/dev/auth.checkPhone
|
||||
//
|
||||
// Deprecated: This method is deprecated and may be disabled soon, please avoid
|
||||
// using it.
|
||||
func (vk *VK) AuthCheckPhone(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("auth.checkPhone", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// AuthRestoreResponse struct.
|
||||
type AuthRestoreResponse struct {
|
||||
Success int `json:"success"`
|
||||
SID string `json:"sid"`
|
||||
}
|
||||
|
||||
// AuthRestore allows to restore account access using a code received via SMS.
|
||||
//
|
||||
// https://vk.com/dev/auth.restore
|
||||
func (vk *VK) AuthRestore(params Params) (response AuthRestoreResponse, err error) {
|
||||
err = vk.RequestUnmarshal("auth.restore", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,173 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// BoardAddTopic creates a new topic on a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.addTopic
|
||||
func (vk *VK) BoardAddTopic(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.addTopic", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardCloseTopic closes a topic on a community's discussion board so that comments cannot be posted.
|
||||
//
|
||||
// https://vk.com/dev/board.closeTopic
|
||||
func (vk *VK) BoardCloseTopic(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.closeTopic", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardCreateComment adds a comment on a topic on a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.createComment
|
||||
func (vk *VK) BoardCreateComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.createComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardDeleteComment deletes a comment on a topic on a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.deleteComment
|
||||
func (vk *VK) BoardDeleteComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.deleteComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardDeleteTopic deletes a topic from a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.deleteTopic
|
||||
func (vk *VK) BoardDeleteTopic(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.deleteTopic", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardEditComment edits a comment on a topic on a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.editComment
|
||||
func (vk *VK) BoardEditComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.editComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardEditTopic edits the title of a topic on a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.editTopic
|
||||
func (vk *VK) BoardEditTopic(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.editTopic", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardFixTopic pins a topic (fixes its place) to the top of a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.fixTopic
|
||||
func (vk *VK) BoardFixTopic(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.fixTopic", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardGetCommentsResponse struct.
|
||||
type BoardGetCommentsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.BoardTopicComment `json:"items"`
|
||||
Poll object.BoardTopicPoll `json:"poll"`
|
||||
RealOffset int `json:"real_offset"`
|
||||
}
|
||||
|
||||
// BoardGetComments returns a list of comments on a topic on a community's discussion board.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/board.getComments
|
||||
func (vk *VK) BoardGetComments(params Params) (response BoardGetCommentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("board.getComments", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// BoardGetCommentsExtendedResponse struct.
|
||||
type BoardGetCommentsExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.BoardTopicComment `json:"items"`
|
||||
Poll object.BoardTopicPoll `json:"poll"`
|
||||
RealOffset int `json:"real_offset"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
Groups []object.GroupsGroup `json:"groups"`
|
||||
}
|
||||
|
||||
// BoardGetCommentsExtended returns a list of comments on a topic on a community's discussion board.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/board.getComments
|
||||
func (vk *VK) BoardGetCommentsExtended(params Params) (response BoardGetCommentsExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("board.getComments", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// BoardGetTopicsResponse struct.
|
||||
type BoardGetTopicsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.BoardTopic `json:"items"`
|
||||
DefaultOrder float64 `json:"default_order"` // BUG(VK): default_order int https://vk.com/bug136682
|
||||
CanAddTopics object.BaseBoolInt `json:"can_add_topics"`
|
||||
}
|
||||
|
||||
// BoardGetTopics returns a list of topics on a community's discussion board.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/board.getTopics
|
||||
func (vk *VK) BoardGetTopics(params Params) (response BoardGetTopicsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("board.getTopics", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// BoardGetTopicsExtendedResponse struct.
|
||||
type BoardGetTopicsExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.BoardTopic `json:"items"`
|
||||
DefaultOrder float64 `json:"default_order"` // BUG(VK): default_order int https://vk.com/bug136682
|
||||
CanAddTopics object.BaseBoolInt `json:"can_add_topics"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
Groups []object.GroupsGroup `json:"groups"`
|
||||
}
|
||||
|
||||
// BoardGetTopicsExtended returns a list of topics on a community's discussion board.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/board.getTopics
|
||||
func (vk *VK) BoardGetTopicsExtended(params Params) (response BoardGetTopicsExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("board.getTopics", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// BoardOpenTopic re-opens a previously closed topic on a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.openTopic
|
||||
func (vk *VK) BoardOpenTopic(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.openTopic", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardRestoreComment restores a comment deleted from a topic on a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.restoreComment
|
||||
func (vk *VK) BoardRestoreComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.restoreComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// BoardUnfixTopic unpins a pinned topic from the top of a community's discussion board.
|
||||
//
|
||||
// https://vk.com/dev/board.unfixTopic
|
||||
func (vk *VK) BoardUnfixTopic(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("board.unfixTopic", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,7 @@
|
||||
package api
|
||||
|
||||
// CaptchaForce api method.
|
||||
func (vk *VK) CaptchaForce(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("captcha.force", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,163 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// DatabaseGetChairsResponse struct.
|
||||
type DatabaseGetChairsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.BaseObject `json:"items"`
|
||||
}
|
||||
|
||||
// DatabaseGetChairs returns list of chairs on a specified faculty.
|
||||
//
|
||||
// https://vk.com/dev/database.getChairs
|
||||
func (vk *VK) DatabaseGetChairs(params Params) (response DatabaseGetChairsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getChairs", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetCitiesResponse struct.
|
||||
type DatabaseGetCitiesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.DatabaseCity `json:"items"`
|
||||
}
|
||||
|
||||
// DatabaseGetCities returns a list of cities.
|
||||
//
|
||||
// https://vk.com/dev/database.getCities
|
||||
func (vk *VK) DatabaseGetCities(params Params) (response DatabaseGetCitiesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getCities", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetCitiesByIDResponse struct.
|
||||
type DatabaseGetCitiesByIDResponse []object.DatabaseCity
|
||||
|
||||
// DatabaseGetCitiesByID returns information about cities by their IDs.
|
||||
//
|
||||
// https://vk.com/dev/database.getCitiesByID
|
||||
func (vk *VK) DatabaseGetCitiesByID(params Params) (response DatabaseGetCitiesByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getCitiesById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetCountriesResponse struct.
|
||||
type DatabaseGetCountriesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.BaseObject `json:"items"`
|
||||
}
|
||||
|
||||
// DatabaseGetCountries returns a list of countries.
|
||||
//
|
||||
// https://vk.com/dev/database.getCountries
|
||||
func (vk *VK) DatabaseGetCountries(params Params) (response DatabaseGetCountriesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getCountries", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetCountriesByIDResponse struct.
|
||||
type DatabaseGetCountriesByIDResponse []object.BaseObject
|
||||
|
||||
// DatabaseGetCountriesByID returns information about countries by their IDs.
|
||||
//
|
||||
// https://vk.com/dev/database.getCountriesByID
|
||||
func (vk *VK) DatabaseGetCountriesByID(params Params) (response DatabaseGetCountriesByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getCountriesById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetFacultiesResponse struct.
|
||||
type DatabaseGetFacultiesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.DatabaseFaculty `json:"items"`
|
||||
}
|
||||
|
||||
// DatabaseGetFaculties returns a list of faculties (i.e., university departments).
|
||||
//
|
||||
// https://vk.com/dev/database.getFaculties
|
||||
func (vk *VK) DatabaseGetFaculties(params Params) (response DatabaseGetFacultiesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getFaculties", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetMetroStationsResponse struct.
|
||||
type DatabaseGetMetroStationsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.DatabaseMetroStation `json:"items"`
|
||||
}
|
||||
|
||||
// DatabaseGetMetroStations returns the list of metro stations.
|
||||
//
|
||||
// https://vk.com/dev/database.getMetroStations
|
||||
func (vk *VK) DatabaseGetMetroStations(params Params) (response DatabaseGetMetroStationsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getMetroStations", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetMetroStationsByIDResponse struct.
|
||||
type DatabaseGetMetroStationsByIDResponse []object.DatabaseMetroStation
|
||||
|
||||
// DatabaseGetMetroStationsByID returns information about one or several metro stations by their identifiers.
|
||||
//
|
||||
// https://vk.com/dev/database.getMetroStationsById
|
||||
func (vk *VK) DatabaseGetMetroStationsByID(params Params) (response DatabaseGetMetroStationsByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getMetroStationsById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetRegionsResponse struct.
|
||||
type DatabaseGetRegionsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.DatabaseRegion `json:"items"`
|
||||
}
|
||||
|
||||
// DatabaseGetRegions returns a list of regions.
|
||||
//
|
||||
// https://vk.com/dev/database.getRegions
|
||||
func (vk *VK) DatabaseGetRegions(params Params) (response DatabaseGetRegionsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getRegions", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetSchoolClassesResponse struct.
|
||||
type DatabaseGetSchoolClassesResponse [][]interface{}
|
||||
|
||||
// DatabaseGetSchoolClasses returns a list of school classes specified for the country.
|
||||
//
|
||||
// BUG(VK): database.getSchoolClasses bad return.
|
||||
//
|
||||
// https://vk.com/dev/database.getSchoolClasses
|
||||
func (vk *VK) DatabaseGetSchoolClasses(params Params) (response DatabaseGetSchoolClassesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getSchoolClasses", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetSchoolsResponse struct.
|
||||
type DatabaseGetSchoolsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.DatabaseSchool `json:"items"`
|
||||
}
|
||||
|
||||
// DatabaseGetSchools returns a list of schools.
|
||||
//
|
||||
// https://vk.com/dev/database.getSchools
|
||||
func (vk *VK) DatabaseGetSchools(params Params) (response DatabaseGetSchoolsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getSchools", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DatabaseGetUniversitiesResponse struct.
|
||||
type DatabaseGetUniversitiesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.DatabaseUniversity `json:"items"`
|
||||
}
|
||||
|
||||
// DatabaseGetUniversities returns a list of higher education institutions.
|
||||
//
|
||||
// https://vk.com/dev/database.getUniversities
|
||||
func (vk *VK) DatabaseGetUniversities(params Params) (response DatabaseGetUniversitiesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("database.getUniversities", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,137 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// DocsAdd copies a document to a user's or community's document list.
|
||||
//
|
||||
// https://vk.com/dev/docs.add
|
||||
func (vk *VK) DocsAdd(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("docs.add", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsDelete deletes a user or community document.
|
||||
//
|
||||
// https://vk.com/dev/docs.delete
|
||||
func (vk *VK) DocsDelete(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("docs.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsEdit edits a document.
|
||||
//
|
||||
// https://vk.com/dev/docs.edit
|
||||
func (vk *VK) DocsEdit(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("docs.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsGetResponse struct.
|
||||
type DocsGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.DocsDoc `json:"items"`
|
||||
}
|
||||
|
||||
// DocsGet returns detailed information about user or community documents.
|
||||
//
|
||||
// https://vk.com/dev/docs.get
|
||||
func (vk *VK) DocsGet(params Params) (response DocsGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("docs.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsGetByIDResponse struct.
|
||||
type DocsGetByIDResponse []object.DocsDoc
|
||||
|
||||
// DocsGetByID returns information about documents by their IDs.
|
||||
//
|
||||
// https://vk.com/dev/docs.getById
|
||||
func (vk *VK) DocsGetByID(params Params) (response DocsGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("docs.getById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsGetMessagesUploadServerResponse struct.
|
||||
type DocsGetMessagesUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// DocsGetMessagesUploadServer returns the server address for document upload.
|
||||
//
|
||||
// https://vk.com/dev/docs.getMessagesUploadServer
|
||||
func (vk *VK) DocsGetMessagesUploadServer(params Params) (response DocsGetMessagesUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("docs.getMessagesUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsGetTypesResponse struct.
|
||||
type DocsGetTypesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.DocsDocTypes `json:"items"`
|
||||
}
|
||||
|
||||
// DocsGetTypes returns documents types available for current user.
|
||||
//
|
||||
// https://vk.com/dev/docs.getTypes
|
||||
func (vk *VK) DocsGetTypes(params Params) (response DocsGetTypesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("docs.getTypes", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsGetUploadServerResponse struct.
|
||||
type DocsGetUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// DocsGetUploadServer returns the server address for document upload.
|
||||
//
|
||||
// https://vk.com/dev/docs.getUploadServer
|
||||
func (vk *VK) DocsGetUploadServer(params Params) (response DocsGetUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("docs.getUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsGetWallUploadServerResponse struct.
|
||||
type DocsGetWallUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// DocsGetWallUploadServer returns the server address for document upload onto a user's or community's wall.
|
||||
//
|
||||
// https://vk.com/dev/docs.getWallUploadServer
|
||||
func (vk *VK) DocsGetWallUploadServer(params Params) (response DocsGetWallUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("docs.getWallUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsSaveResponse struct.
|
||||
type DocsSaveResponse struct {
|
||||
Type string `json:"type"`
|
||||
AudioMessage object.MessagesAudioMessage `json:"audio_message"`
|
||||
Doc object.DocsDoc `json:"doc"`
|
||||
Graffiti object.MessagesGraffiti `json:"graffiti"`
|
||||
}
|
||||
|
||||
// DocsSave saves a document after uploading it to a server.
|
||||
//
|
||||
// https://vk.com/dev/docs.save
|
||||
func (vk *VK) DocsSave(params Params) (response DocsSaveResponse, err error) {
|
||||
err = vk.RequestUnmarshal("docs.save", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DocsSearchResponse struct.
|
||||
type DocsSearchResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.DocsDoc `json:"items"`
|
||||
}
|
||||
|
||||
// DocsSearch returns a list of documents matching the search criteria.
|
||||
//
|
||||
// https://vk.com/dev/docs.search
|
||||
func (vk *VK) DocsSearch(params Params) (response DocsSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("docs.search", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,49 @@
|
||||
package api
|
||||
|
||||
import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// DonutGetFriendsResponse struct.
|
||||
type DonutGetFriendsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// DonutGetFriends method.
|
||||
//
|
||||
// https://vk.com/dev/donut.getFriends
|
||||
func (vk *VK) DonutGetFriends(params Params) (response DonutGetFriendsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("donut.getFriends", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DonutGetSubscription method.
|
||||
//
|
||||
// https://vk.com/dev/donut.getSubscription
|
||||
func (vk *VK) DonutGetSubscription(params Params) (response object.DonutDonatorSubscriptionInfo, err error) {
|
||||
err = vk.RequestUnmarshal("donut.getSubscription", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DonutGetSubscriptionsResponse struct.
|
||||
type DonutGetSubscriptionsResponse struct {
|
||||
Subscriptions []object.DonutDonatorSubscriptionInfo `json:"subscriptions"`
|
||||
Count int `json:"count"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
Groups []object.GroupsGroup `json:"groups"`
|
||||
}
|
||||
|
||||
// DonutGetSubscriptions method.
|
||||
//
|
||||
// https://vk.com/dev/donut.getSubscriptions
|
||||
func (vk *VK) DonutGetSubscriptions(params Params) (response DonutGetSubscriptionsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("donut.getSubscriptions", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// DonutIsDon method.
|
||||
//
|
||||
// https://vk.com/dev/donut.isDon
|
||||
func (vk *VK) DonutIsDon(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("donut.isDon", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,19 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// DownloadedGamesGetPaidStatusResponse struct.
|
||||
type DownloadedGamesGetPaidStatusResponse struct {
|
||||
IsPaid object.BaseBoolInt `json:"is_paid"`
|
||||
}
|
||||
|
||||
// DownloadedGamesGetPaidStatus method.
|
||||
//
|
||||
// https://vk.com/dev/downloadedGames.getPaidStatus
|
||||
func (vk *VK) DownloadedGamesGetPaidStatus(params Params) (response DownloadedGamesGetPaidStatusResponse, err error) {
|
||||
err = vk.RequestUnmarshal("downloadedGames.getPaidStatus", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
@ -0,0 +1,52 @@
|
||||
package api
|
||||
|
||||
import "encoding/json"
|
||||
|
||||
// ExecuteWithArgs a universal method for calling a sequence of other methods
|
||||
// while saving and filtering interim results.
|
||||
//
|
||||
// The Args map variable allows you to retrieve the parameters passed during
|
||||
// the request and avoids code formatting.
|
||||
//
|
||||
// return Args.code; // return parameter "code"
|
||||
// return Args.v; // return parameter "v"
|
||||
//
|
||||
// https://vk.com/dev/execute
|
||||
func (vk *VK) ExecuteWithArgs(code string, params Params, obj interface{}) error {
|
||||
token := vk.getToken()
|
||||
|
||||
reqParams := Params{
|
||||
"code": code,
|
||||
"access_token": token,
|
||||
"v": vk.Version,
|
||||
}
|
||||
|
||||
resp, err := vk.Handler("execute", params, reqParams)
|
||||
|
||||
jsonErr := json.Unmarshal(resp.Response, &obj)
|
||||
if jsonErr != nil {
|
||||
return jsonErr
|
||||
}
|
||||
|
||||
if resp.ExecuteErrors != nil {
|
||||
return &resp.ExecuteErrors
|
||||
}
|
||||
|
||||
return err
|
||||
}
|
||||
|
||||
// Execute a universal method for calling a sequence of other methods while
|
||||
// saving and filtering interim results.
|
||||
//
|
||||
// https://vk.com/dev/execute
|
||||
func (vk *VK) Execute(code string, obj interface{}) error {
|
||||
return vk.ExecuteWithArgs(code, Params{}, obj)
|
||||
}
|
||||
|
||||
func fmtBool(value bool) string {
|
||||
if value {
|
||||
return "1"
|
||||
}
|
||||
|
||||
return "0"
|
||||
}
|
@ -0,0 +1,231 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// FaveAddArticle adds a link to user faves.
|
||||
//
|
||||
// https://vk.com/dev/fave.addArticle
|
||||
func (vk *VK) FaveAddArticle(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.addArticle", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveAddLink adds a link to user faves.
|
||||
//
|
||||
// https://vk.com/dev/fave.addLink
|
||||
func (vk *VK) FaveAddLink(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.addLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveAddPage method.
|
||||
//
|
||||
// https://vk.com/dev/fave.addPage
|
||||
func (vk *VK) FaveAddPage(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.addPage", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveAddPost method.
|
||||
//
|
||||
// https://vk.com/dev/fave.addPost
|
||||
func (vk *VK) FaveAddPost(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.addPost", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveAddProduct method.
|
||||
//
|
||||
// https://vk.com/dev/fave.addProduct
|
||||
func (vk *VK) FaveAddProduct(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.addProduct", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveAddTagResponse struct.
|
||||
type FaveAddTagResponse object.FaveTag
|
||||
|
||||
// FaveAddTag method.
|
||||
//
|
||||
// https://vk.com/dev/fave.addTag
|
||||
func (vk *VK) FaveAddTag(params Params) (response FaveAddTagResponse, err error) {
|
||||
err = vk.RequestUnmarshal("fave.addTag", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveAddVideo method.
|
||||
//
|
||||
// https://vk.com/dev/fave.addVideo
|
||||
func (vk *VK) FaveAddVideo(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.addVideo", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveEditTag method.
|
||||
//
|
||||
// https://vk.com/dev/fave.editTag
|
||||
func (vk *VK) FaveEditTag(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.editTag", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveGetResponse struct.
|
||||
type FaveGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.FaveItem `json:"items"`
|
||||
}
|
||||
|
||||
// FaveGet method.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/fave.get
|
||||
func (vk *VK) FaveGet(params Params) (response FaveGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("fave.get", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// FaveGetExtendedResponse struct.
|
||||
type FaveGetExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.FaveItem `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// FaveGetExtended method.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/fave.get
|
||||
func (vk *VK) FaveGetExtended(params Params) (response FaveGetExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("fave.get", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// FaveGetPagesResponse struct.
|
||||
type FaveGetPagesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.FavePage `json:"items"`
|
||||
}
|
||||
|
||||
// FaveGetPages method.
|
||||
//
|
||||
// https://vk.com/dev/fave.getPages
|
||||
func (vk *VK) FaveGetPages(params Params) (response FaveGetPagesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("fave.getPages", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveGetTagsResponse struct.
|
||||
type FaveGetTagsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.FaveTag `json:"items"`
|
||||
}
|
||||
|
||||
// FaveGetTags method.
|
||||
//
|
||||
// https://vk.com/dev/fave.getTags
|
||||
func (vk *VK) FaveGetTags(params Params) (response FaveGetTagsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("fave.getTags", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveMarkSeen method.
|
||||
//
|
||||
// https://vk.com/dev/fave.markSeen
|
||||
func (vk *VK) FaveMarkSeen(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.markSeen", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveRemoveArticle method.
|
||||
//
|
||||
// https://vk.com/dev/fave.removeArticle
|
||||
func (vk *VK) FaveRemoveArticle(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.removeArticle", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveRemoveLink removes link from the user's faves.
|
||||
//
|
||||
// https://vk.com/dev/fave.removeLink
|
||||
func (vk *VK) FaveRemoveLink(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.removeLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveRemovePage method.
|
||||
//
|
||||
// https://vk.com/dev/fave.removePage
|
||||
func (vk *VK) FaveRemovePage(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.removePage", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveRemovePost method.
|
||||
//
|
||||
// https://vk.com/dev/fave.removePost
|
||||
func (vk *VK) FaveRemovePost(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.removePost", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveRemoveProduct method.
|
||||
//
|
||||
// https://vk.com/dev/fave.removeProduct
|
||||
func (vk *VK) FaveRemoveProduct(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.removeProduct", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveRemoveTag method.
|
||||
//
|
||||
// https://vk.com/dev/fave.removeTag
|
||||
func (vk *VK) FaveRemoveTag(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.removeTag", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveRemoveVideo method.
|
||||
//
|
||||
// https://vk.com/dev/fave.removeVideo
|
||||
func (vk *VK) FaveRemoveVideo(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.removeVideo", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveReorderTags method.
|
||||
//
|
||||
// https://vk.com/dev/fave.reorderTags
|
||||
func (vk *VK) FaveReorderTags(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.reorderTags", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveSetPageTags method.
|
||||
//
|
||||
// https://vk.com/dev/fave.setPageTags
|
||||
func (vk *VK) FaveSetPageTags(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.setPageTags", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveSetTags method.
|
||||
//
|
||||
// https://vk.com/dev/fave.setTags
|
||||
func (vk *VK) FaveSetTags(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.setTags", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FaveTrackPageInteraction method.
|
||||
//
|
||||
// https://vk.com/dev/fave.trackPageInteraction
|
||||
func (vk *VK) FaveTrackPageInteraction(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("fave.trackPageInteraction", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,295 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// FriendsAdd approves or creates a friend request.
|
||||
//
|
||||
// https://vk.com/dev/friends.add
|
||||
func (vk *VK) FriendsAdd(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("friends.add", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsAddListResponse struct.
|
||||
type FriendsAddListResponse struct {
|
||||
ListID int `json:"list_id"`
|
||||
}
|
||||
|
||||
// FriendsAddList creates a new friend list for the current user.
|
||||
//
|
||||
// https://vk.com/dev/friends.addList
|
||||
func (vk *VK) FriendsAddList(params Params) (response FriendsAddListResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.addList", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsAreFriendsResponse struct.
|
||||
type FriendsAreFriendsResponse []object.FriendsFriendStatus
|
||||
|
||||
// FriendsAreFriends checks the current user's friendship status with other specified users.
|
||||
//
|
||||
// https://vk.com/dev/friends.areFriends
|
||||
func (vk *VK) FriendsAreFriends(params Params) (response FriendsAreFriendsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.areFriends", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsDeleteResponse struct.
|
||||
type FriendsDeleteResponse struct {
|
||||
Success object.BaseBoolInt `json:"success"`
|
||||
FriendDeleted object.BaseBoolInt `json:"friend_deleted"`
|
||||
OutRequestDeleted object.BaseBoolInt `json:"out_request_deleted"`
|
||||
InRequestDeleted object.BaseBoolInt `json:"in_request_deleted"`
|
||||
SuggestionDeleted object.BaseBoolInt `json:"suggestion_deleted"`
|
||||
}
|
||||
|
||||
// FriendsDelete declines a friend request or deletes a user from the current user's friend list.
|
||||
//
|
||||
// https://vk.com/dev/friends.delete
|
||||
func (vk *VK) FriendsDelete(params Params) (response FriendsDeleteResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsDeleteAllRequests marks all incoming friend requests as viewed.
|
||||
//
|
||||
// https://vk.com/dev/friends.deleteAllRequests
|
||||
func (vk *VK) FriendsDeleteAllRequests(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("friends.deleteAllRequests", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsDeleteList deletes a friend list of the current user.
|
||||
//
|
||||
// https://vk.com/dev/friends.deleteList
|
||||
func (vk *VK) FriendsDeleteList(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("friends.deleteList", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsEdit edits the friend lists of the selected user.
|
||||
//
|
||||
// https://vk.com/dev/friends.edit
|
||||
func (vk *VK) FriendsEdit(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("friends.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsEditList edits a friend list of the current user.
|
||||
//
|
||||
// https://vk.com/dev/friends.editList
|
||||
func (vk *VK) FriendsEditList(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("friends.editList", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetResponse struct.
|
||||
type FriendsGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// FriendsGet returns a list of user IDs or detailed information about a user's friends.
|
||||
//
|
||||
// https://vk.com/dev/friends.get
|
||||
func (vk *VK) FriendsGet(params Params) (response FriendsGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetFieldsResponse struct.
|
||||
type FriendsGetFieldsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.FriendsUserXtrLists `json:"items"`
|
||||
}
|
||||
|
||||
// FriendsGetFields returns a list of user IDs or detailed information about a user's friends.
|
||||
//
|
||||
// https://vk.com/dev/friends.get
|
||||
func (vk *VK) FriendsGetFields(params Params) (response FriendsGetFieldsResponse, err error) {
|
||||
reqParams := make(Params)
|
||||
if v, prs := params["fields"]; v == "" || !prs {
|
||||
reqParams["fields"] = "id"
|
||||
}
|
||||
|
||||
err = vk.RequestUnmarshal("friends.get", &response, params, reqParams)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetAppUsersResponse struct.
|
||||
type FriendsGetAppUsersResponse []int
|
||||
|
||||
// FriendsGetAppUsers returns a list of IDs of the current user's friends who installed the application.
|
||||
//
|
||||
// https://vk.com/dev/friends.getAppUsers
|
||||
func (vk *VK) FriendsGetAppUsers(params Params) (response FriendsGetAppUsersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.getAppUsers", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetByPhonesResponse struct.
|
||||
type FriendsGetByPhonesResponse []object.FriendsUserXtrPhone
|
||||
|
||||
// FriendsGetByPhones returns a list of the current user's friends
|
||||
// whose phone numbers, validated or specified in a profile, are in a given list.
|
||||
//
|
||||
// https://vk.com/dev/friends.getByPhones
|
||||
func (vk *VK) FriendsGetByPhones(params Params) (response FriendsGetByPhonesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.getByPhones", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetListsResponse struct.
|
||||
type FriendsGetListsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.FriendsFriendsList `json:"items"`
|
||||
}
|
||||
|
||||
// FriendsGetLists returns a list of the user's friend lists.
|
||||
//
|
||||
// https://vk.com/dev/friends.getLists
|
||||
func (vk *VK) FriendsGetLists(params Params) (response FriendsGetListsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.getLists", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetMutualResponse struct.
|
||||
type FriendsGetMutualResponse []int
|
||||
|
||||
// FriendsGetMutual returns a list of user IDs of the mutual friends of two users.
|
||||
//
|
||||
// https://vk.com/dev/friends.getMutual
|
||||
func (vk *VK) FriendsGetMutual(params Params) (response FriendsGetMutualResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.getMutual", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetOnline returns a list of user IDs of a user's friends who are online.
|
||||
//
|
||||
// online_mobile=0
|
||||
//
|
||||
// https://vk.com/dev/friends.getOnline
|
||||
func (vk *VK) FriendsGetOnline(params Params) (response []int, err error) {
|
||||
err = vk.RequestUnmarshal("friends.getOnline", &response, params, Params{"online_mobile": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetOnlineOnlineMobileResponse struct.
|
||||
type FriendsGetOnlineOnlineMobileResponse struct {
|
||||
Online []int `json:"online"`
|
||||
OnlineMobile []int `json:"online_mobile"`
|
||||
}
|
||||
|
||||
// FriendsGetOnlineOnlineMobile returns a list of user IDs of a user's friends who are online.
|
||||
//
|
||||
// online_mobile=1
|
||||
//
|
||||
// https://vk.com/dev/friends.getOnline
|
||||
func (vk *VK) FriendsGetOnlineOnlineMobile(params Params) (response FriendsGetOnlineOnlineMobileResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.getOnline", &response, params, Params{"online_mobile": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetRecentResponse struct.
|
||||
type FriendsGetRecentResponse []int
|
||||
|
||||
// FriendsGetRecent returns a list of user IDs of the current user's recently added friends.
|
||||
//
|
||||
// https://vk.com/dev/friends.getRecent
|
||||
func (vk *VK) FriendsGetRecent(params Params) (response FriendsGetRecentResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.getRecent", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetRequestsResponse struct.
|
||||
type FriendsGetRequestsResponse struct {
|
||||
Count int `json:"count"` // Total requests number
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// FriendsGetRequests returns information about the current user's incoming and outgoing friend requests.
|
||||
//
|
||||
// https://vk.com/dev/friends.getRequests
|
||||
func (vk *VK) FriendsGetRequests(params Params) (response FriendsGetRequestsResponse, err error) {
|
||||
reqParams := Params{
|
||||
"need_mutual": false,
|
||||
"extended": false,
|
||||
}
|
||||
|
||||
err = vk.RequestUnmarshal("friends.getRequests", &response, params, reqParams)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetRequestsNeedMutualResponse struct.
|
||||
type FriendsGetRequestsNeedMutualResponse struct {
|
||||
Count int `json:"count"` // Total requests number
|
||||
Items []object.FriendsRequests `json:"items"`
|
||||
}
|
||||
|
||||
// FriendsGetRequestsNeedMutual returns information about the current user's incoming and outgoing friend requests.
|
||||
//
|
||||
// https://vk.com/dev/friends.getRequests
|
||||
func (vk *VK) FriendsGetRequestsNeedMutual(params Params) (response FriendsGetRequestsNeedMutualResponse, err error) {
|
||||
reqParams := Params{
|
||||
"extended": false,
|
||||
"need_mutual": true,
|
||||
}
|
||||
|
||||
err = vk.RequestUnmarshal("friends.getRequests", &response, params, reqParams)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetRequestsExtendedResponse struct.
|
||||
type FriendsGetRequestsExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.FriendsRequestsXtrMessage `json:"items"`
|
||||
}
|
||||
|
||||
// FriendsGetRequestsExtended returns information about the current user's incoming and outgoing friend requests.
|
||||
//
|
||||
// https://vk.com/dev/friends.getRequests
|
||||
func (vk *VK) FriendsGetRequestsExtended(params Params) (response FriendsGetRequestsExtendedResponse, err error) {
|
||||
reqParams := Params{
|
||||
"need_mutual": false,
|
||||
"extended": true,
|
||||
}
|
||||
|
||||
err = vk.RequestUnmarshal("friends.getRequests", &response, params, reqParams)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsGetSuggestionsResponse struct.
|
||||
type FriendsGetSuggestionsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// FriendsGetSuggestions returns a list of profiles of users whom the current user may know.
|
||||
//
|
||||
// https://vk.com/dev/friends.getSuggestions
|
||||
func (vk *VK) FriendsGetSuggestions(params Params) (response FriendsGetSuggestionsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.getSuggestions", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// FriendsSearchResponse struct.
|
||||
type FriendsSearchResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// FriendsSearch returns a list of friends matching the search criteria.
|
||||
//
|
||||
// https://vk.com/dev/friends.search
|
||||
func (vk *VK) FriendsSearch(params Params) (response FriendsSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("friends.search", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,32 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// GiftsGetResponse struct.
|
||||
type GiftsGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GiftsGift `json:"items"`
|
||||
}
|
||||
|
||||
// GiftsGet returns a list of user gifts.
|
||||
//
|
||||
// https://vk.com/dev/gifts.get
|
||||
func (vk *VK) GiftsGet(params Params) (response GiftsGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("gifts.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GiftsGetCatalogResponse struct.
|
||||
type GiftsGetCatalogResponse []struct {
|
||||
Name string `json:"name"`
|
||||
Title string `json:"title"`
|
||||
Items []object.GiftsGift `json:"items"`
|
||||
}
|
||||
|
||||
// GiftsGetCatalog returns catalog.
|
||||
//
|
||||
// https://vk.com/dev/gifts.get
|
||||
func (vk *VK) GiftsGetCatalog(params Params) (response GiftsGetCatalogResponse, err error) {
|
||||
err = vk.RequestUnmarshal("gifts.getCatalog", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,712 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// GroupsAddAddressResponse struct.
|
||||
type GroupsAddAddressResponse object.GroupsAddress
|
||||
|
||||
// GroupsAddAddress groups.addAddress.
|
||||
//
|
||||
// https://vk.com/dev/groups.addAddress
|
||||
func (vk *VK) GroupsAddAddress(params Params) (response GroupsAddAddressResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.addAddress", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsAddCallbackServerResponse struct.
|
||||
type GroupsAddCallbackServerResponse struct {
|
||||
ServerID int `json:"server_id"`
|
||||
}
|
||||
|
||||
// GroupsAddCallbackServer callback API server to the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.addCallbackServer
|
||||
func (vk *VK) GroupsAddCallbackServer(params Params) (response GroupsAddCallbackServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.addCallbackServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsAddLinkResponse struct.
|
||||
type GroupsAddLinkResponse object.GroupsGroupLink
|
||||
|
||||
// GroupsAddLink allows to add a link to the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.addLink
|
||||
func (vk *VK) GroupsAddLink(params Params) (response GroupsAddLinkResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.addLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsApproveRequest allows to approve join request to the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.approveRequest
|
||||
func (vk *VK) GroupsApproveRequest(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.approveRequest", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsBan adds a user or a group to the community blacklist.
|
||||
//
|
||||
// https://vk.com/dev/groups.ban
|
||||
func (vk *VK) GroupsBan(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.ban", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsCreateResponse struct.
|
||||
type GroupsCreateResponse object.GroupsGroup
|
||||
|
||||
// GroupsCreate creates a new community.
|
||||
//
|
||||
// https://vk.com/dev/groups.create
|
||||
func (vk *VK) GroupsCreate(params Params) (response GroupsCreateResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.create", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsDeleteAddress groups.deleteAddress.
|
||||
//
|
||||
// https://vk.com/dev/groups.deleteAddress
|
||||
func (vk *VK) GroupsDeleteAddress(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.deleteAddress", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsDeleteCallbackServer callback API server from the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.deleteCallbackServer
|
||||
func (vk *VK) GroupsDeleteCallbackServer(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.deleteCallbackServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsDeleteLink allows to delete a link from the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.deleteLink
|
||||
func (vk *VK) GroupsDeleteLink(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.deleteLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsDisableOnline disables "online" status in the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.disableOnline
|
||||
func (vk *VK) GroupsDisableOnline(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.disableOnline", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsEdit edits a community.
|
||||
//
|
||||
// https://vk.com/dev/groups.edit
|
||||
func (vk *VK) GroupsEdit(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsEditAddressResponse struct.
|
||||
type GroupsEditAddressResponse object.GroupsAddress
|
||||
|
||||
// GroupsEditAddress groups.editAddress.
|
||||
//
|
||||
// https://vk.com/dev/groups.editAddress
|
||||
func (vk *VK) GroupsEditAddress(params Params) (response GroupsEditAddressResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.editAddress", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsEditCallbackServer edits Callback API server in the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.editCallbackServer
|
||||
func (vk *VK) GroupsEditCallbackServer(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.editCallbackServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsEditLink allows to edit a link in the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.editLink
|
||||
func (vk *VK) GroupsEditLink(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.editLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsEditManager allows to add, remove or edit the community manager .
|
||||
//
|
||||
// https://vk.com/dev/groups.editManager
|
||||
func (vk *VK) GroupsEditManager(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.editManager", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsEnableOnline enables "online" status in the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.enableOnline
|
||||
func (vk *VK) GroupsEnableOnline(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.enableOnline", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetResponse struct.
|
||||
type GroupsGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGet returns a list of the communities to which a user belongs.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/groups.get
|
||||
func (vk *VK) GroupsGet(params Params) (response GroupsGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.get", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetExtendedResponse struct.
|
||||
type GroupsGetExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsGroup `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetExtended returns a list of the communities to which a user belongs.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/groups.get
|
||||
func (vk *VK) GroupsGetExtended(params Params) (response GroupsGetExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.get", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetAddressesResponse struct.
|
||||
type GroupsGetAddressesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsAddress `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetAddresses groups.getAddresses.
|
||||
//
|
||||
// https://vk.com/dev/groups.getAddresses
|
||||
func (vk *VK) GroupsGetAddresses(params Params) (response GroupsGetAddressesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getAddresses", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetBannedResponse struct.
|
||||
type GroupsGetBannedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsOwnerXtrBanInfo `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetBanned returns a list of users on a community blacklist.
|
||||
//
|
||||
// https://vk.com/dev/groups.getBanned
|
||||
func (vk *VK) GroupsGetBanned(params Params) (response GroupsGetBannedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getBanned", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetByIDResponse struct.
|
||||
type GroupsGetByIDResponse []object.GroupsGroup
|
||||
|
||||
// GroupsGetByID returns information about communities by their IDs.
|
||||
//
|
||||
// https://vk.com/dev/groups.getById
|
||||
func (vk *VK) GroupsGetByID(params Params) (response GroupsGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetCallbackConfirmationCodeResponse struct.
|
||||
type GroupsGetCallbackConfirmationCodeResponse struct {
|
||||
Code string `json:"code"`
|
||||
}
|
||||
|
||||
// GroupsGetCallbackConfirmationCode returns Callback API confirmation code for the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.getCallbackConfirmationCode
|
||||
func (vk *VK) GroupsGetCallbackConfirmationCode(params Params) (
|
||||
response GroupsGetCallbackConfirmationCodeResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("groups.getCallbackConfirmationCode", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetCallbackServersResponse struct.
|
||||
type GroupsGetCallbackServersResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsCallbackServer `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetCallbackServers receives a list of Callback API servers from the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.getCallbackServers
|
||||
func (vk *VK) GroupsGetCallbackServers(params Params) (response GroupsGetCallbackServersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getCallbackServers", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetCallbackSettingsResponse struct.
|
||||
type GroupsGetCallbackSettingsResponse object.GroupsCallbackSettings
|
||||
|
||||
// GroupsGetCallbackSettings returns Callback API notifications settings.
|
||||
//
|
||||
// BUG(VK): MessageEdit always 0 https://vk.com/bugtracker?act=show&id=86762
|
||||
//
|
||||
// https://vk.com/dev/groups.getCallbackSettings
|
||||
func (vk *VK) GroupsGetCallbackSettings(params Params) (response GroupsGetCallbackSettingsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getCallbackSettings", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetCatalogResponse struct.
|
||||
type GroupsGetCatalogResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsGroup `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetCatalog returns communities list for a catalog category.
|
||||
//
|
||||
// https://vk.com/dev/groups.getCatalog
|
||||
func (vk *VK) GroupsGetCatalog(params Params) (response GroupsGetCatalogResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getCatalog", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetCatalogInfoResponse struct.
|
||||
type GroupsGetCatalogInfoResponse struct {
|
||||
Enabled object.BaseBoolInt `json:"enabled"`
|
||||
Categories []object.GroupsGroupCategory `json:"categories"`
|
||||
}
|
||||
|
||||
// GroupsGetCatalogInfo returns categories list for communities catalog.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/groups.getCatalogInfo
|
||||
func (vk *VK) GroupsGetCatalogInfo(params Params) (response GroupsGetCatalogInfoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getCatalogInfo", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetCatalogInfoExtendedResponse struct.
|
||||
type GroupsGetCatalogInfoExtendedResponse struct {
|
||||
Enabled object.BaseBoolInt `json:"enabled"`
|
||||
Categories []object.GroupsGroupCategoryFull `json:"categories"`
|
||||
}
|
||||
|
||||
// GroupsGetCatalogInfoExtended returns categories list for communities catalog.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/groups.getCatalogInfo
|
||||
func (vk *VK) GroupsGetCatalogInfoExtended(params Params) (response GroupsGetCatalogInfoExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getCatalogInfo", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetInvitedUsersResponse struct.
|
||||
type GroupsGetInvitedUsersResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetInvitedUsers returns invited users list of a community.
|
||||
//
|
||||
// https://vk.com/dev/groups.getInvitedUsers
|
||||
func (vk *VK) GroupsGetInvitedUsers(params Params) (response GroupsGetInvitedUsersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getInvitedUsers", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetInvitesResponse struct.
|
||||
type GroupsGetInvitesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsGroupXtrInvitedBy `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetInvites returns a list of invitations to join communities and events.
|
||||
//
|
||||
// https://vk.com/dev/groups.getInvites
|
||||
func (vk *VK) GroupsGetInvites(params Params) (response GroupsGetInvitesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getInvites", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetInvitesExtendedResponse struct.
|
||||
type GroupsGetInvitesExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsGroupXtrInvitedBy `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// GroupsGetInvitesExtended returns a list of invitations to join communities and events.
|
||||
//
|
||||
// https://vk.com/dev/groups.getInvites
|
||||
func (vk *VK) GroupsGetInvitesExtended(params Params) (response GroupsGetInvitesExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getInvites", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetLongPollServerResponse struct.
|
||||
type GroupsGetLongPollServerResponse object.GroupsLongPollServer
|
||||
|
||||
// GroupsGetLongPollServer returns data for Bots Long Poll API connection.
|
||||
//
|
||||
// https://vk.com/dev/groups.getLongPollServer
|
||||
func (vk *VK) GroupsGetLongPollServer(params Params) (response GroupsGetLongPollServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getLongPollServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetLongPollSettingsResponse struct.
|
||||
type GroupsGetLongPollSettingsResponse object.GroupsLongPollSettings
|
||||
|
||||
// GroupsGetLongPollSettings returns Bots Long Poll API settings.
|
||||
//
|
||||
// https://vk.com/dev/groups.getLongPollSettings
|
||||
func (vk *VK) GroupsGetLongPollSettings(params Params) (response GroupsGetLongPollSettingsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getLongPollSettings", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetMembersResponse struct.
|
||||
type GroupsGetMembersResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetMembers returns a list of community members.
|
||||
//
|
||||
// https://vk.com/dev/groups.getMembers
|
||||
func (vk *VK) GroupsGetMembers(params Params) (response GroupsGetMembersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getMembers", &response, params, Params{"filter": ""})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetMembersFieldsResponse struct.
|
||||
type GroupsGetMembersFieldsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetMembersFields returns a list of community members.
|
||||
//
|
||||
// https://vk.com/dev/groups.getMembers
|
||||
func (vk *VK) GroupsGetMembersFields(params Params) (response GroupsGetMembersFieldsResponse, err error) {
|
||||
reqParams := make(Params)
|
||||
if v, prs := params["fields"]; v == "" || !prs {
|
||||
reqParams["fields"] = "id"
|
||||
}
|
||||
|
||||
err = vk.RequestUnmarshal("groups.getMembers", &response, params, reqParams)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetMembersFilterManagersResponse struct.
|
||||
type GroupsGetMembersFilterManagersResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsMemberRoleXtrUsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetMembersFilterManagers returns a list of community members.
|
||||
//
|
||||
// filter=managers
|
||||
//
|
||||
// https://vk.com/dev/groups.getMembers
|
||||
func (vk *VK) GroupsGetMembersFilterManagers(params Params) (
|
||||
response GroupsGetMembersFilterManagersResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("groups.getMembers", &response, params, Params{"filter": "managers"})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetOnlineStatusResponse struct.
|
||||
type GroupsGetOnlineStatusResponse object.GroupsOnlineStatus
|
||||
|
||||
// GroupsGetOnlineStatus returns a community's online status.
|
||||
//
|
||||
// https://vk.com/dev/groups.getOnlineStatus
|
||||
func (vk *VK) GroupsGetOnlineStatus(params Params) (response GroupsGetOnlineStatusResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getOnlineStatus", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetRequestsResponse struct.
|
||||
type GroupsGetRequestsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetRequests returns a list of requests to the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.getRequests
|
||||
func (vk *VK) GroupsGetRequests(params Params) (response GroupsGetRequestsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getRequests", &response, params, Params{"fields": ""})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetRequestsFieldsResponse struct.
|
||||
type GroupsGetRequestsFieldsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsGetRequestsFields returns a list of requests to the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.getRequests
|
||||
func (vk *VK) GroupsGetRequestsFields(params Params) (response GroupsGetRequestsFieldsResponse, err error) {
|
||||
reqParams := make(Params)
|
||||
if v, prs := params["fields"]; v == "" || !prs {
|
||||
reqParams["fields"] = "id"
|
||||
}
|
||||
|
||||
err = vk.RequestUnmarshal("groups.getRequests", &response, params, reqParams)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetSettingsResponse struct.
|
||||
type GroupsGetSettingsResponse object.GroupsGroupSettings
|
||||
|
||||
// GroupsGetSettings returns community settings.
|
||||
//
|
||||
// https://vk.com/dev/groups.getSettings
|
||||
func (vk *VK) GroupsGetSettings(params Params) (response GroupsGetSettingsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getSettings", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetTagListResponse struct.
|
||||
type GroupsGetTagListResponse []object.GroupsTag
|
||||
|
||||
// GroupsGetTagList returns community tags list.
|
||||
//
|
||||
// https://vk.com/dev/groups.getTagList
|
||||
func (vk *VK) GroupsGetTagList(params Params) (response GroupsGetTagListResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getTagList", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsGetTokenPermissionsResponse struct.
|
||||
type GroupsGetTokenPermissionsResponse object.GroupsTokenPermissions
|
||||
|
||||
// GroupsGetTokenPermissions returns permissions scope for the community's access_token.
|
||||
//
|
||||
// https://vk.com/dev/groups.getTokenPermissions
|
||||
func (vk *VK) GroupsGetTokenPermissions(params Params) (response GroupsGetTokenPermissionsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.getTokenPermissions", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsInvite allows to invite friends to the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.invite
|
||||
func (vk *VK) GroupsInvite(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.invite", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsIsMember returns information specifying whether a user is a member of a community.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/groups.isMember
|
||||
func (vk *VK) GroupsIsMember(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.isMember", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsIsMemberExtendedResponse struct.
|
||||
type GroupsIsMemberExtendedResponse struct {
|
||||
Invitation object.BaseBoolInt `json:"invitation"` // Information whether user has been invited to the group
|
||||
Member object.BaseBoolInt `json:"member"` // Information whether user is a member of the group
|
||||
Request object.BaseBoolInt `json:"request"` // Information whether user has send request to the group
|
||||
CanInvite object.BaseBoolInt `json:"can_invite"` // Information whether user can be invite
|
||||
CanRecall object.BaseBoolInt `json:"can_recall"` // Information whether user's invite to the group can be recalled
|
||||
}
|
||||
|
||||
// GroupsIsMemberExtended returns information specifying whether a user is a member of a community.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/groups.isMember
|
||||
func (vk *VK) GroupsIsMemberExtended(params Params) (response GroupsIsMemberExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.isMember", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsIsMemberUserIDsExtendedResponse struct.
|
||||
type GroupsIsMemberUserIDsExtendedResponse []object.GroupsMemberStatusFull
|
||||
|
||||
// GroupsIsMemberUserIDsExtended returns information specifying whether a user is a member of a community.
|
||||
//
|
||||
// extended=1
|
||||
// need user_ids
|
||||
//
|
||||
// https://vk.com/dev/groups.isMember
|
||||
func (vk *VK) GroupsIsMemberUserIDsExtended(params Params) (response GroupsIsMemberUserIDsExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.isMember", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsIsMemberUserIDsResponse struct.
|
||||
type GroupsIsMemberUserIDsResponse []object.GroupsMemberStatus
|
||||
|
||||
// GroupsIsMemberUserIDs returns information specifying whether a user is a member of a community.
|
||||
//
|
||||
// extended=0
|
||||
// need user_ids
|
||||
//
|
||||
// https://vk.com/dev/groups.isMember
|
||||
func (vk *VK) GroupsIsMemberUserIDs(params Params) (response GroupsIsMemberUserIDsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.isMember", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsJoin with this method you can join the group or public page, and also confirm your participation in an event.
|
||||
//
|
||||
// https://vk.com/dev/groups.join
|
||||
func (vk *VK) GroupsJoin(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.join", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsLeave with this method you can leave a group, public page, or event.
|
||||
//
|
||||
// https://vk.com/dev/groups.leave
|
||||
func (vk *VK) GroupsLeave(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.leave", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsRemoveUser removes a user from the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.removeUser
|
||||
func (vk *VK) GroupsRemoveUser(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.removeUser", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsReorderLink allows to reorder links in the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.reorderLink
|
||||
func (vk *VK) GroupsReorderLink(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.reorderLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsSearchResponse struct.
|
||||
type GroupsSearchResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsGroup `json:"items"`
|
||||
}
|
||||
|
||||
// GroupsSearch returns a list of communities matching the search criteria.
|
||||
//
|
||||
// https://vk.com/dev/groups.search
|
||||
func (vk *VK) GroupsSearch(params Params) (response GroupsSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("groups.search", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsSetCallbackSettings allow to set notifications settings for Callback API.
|
||||
//
|
||||
// https://vk.com/dev/groups.setCallbackSettings
|
||||
func (vk *VK) GroupsSetCallbackSettings(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.setCallbackSettings", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsSetLongPollSettings allows to set Bots Long Poll API settings in the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.setLongPollSettings
|
||||
func (vk *VK) GroupsSetLongPollSettings(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.setLongPollSettings", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsSetSettings sets community settings.
|
||||
//
|
||||
// https://vk.com/dev/groups.setSettings
|
||||
func (vk *VK) GroupsSetSettings(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.setSettings", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsSetUserNote allows to create or edit a note about a user as part
|
||||
// of the user's correspondence with the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.setUserNote
|
||||
func (vk *VK) GroupsSetUserNote(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.setUserNote", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsTagAdd allows to add a new tag to the community.
|
||||
//
|
||||
// https://vk.com/dev/groups.tagAdd
|
||||
func (vk *VK) GroupsTagAdd(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.tagAdd", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsTagBind allows to "bind" and "unbind" community tags to conversations.
|
||||
//
|
||||
// https://vk.com/dev/groups.tagBind
|
||||
func (vk *VK) GroupsTagBind(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.tagBind", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsTagDelete allows to remove a community tag
|
||||
//
|
||||
// The remote tag will be automatically "unbind" from all conversations to
|
||||
// which it was "bind" earlier.
|
||||
//
|
||||
// https://vk.com/dev/groups.tagDelete
|
||||
func (vk *VK) GroupsTagDelete(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.tagDelete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsTagUpdate allows to change an existing tag.
|
||||
//
|
||||
// https://vk.com/dev/groups.tagUpdate
|
||||
func (vk *VK) GroupsTagUpdate(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.tagUpdate", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsToggleMarket method.
|
||||
//
|
||||
// https://vk.com/dev/groups.toggleMarket
|
||||
func (vk *VK) GroupsToggleMarket(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.toggleMarket", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// GroupsUnban groups.unban.
|
||||
//
|
||||
// https://vk.com/dev/groups.unban
|
||||
func (vk *VK) GroupsUnban(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("groups.unban", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,89 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// LeadFormsCreateResponse struct.
|
||||
type LeadFormsCreateResponse struct {
|
||||
FormID int `json:"form_id"`
|
||||
URL string `json:"url"`
|
||||
}
|
||||
|
||||
// LeadFormsCreate leadForms.create.
|
||||
//
|
||||
// https://vk.com/dev/leadForms.create
|
||||
func (vk *VK) LeadFormsCreate(params Params) (response LeadFormsCreateResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leadForms.create", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadFormsDeleteResponse struct.
|
||||
type LeadFormsDeleteResponse struct {
|
||||
FormID int `json:"form_id"`
|
||||
}
|
||||
|
||||
// LeadFormsDelete leadForms.delete.
|
||||
//
|
||||
// https://vk.com/dev/leadForms.delete
|
||||
func (vk *VK) LeadFormsDelete(params Params) (response LeadFormsDeleteResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leadForms.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadFormsGetResponse struct.
|
||||
type LeadFormsGetResponse object.LeadFormsForm
|
||||
|
||||
// LeadFormsGet leadForms.get.
|
||||
//
|
||||
// https://vk.com/dev/leadForms.get
|
||||
func (vk *VK) LeadFormsGet(params Params) (response LeadFormsGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leadForms.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadFormsGetLeadsResponse struct.
|
||||
type LeadFormsGetLeadsResponse struct {
|
||||
Leads []object.LeadFormsLead `json:"leads"`
|
||||
}
|
||||
|
||||
// LeadFormsGetLeads leadForms.getLeads.
|
||||
//
|
||||
// https://vk.com/dev/leadForms.getLeads
|
||||
func (vk *VK) LeadFormsGetLeads(params Params) (response LeadFormsGetLeadsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leadForms.getLeads", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadFormsGetUploadURL leadForms.getUploadURL.
|
||||
//
|
||||
// https://vk.com/dev/leadForms.getUploadURL
|
||||
func (vk *VK) LeadFormsGetUploadURL(params Params) (response string, err error) {
|
||||
err = vk.RequestUnmarshal("leadForms.getUploadURL", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadFormsListResponse struct.
|
||||
type LeadFormsListResponse []object.LeadFormsForm
|
||||
|
||||
// LeadFormsList leadForms.list.
|
||||
//
|
||||
// https://vk.com/dev/leadForms.list
|
||||
func (vk *VK) LeadFormsList(params Params) (response LeadFormsListResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leadForms.list", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadFormsUpdateResponse struct.
|
||||
type LeadFormsUpdateResponse struct {
|
||||
FormID int `json:"form_id"`
|
||||
URL string `json:"url"`
|
||||
}
|
||||
|
||||
// LeadFormsUpdate leadForms.update.
|
||||
//
|
||||
// https://vk.com/dev/leadForms.update
|
||||
func (vk *VK) LeadFormsUpdate(params Params) (response LeadFormsUpdateResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leadForms.update", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,74 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// LeadsCheckUserResponse struct.
|
||||
type LeadsCheckUserResponse object.LeadsChecked
|
||||
|
||||
// LeadsCheckUser checks if the user can start the lead.
|
||||
//
|
||||
// https://vk.com/dev/leads.checkUser
|
||||
func (vk *VK) LeadsCheckUser(params Params) (response LeadsCheckUserResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leads.checkUser", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadsCompleteResponse struct.
|
||||
type LeadsCompleteResponse object.LeadsComplete
|
||||
|
||||
// LeadsComplete completes the lead started by user.
|
||||
//
|
||||
// https://vk.com/dev/leads.complete
|
||||
func (vk *VK) LeadsComplete(params Params) (response LeadsCompleteResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leads.complete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadsGetStatsResponse struct.
|
||||
type LeadsGetStatsResponse object.LeadsLead
|
||||
|
||||
// LeadsGetStats returns lead stats data.
|
||||
//
|
||||
// https://vk.com/dev/leads.getStats
|
||||
func (vk *VK) LeadsGetStats(params Params) (response LeadsGetStatsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leads.getStats", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadsGetUsersResponse struct.
|
||||
type LeadsGetUsersResponse object.LeadsEntry
|
||||
|
||||
// LeadsGetUsers returns a list of last user actions for the offer.
|
||||
//
|
||||
// https://vk.com/dev/leads.getUsers
|
||||
func (vk *VK) LeadsGetUsers(params Params) (response LeadsGetUsersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leads.getUsers", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadsMetricHitResponse struct.
|
||||
type LeadsMetricHitResponse struct {
|
||||
Result object.BaseBoolInt `json:"result"` // Information whether request has been processed successfully
|
||||
RedirectLink string `json:"redirect_link"` // Redirect link
|
||||
}
|
||||
|
||||
// LeadsMetricHit counts the metric event.
|
||||
//
|
||||
// https://vk.com/dev/leads.metricHit
|
||||
func (vk *VK) LeadsMetricHit(params Params) (response LeadsMetricHitResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leads.metricHit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LeadsStartResponse struct.
|
||||
type LeadsStartResponse object.LeadsStart
|
||||
|
||||
// LeadsStart creates new session for the user passing the offer.
|
||||
//
|
||||
// https://vk.com/dev/leads.start
|
||||
func (vk *VK) LeadsStart(params Params) (response LeadsStartResponse, err error) {
|
||||
err = vk.RequestUnmarshal("leads.start", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,79 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// LikesAddResponse struct.
|
||||
type LikesAddResponse struct {
|
||||
Likes int `json:"likes"`
|
||||
}
|
||||
|
||||
// LikesAdd adds the specified object to the Likes list of the current user.
|
||||
//
|
||||
// https://vk.com/dev/likes.add
|
||||
func (vk *VK) LikesAdd(params Params) (response LikesAddResponse, err error) {
|
||||
err = vk.RequestUnmarshal("likes.add", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LikesDeleteResponse struct.
|
||||
type LikesDeleteResponse struct {
|
||||
Likes int `json:"likes"`
|
||||
}
|
||||
|
||||
// LikesDelete deletes the specified object from the Likes list of the current user.
|
||||
//
|
||||
// https://vk.com/dev/likes.delete
|
||||
func (vk *VK) LikesDelete(params Params) (response LikesDeleteResponse, err error) {
|
||||
err = vk.RequestUnmarshal("likes.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// LikesGetListResponse struct.
|
||||
type LikesGetListResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// LikesGetList likes.getList returns a list of IDs of users who added the specified object to their Likes list.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/likes.getList
|
||||
func (vk *VK) LikesGetList(params Params) (response LikesGetListResponse, err error) {
|
||||
err = vk.RequestUnmarshal("likes.getList", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// LikesGetListExtendedResponse struct.
|
||||
type LikesGetListExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// LikesGetListExtended likes.getList returns a list of IDs of users who added the specified object to their Likes list.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/likes.getList
|
||||
func (vk *VK) LikesGetListExtended(params Params) (response LikesGetListExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("likes.getList", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// LikesIsLikedResponse struct.
|
||||
type LikesIsLikedResponse struct {
|
||||
Liked object.BaseBoolInt `json:"liked"`
|
||||
Copied object.BaseBoolInt `json:"copied"`
|
||||
}
|
||||
|
||||
// LikesIsLiked checks for the object in the Likes list of the specified user.
|
||||
//
|
||||
// https://vk.com/dev/likes.isLiked
|
||||
func (vk *VK) LikesIsLiked(params Params) (response LikesIsLikedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("likes.isLiked", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,319 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// MarketAddResponse struct.
|
||||
type MarketAddResponse struct {
|
||||
MarketItemID int `json:"market_item_id"` // Item ID
|
||||
}
|
||||
|
||||
// MarketAdd adds a new item to the market.
|
||||
//
|
||||
// https://vk.com/dev/market.add
|
||||
func (vk *VK) MarketAdd(params Params) (response MarketAddResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.add", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketAddAlbumResponse struct.
|
||||
type MarketAddAlbumResponse struct {
|
||||
MarketAlbumID int `json:"market_album_id"` // Album ID
|
||||
}
|
||||
|
||||
// MarketAddAlbum creates new collection of items.
|
||||
//
|
||||
// https://vk.com/dev/market.addAlbum
|
||||
func (vk *VK) MarketAddAlbum(params Params) (response MarketAddAlbumResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.addAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketAddToAlbum adds an item to one or multiple collections.
|
||||
//
|
||||
// https://vk.com/dev/market.addToAlbum
|
||||
func (vk *VK) MarketAddToAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.addToAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketCreateComment creates a new comment for an item.
|
||||
//
|
||||
// https://vk.com/dev/market.createComment
|
||||
func (vk *VK) MarketCreateComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.createComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketDelete deletes an item.
|
||||
//
|
||||
// https://vk.com/dev/market.delete
|
||||
func (vk *VK) MarketDelete(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketDeleteAlbum deletes a collection of items.
|
||||
//
|
||||
// https://vk.com/dev/market.deleteAlbum
|
||||
func (vk *VK) MarketDeleteAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.deleteAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketDeleteComment deletes an item's comment.
|
||||
//
|
||||
// https://vk.com/dev/market.deleteComment
|
||||
func (vk *VK) MarketDeleteComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.deleteComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketEdit edits an item.
|
||||
//
|
||||
// https://vk.com/dev/market.edit
|
||||
func (vk *VK) MarketEdit(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketEditAlbum edits a collection of items.
|
||||
//
|
||||
// https://vk.com/dev/market.editAlbum
|
||||
func (vk *VK) MarketEditAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.editAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketEditComment changes item comment's text.
|
||||
//
|
||||
// https://vk.com/dev/market.editComment
|
||||
func (vk *VK) MarketEditComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.editComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketEditOrder edits an order.
|
||||
//
|
||||
// https://vk.com/dev/market.editOrder
|
||||
func (vk *VK) MarketEditOrder(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.editOrder", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetResponse struct.
|
||||
type MarketGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MarketMarketItem `json:"items"`
|
||||
}
|
||||
|
||||
// MarketGet returns items list for a community.
|
||||
//
|
||||
// https://vk.com/dev/market.get
|
||||
func (vk *VK) MarketGet(params Params) (response MarketGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetAlbumByIDResponse struct.
|
||||
type MarketGetAlbumByIDResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MarketMarketAlbum `json:"items"`
|
||||
}
|
||||
|
||||
// MarketGetAlbumByID returns items album's data.
|
||||
//
|
||||
// https://vk.com/dev/market.getAlbumById
|
||||
func (vk *VK) MarketGetAlbumByID(params Params) (response MarketGetAlbumByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.getAlbumById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetAlbumsResponse struct.
|
||||
type MarketGetAlbumsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MarketMarketAlbum `json:"items"`
|
||||
}
|
||||
|
||||
// MarketGetAlbums returns community's collections list.
|
||||
//
|
||||
// https://vk.com/dev/market.getAlbums
|
||||
func (vk *VK) MarketGetAlbums(params Params) (response MarketGetAlbumsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.getAlbums", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetByIDResponse struct.
|
||||
type MarketGetByIDResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MarketMarketItem `json:"items"`
|
||||
}
|
||||
|
||||
// MarketGetByID returns information about market items by their iDs.
|
||||
//
|
||||
// https://vk.com/dev/market.getById
|
||||
func (vk *VK) MarketGetByID(params Params) (response MarketGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.getById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetCategoriesResponse struct.
|
||||
type MarketGetCategoriesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MarketMarketCategory `json:"items"`
|
||||
}
|
||||
|
||||
// MarketGetCategories returns a list of market categories.
|
||||
//
|
||||
// https://vk.com/dev/market.getCategories
|
||||
func (vk *VK) MarketGetCategories(params Params) (response MarketGetCategoriesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.getCategories", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetCommentsResponse struct.
|
||||
type MarketGetCommentsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
}
|
||||
|
||||
// MarketGetComments returns comments list for an item.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/market.getComments
|
||||
func (vk *VK) MarketGetComments(params Params) (response MarketGetCommentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.getComments", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetCommentsExtendedResponse struct.
|
||||
type MarketGetCommentsExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MarketGetCommentsExtended returns comments list for an item.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/market.getComments
|
||||
func (vk *VK) MarketGetCommentsExtended(params Params) (response MarketGetCommentsExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.getComments", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetGroupOrdersResponse struct.
|
||||
type MarketGetGroupOrdersResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MarketOrder `json:"items"`
|
||||
}
|
||||
|
||||
// MarketGetGroupOrders returns community's orders list.
|
||||
//
|
||||
// https://vk.com/dev/market.getGroupOrders
|
||||
func (vk *VK) MarketGetGroupOrders(params Params) (response MarketGetGroupOrdersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.getGroupOrders", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetOrderByIDResponse struct.
|
||||
type MarketGetOrderByIDResponse struct {
|
||||
Order object.MarketOrder `json:"order"`
|
||||
}
|
||||
|
||||
// MarketGetOrderByID returns order by id.
|
||||
//
|
||||
// https://vk.com/dev/market.getOrderById
|
||||
func (vk *VK) MarketGetOrderByID(params Params) (response MarketGetOrderByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.getOrderById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketGetOrderItemsResponse struct.
|
||||
type MarketGetOrderItemsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MarketOrderItem `json:"items"`
|
||||
}
|
||||
|
||||
// MarketGetOrderItems returns items of an order.
|
||||
//
|
||||
// https://vk.com/dev/market.getOrderItems
|
||||
func (vk *VK) MarketGetOrderItems(params Params) (response MarketGetOrderItemsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.getOrderItems", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketRemoveFromAlbum removes an item from one or multiple collections.
|
||||
//
|
||||
// https://vk.com/dev/market.removeFromAlbum
|
||||
func (vk *VK) MarketRemoveFromAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.removeFromAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketReorderAlbums reorders the collections list.
|
||||
//
|
||||
// https://vk.com/dev/market.reorderAlbums
|
||||
func (vk *VK) MarketReorderAlbums(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.reorderAlbums", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketReorderItems changes item place in a collection.
|
||||
//
|
||||
// https://vk.com/dev/market.reorderItems
|
||||
func (vk *VK) MarketReorderItems(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.reorderItems", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketReport sends a complaint to the item.
|
||||
//
|
||||
// https://vk.com/dev/market.report
|
||||
func (vk *VK) MarketReport(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.report", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketReportComment sends a complaint to the item's comment.
|
||||
//
|
||||
// https://vk.com/dev/market.reportComment
|
||||
func (vk *VK) MarketReportComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.reportComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketRestore restores recently deleted item.
|
||||
//
|
||||
// https://vk.com/dev/market.restore
|
||||
func (vk *VK) MarketRestore(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.restore", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketRestoreComment restores a recently deleted comment.
|
||||
//
|
||||
// https://vk.com/dev/market.restoreComment
|
||||
func (vk *VK) MarketRestoreComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("market.restoreComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MarketSearchResponse struct.
|
||||
type MarketSearchResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MarketMarketItem `json:"items"`
|
||||
}
|
||||
|
||||
// MarketSearch searches market items in a community's catalog.
|
||||
//
|
||||
// https://vk.com/dev/market.search
|
||||
func (vk *VK) MarketSearch(params Params) (response MarketSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("market.search", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,616 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// MessagesAddChatUser adds a new user to a chat.
|
||||
//
|
||||
// https://vk.com/dev/messages.addChatUser
|
||||
func (vk *VK) MessagesAddChatUser(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.addChatUser", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesAllowMessagesFromGroup allows sending messages from community to the current user.
|
||||
//
|
||||
// https://vk.com/dev/messages.allowMessagesFromGroup
|
||||
func (vk *VK) MessagesAllowMessagesFromGroup(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.allowMessagesFromGroup", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesCreateChat creates a chat with several participants.
|
||||
//
|
||||
// https://vk.com/dev/messages.createChat
|
||||
func (vk *VK) MessagesCreateChat(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.createChat", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesDeleteResponse struct.
|
||||
type MessagesDeleteResponse map[string]int
|
||||
|
||||
// MessagesDelete deletes one or more messages.
|
||||
//
|
||||
// https://vk.com/dev/messages.delete
|
||||
func (vk *VK) MessagesDelete(params Params) (response MessagesDeleteResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesDeleteChatPhotoResponse struct.
|
||||
type MessagesDeleteChatPhotoResponse struct {
|
||||
MessageID int `json:"message_id"`
|
||||
Chat object.MessagesChat `json:"chat"`
|
||||
}
|
||||
|
||||
// MessagesDeleteChatPhoto deletes a chat's cover picture.
|
||||
//
|
||||
// https://vk.com/dev/messages.deleteChatPhoto
|
||||
func (vk *VK) MessagesDeleteChatPhoto(params Params) (response MessagesDeleteChatPhotoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.deleteChatPhoto", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesDeleteConversationResponse struct.
|
||||
type MessagesDeleteConversationResponse struct {
|
||||
LastDeletedID int `json:"last_deleted_id"` // Id of the last message, that was deleted
|
||||
}
|
||||
|
||||
// MessagesDeleteConversation deletes private messages in a conversation.
|
||||
//
|
||||
// https://vk.com/dev/messages.deleteConversation
|
||||
func (vk *VK) MessagesDeleteConversation(params Params) (response MessagesDeleteConversationResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.deleteConversation", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesDenyMessagesFromGroup denies sending message from community to the current user.
|
||||
//
|
||||
// https://vk.com/dev/messages.denyMessagesFromGroup
|
||||
func (vk *VK) MessagesDenyMessagesFromGroup(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.denyMessagesFromGroup", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesEdit edits the message.
|
||||
//
|
||||
// https://vk.com/dev/messages.edit
|
||||
func (vk *VK) MessagesEdit(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesEditChat edits the title of a chat.
|
||||
//
|
||||
// https://vk.com/dev/messages.editChat
|
||||
func (vk *VK) MessagesEditChat(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.editChat", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetByConversationMessageIDResponse struct.
|
||||
type MessagesGetByConversationMessageIDResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesMessage `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MessagesGetByConversationMessageID messages.getByConversationMessageId.
|
||||
//
|
||||
// https://vk.com/dev/messages.getByConversationMessageId
|
||||
func (vk *VK) MessagesGetByConversationMessageID(params Params) (
|
||||
response MessagesGetByConversationMessageIDResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("messages.getByConversationMessageId", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetByIDResponse struct.
|
||||
type MessagesGetByIDResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesMessage `json:"items"`
|
||||
}
|
||||
|
||||
// MessagesGetByID returns messages by their IDs.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/messages.getById
|
||||
func (vk *VK) MessagesGetByID(params Params) (response MessagesGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getById", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetByIDExtendedResponse struct.
|
||||
type MessagesGetByIDExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesMessage `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MessagesGetByIDExtended returns messages by their IDs.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/messages.getById
|
||||
func (vk *VK) MessagesGetByIDExtended(params Params) (response MessagesGetByIDExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getById", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetChatResponse struct.
|
||||
type MessagesGetChatResponse object.MessagesChat
|
||||
|
||||
// MessagesGetChat returns information about a chat.
|
||||
//
|
||||
// https://vk.com/dev/messages.getChat
|
||||
func (vk *VK) MessagesGetChat(params Params) (response MessagesGetChatResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getChat", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetChatChatIDsResponse struct.
|
||||
type MessagesGetChatChatIDsResponse []object.MessagesChat
|
||||
|
||||
// MessagesGetChatChatIDs returns information about a chat.
|
||||
//
|
||||
// https://vk.com/dev/messages.getChat
|
||||
func (vk *VK) MessagesGetChatChatIDs(params Params) (response MessagesGetChatChatIDsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getChat", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetChatPreviewResponse struct.
|
||||
type MessagesGetChatPreviewResponse struct {
|
||||
Preview object.MessagesChatPreview `json:"preview"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MessagesGetChatPreview allows to receive chat preview by the invitation link.
|
||||
//
|
||||
// https://vk.com/dev/messages.getChatPreview
|
||||
func (vk *VK) MessagesGetChatPreview(params Params) (response MessagesGetChatPreviewResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getChatPreview", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetConversationMembersResponse struct.
|
||||
type MessagesGetConversationMembersResponse struct {
|
||||
Items []struct {
|
||||
MemberID int `json:"member_id"`
|
||||
JoinDate int `json:"join_date"`
|
||||
InvitedBy int `json:"invited_by"`
|
||||
IsOwner object.BaseBoolInt `json:"is_owner,omitempty"`
|
||||
IsAdmin object.BaseBoolInt `json:"is_admin,omitempty"`
|
||||
CanKick object.BaseBoolInt `json:"can_kick,omitempty"`
|
||||
} `json:"items"`
|
||||
Count int `json:"count"`
|
||||
ChatRestrictions struct {
|
||||
OnlyAdminsInvite object.BaseBoolInt `json:"only_admins_invite"`
|
||||
OnlyAdminsEditPin object.BaseBoolInt `json:"only_admins_edit_pin"`
|
||||
OnlyAdminsEditInfo object.BaseBoolInt `json:"only_admins_edit_info"`
|
||||
AdminsPromoteUsers object.BaseBoolInt `json:"admins_promote_users"`
|
||||
} `json:"chat_restrictions"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MessagesGetConversationMembers returns a list of IDs of users participating in a conversation.
|
||||
//
|
||||
// https://vk.com/dev/messages.getConversationMembers
|
||||
func (vk *VK) MessagesGetConversationMembers(params Params) (
|
||||
response MessagesGetConversationMembersResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("messages.getConversationMembers", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetConversationsResponse struct.
|
||||
type MessagesGetConversationsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesConversationWithMessage `json:"items"`
|
||||
UnreadCount int `json:"unread_count"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MessagesGetConversations returns a list of conversations.
|
||||
//
|
||||
// https://vk.com/dev/messages.getConversations
|
||||
func (vk *VK) MessagesGetConversations(params Params) (response MessagesGetConversationsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getConversations", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetConversationsByIDResponse struct.
|
||||
type MessagesGetConversationsByIDResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesConversation `json:"items"`
|
||||
}
|
||||
|
||||
// MessagesGetConversationsByID returns conversations by their IDs.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/messages.getConversationsById
|
||||
func (vk *VK) MessagesGetConversationsByID(params Params) (response MessagesGetConversationsByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getConversationsById", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetConversationsByIDExtendedResponse struct.
|
||||
type MessagesGetConversationsByIDExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesConversation `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MessagesGetConversationsByIDExtended returns conversations by their IDs.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/messages.getConversationsById
|
||||
func (vk *VK) MessagesGetConversationsByIDExtended(params Params) (
|
||||
response MessagesGetConversationsByIDExtendedResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("messages.getConversationsById", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetHistoryResponse struct.
|
||||
type MessagesGetHistoryResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesMessage `json:"items"`
|
||||
|
||||
// extended=1
|
||||
object.ExtendedResponse
|
||||
|
||||
// extended=1
|
||||
Conversations []object.MessagesConversation `json:"conversations,omitempty"`
|
||||
|
||||
// Deprecated: use .Conversations.InRead
|
||||
InRead int `json:"in_read,omitempty"`
|
||||
// Deprecated: use .Conversations.OutRead
|
||||
OutRead int `json:"out_read,omitempty"`
|
||||
}
|
||||
|
||||
// MessagesGetHistory returns message history for the specified user or group chat.
|
||||
//
|
||||
// https://vk.com/dev/messages.getHistory
|
||||
func (vk *VK) MessagesGetHistory(params Params) (response MessagesGetHistoryResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getHistory", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetHistoryAttachmentsResponse struct.
|
||||
type MessagesGetHistoryAttachmentsResponse struct {
|
||||
Items []object.MessagesHistoryAttachment `json:"items"`
|
||||
NextFrom string `json:"next_from"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MessagesGetHistoryAttachments returns media files from the dialog or group chat.
|
||||
//
|
||||
// https://vk.com/dev/messages.getHistoryAttachments
|
||||
func (vk *VK) MessagesGetHistoryAttachments(params Params) (response MessagesGetHistoryAttachmentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getHistoryAttachments", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetImportantMessagesResponse struct.
|
||||
type MessagesGetImportantMessagesResponse struct {
|
||||
Messages struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesMessage `json:"items"`
|
||||
} `json:"messages"`
|
||||
Conversations []object.MessagesConversation `json:"conversations"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MessagesGetImportantMessages messages.getImportantMessages.
|
||||
//
|
||||
// https://vk.com/dev/messages.getImportantMessages
|
||||
func (vk *VK) MessagesGetImportantMessages(params Params) (response MessagesGetImportantMessagesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getImportantMessages", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetIntentUsersResponse struct.
|
||||
type MessagesGetIntentUsersResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
Profiles []object.MessagesMessage `json:"profiles,omitempty"`
|
||||
}
|
||||
|
||||
// MessagesGetIntentUsers method.
|
||||
//
|
||||
// https://vk.com/dev/messages.getIntentUsers
|
||||
func (vk *VK) MessagesGetIntentUsers(params Params) (response MessagesGetIntentUsersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getIntentUsers", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetInviteLinkResponse struct.
|
||||
type MessagesGetInviteLinkResponse struct {
|
||||
Link string `json:"link"`
|
||||
}
|
||||
|
||||
// MessagesGetInviteLink receives a link to invite a user to the chat.
|
||||
//
|
||||
// https://vk.com/dev/messages.getInviteLink
|
||||
func (vk *VK) MessagesGetInviteLink(params Params) (response MessagesGetInviteLinkResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getInviteLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetLastActivityResponse struct.
|
||||
type MessagesGetLastActivityResponse object.MessagesLastActivity
|
||||
|
||||
// MessagesGetLastActivity returns a user's current status and date of last activity.
|
||||
//
|
||||
// https://vk.com/dev/messages.getLastActivity
|
||||
func (vk *VK) MessagesGetLastActivity(params Params) (response MessagesGetLastActivityResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getLastActivity", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetLongPollHistoryResponse struct.
|
||||
type MessagesGetLongPollHistoryResponse struct {
|
||||
History [][]int `json:"history"`
|
||||
Groups []object.GroupsGroup `json:"groups"`
|
||||
Messages struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesMessage `json:"items"`
|
||||
} `json:"messages"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
// Chats struct {} `json:"chats"`
|
||||
NewPTS int `json:"new_pts"`
|
||||
FromPTS int `json:"from_pts"`
|
||||
More object.BaseBoolInt `json:"chats"`
|
||||
Conversations []object.MessagesConversation `json:"conversations"`
|
||||
}
|
||||
|
||||
// MessagesGetLongPollHistory returns updates in user's private messages.
|
||||
//
|
||||
// https://vk.com/dev/messages.getLongPollHistory
|
||||
func (vk *VK) MessagesGetLongPollHistory(params Params) (response MessagesGetLongPollHistoryResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getLongPollHistory", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesGetLongPollServerResponse struct.
|
||||
type MessagesGetLongPollServerResponse object.MessagesLongPollParams
|
||||
|
||||
// MessagesGetLongPollServer returns data required for connection to a Long Poll server.
|
||||
//
|
||||
// https://vk.com/dev/messages.getLongPollServer
|
||||
func (vk *VK) MessagesGetLongPollServer(params Params) (response MessagesGetLongPollServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.getLongPollServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesIsMessagesFromGroupAllowedResponse struct.
|
||||
type MessagesIsMessagesFromGroupAllowedResponse struct {
|
||||
IsAllowed object.BaseBoolInt `json:"is_allowed"`
|
||||
}
|
||||
|
||||
// MessagesIsMessagesFromGroupAllowed returns information whether
|
||||
// sending messages from the community to current user is allowed.
|
||||
//
|
||||
// https://vk.com/dev/messages.isMessagesFromGroupAllowed
|
||||
func (vk *VK) MessagesIsMessagesFromGroupAllowed(params Params) (
|
||||
response MessagesIsMessagesFromGroupAllowedResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("messages.isMessagesFromGroupAllowed", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesJoinChatByInviteLinkResponse struct.
|
||||
type MessagesJoinChatByInviteLinkResponse struct {
|
||||
ChatID int `json:"chat_id"`
|
||||
}
|
||||
|
||||
// MessagesJoinChatByInviteLink allows to enter the chat by the invitation link.
|
||||
//
|
||||
// https://vk.com/dev/messages.joinChatByInviteLink
|
||||
func (vk *VK) MessagesJoinChatByInviteLink(params Params) (response MessagesJoinChatByInviteLinkResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.joinChatByInviteLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesMarkAsAnsweredConversation messages.markAsAnsweredConversation.
|
||||
//
|
||||
// https://vk.com/dev/messages.markAsAnsweredConversation
|
||||
func (vk *VK) MessagesMarkAsAnsweredConversation(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.markAsAnsweredConversation", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesMarkAsImportantResponse struct.
|
||||
type MessagesMarkAsImportantResponse []int
|
||||
|
||||
// MessagesMarkAsImportant marks and un marks messages as important (starred).
|
||||
//
|
||||
// https://vk.com/dev/messages.markAsImportant
|
||||
func (vk *VK) MessagesMarkAsImportant(params Params) (response MessagesMarkAsImportantResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.markAsImportant", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesMarkAsImportantConversation messages.markAsImportantConversation.
|
||||
//
|
||||
// https://vk.com/dev/messages.markAsImportantConversation
|
||||
func (vk *VK) MessagesMarkAsImportantConversation(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.markAsImportantConversation", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesMarkAsRead marks messages as read.
|
||||
//
|
||||
// https://vk.com/dev/messages.markAsRead
|
||||
func (vk *VK) MessagesMarkAsRead(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.markAsRead", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesPinResponse struct.
|
||||
type MessagesPinResponse object.MessagesMessage
|
||||
|
||||
// MessagesPin messages.pin.
|
||||
//
|
||||
// https://vk.com/dev/messages.pin
|
||||
func (vk *VK) MessagesPin(params Params) (response MessagesPinResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.pin", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesRemoveChatUser allows the current user to leave a chat or, if the
|
||||
// current user started the chat, allows the user to remove another user from
|
||||
// the chat.
|
||||
//
|
||||
// https://vk.com/dev/messages.removeChatUser
|
||||
func (vk *VK) MessagesRemoveChatUser(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.removeChatUser", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesRestore restores a deleted message.
|
||||
//
|
||||
// https://vk.com/dev/messages.restore
|
||||
func (vk *VK) MessagesRestore(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.restore", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesSearchResponse struct.
|
||||
type MessagesSearchResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesMessage `json:"items"`
|
||||
object.ExtendedResponse
|
||||
Conversations []object.MessagesConversation `json:"conversations,omitempty"`
|
||||
}
|
||||
|
||||
// MessagesSearch returns a list of the current user's private messages that match search criteria.
|
||||
//
|
||||
// https://vk.com/dev/messages.search
|
||||
func (vk *VK) MessagesSearch(params Params) (response MessagesSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.search", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesSearchConversationsResponse struct.
|
||||
type MessagesSearchConversationsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.MessagesConversation `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// MessagesSearchConversations returns a list of conversations that match search criteria.
|
||||
//
|
||||
// https://vk.com/dev/messages.searchConversations
|
||||
func (vk *VK) MessagesSearchConversations(params Params) (response MessagesSearchConversationsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.searchConversations", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesSend sends a message.
|
||||
//
|
||||
// For user_ids or peer_ids parameters, use MessagesSendUserIDs.
|
||||
//
|
||||
// https://vk.com/dev/messages.send
|
||||
func (vk *VK) MessagesSend(params Params) (response int, err error) {
|
||||
reqParams := Params{
|
||||
"user_ids": "",
|
||||
"peer_ids": "",
|
||||
}
|
||||
|
||||
err = vk.RequestUnmarshal("messages.send", &response, params, reqParams)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesSendUserIDsResponse struct.
|
||||
//
|
||||
// TODO: v3 rename MessagesSendPeerIDsResponse - user_ids outdated.
|
||||
type MessagesSendUserIDsResponse []struct {
|
||||
PeerID int `json:"peer_id"`
|
||||
MessageID int `json:"message_id"`
|
||||
ConversationMessageID int `json:"conversation_message_id"`
|
||||
Error Error `json:"error"`
|
||||
}
|
||||
|
||||
// MessagesSendPeerIDs sends a message.
|
||||
//
|
||||
// need peer_ids;
|
||||
//
|
||||
// https://vk.com/dev/messages.send
|
||||
func (vk *VK) MessagesSendPeerIDs(params Params) (response MessagesSendUserIDsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.send", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesSendUserIDs sends a message.
|
||||
//
|
||||
// need user_ids or peer_ids;
|
||||
//
|
||||
// https://vk.com/dev/messages.send
|
||||
//
|
||||
// Deprecated: user_ids outdated, use MessagesSendPeerIDs.
|
||||
func (vk *VK) MessagesSendUserIDs(params Params) (response MessagesSendUserIDsResponse, err error) {
|
||||
return vk.MessagesSendPeerIDs(params)
|
||||
}
|
||||
|
||||
// MessagesSendMessageEventAnswer method.
|
||||
//
|
||||
// https://vk.com/dev/messages.sendMessageEventAnswer
|
||||
func (vk *VK) MessagesSendMessageEventAnswer(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.sendMessageEventAnswer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesSendSticker sends a message.
|
||||
//
|
||||
// https://vk.com/dev/messages.sendSticker
|
||||
func (vk *VK) MessagesSendSticker(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.sendSticker", &response, params, Params{"user_ids": ""})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesSetActivity changes the status of a user as typing in a conversation.
|
||||
//
|
||||
// https://vk.com/dev/messages.setActivity
|
||||
func (vk *VK) MessagesSetActivity(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.setActivity", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesSetChatPhotoResponse struct.
|
||||
type MessagesSetChatPhotoResponse struct {
|
||||
MessageID int `json:"message_id"`
|
||||
Chat object.MessagesChat `json:"chat"`
|
||||
}
|
||||
|
||||
// MessagesSetChatPhoto sets a previously-uploaded picture as the cover picture of a chat.
|
||||
//
|
||||
// https://vk.com/dev/messages.setChatPhoto
|
||||
func (vk *VK) MessagesSetChatPhoto(params Params) (response MessagesSetChatPhotoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("messages.setChatPhoto", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// MessagesUnpin messages.unpin.
|
||||
//
|
||||
// https://vk.com/dev/messages.unpin
|
||||
func (vk *VK) MessagesUnpin(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("messages.unpin", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,230 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// NewsfeedAddBan prevents news from specified users and communities
|
||||
// from appearing in the current user's newsfeed.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.addBan
|
||||
func (vk *VK) NewsfeedAddBan(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.addBan", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedDeleteBan allows news from previously banned users and
|
||||
// communities to be shown in the current user's newsfeed.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.deleteBan
|
||||
func (vk *VK) NewsfeedDeleteBan(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.deleteBan", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedDeleteList the method allows you to delete a custom news list.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.deleteList
|
||||
func (vk *VK) NewsfeedDeleteList(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.deleteList", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedGetResponse struct.
|
||||
type NewsfeedGetResponse struct {
|
||||
Items []object.NewsfeedNewsfeedItem `json:"items"`
|
||||
object.ExtendedResponse
|
||||
NextFrom string `json:"next_from"`
|
||||
}
|
||||
|
||||
// NewsfeedGet returns data required to show newsfeed for the current user.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.get
|
||||
func (vk *VK) NewsfeedGet(params Params) (response NewsfeedGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedGetBannedResponse struct.
|
||||
type NewsfeedGetBannedResponse struct {
|
||||
Members []int `json:"members"`
|
||||
Groups []int `json:"groups"`
|
||||
}
|
||||
|
||||
// NewsfeedGetBanned returns a list of users and communities banned from the current user's newsfeed.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.getBanned
|
||||
func (vk *VK) NewsfeedGetBanned(params Params) (response NewsfeedGetBannedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.getBanned", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedGetBannedExtendedResponse struct.
|
||||
type NewsfeedGetBannedExtendedResponse struct {
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// NewsfeedGetBannedExtended returns a list of users and communities banned from the current user's newsfeed.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.getBanned
|
||||
func (vk *VK) NewsfeedGetBannedExtended(params Params) (response NewsfeedGetBannedExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.getBanned", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedGetCommentsResponse struct.
|
||||
type NewsfeedGetCommentsResponse struct {
|
||||
Items []object.NewsfeedNewsfeedItem `json:"items"`
|
||||
object.ExtendedResponse
|
||||
NextFrom string `json:"next_from"`
|
||||
}
|
||||
|
||||
// NewsfeedGetComments returns a list of comments in the current user's newsfeed.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.getComments
|
||||
func (vk *VK) NewsfeedGetComments(params Params) (response NewsfeedGetCommentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.getComments", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedGetListsResponse struct.
|
||||
type NewsfeedGetListsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []struct {
|
||||
ID int `json:"id"`
|
||||
Title string `json:"title"`
|
||||
NoReposts int `json:"no_reposts"`
|
||||
SourceIDs []int `json:"source_ids"`
|
||||
} `json:"items"`
|
||||
}
|
||||
|
||||
// NewsfeedGetLists returns a list of newsfeeds followed by the current user.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.getLists
|
||||
func (vk *VK) NewsfeedGetLists(params Params) (response NewsfeedGetListsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.getLists", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedGetMentionsResponse struct.
|
||||
type NewsfeedGetMentionsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallpostToID `json:"items"`
|
||||
}
|
||||
|
||||
// NewsfeedGetMentions returns a list of posts on user walls in which the current user is mentioned.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.getMentions
|
||||
func (vk *VK) NewsfeedGetMentions(params Params) (response NewsfeedGetMentionsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.getMentions", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedGetRecommendedResponse struct.
|
||||
type NewsfeedGetRecommendedResponse struct {
|
||||
Items []object.NewsfeedNewsfeedItem `json:"items"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
Groups []object.GroupsGroup `json:"groups"`
|
||||
NextOffset string `json:"next_offset"`
|
||||
NextFrom string `json:"next_from"`
|
||||
}
|
||||
|
||||
// NewsfeedGetRecommended returns a list of newsfeeds recommended to the current user.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.getRecommended
|
||||
func (vk *VK) NewsfeedGetRecommended(params Params) (response NewsfeedGetRecommendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.getRecommended", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedGetSuggestedSourcesResponse struct.
|
||||
type NewsfeedGetSuggestedSourcesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.GroupsGroup `json:"items"` // FIXME: GroupsGroup + UsersUser
|
||||
}
|
||||
|
||||
// NewsfeedGetSuggestedSources returns communities and users that current user is suggested to follow.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.getSuggestedSources
|
||||
func (vk *VK) NewsfeedGetSuggestedSources(params Params) (response NewsfeedGetSuggestedSourcesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.getSuggestedSources", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedIgnoreItem hides an item from the newsfeed.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.ignoreItem
|
||||
func (vk *VK) NewsfeedIgnoreItem(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.ignoreItem", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedSaveList creates and edits user newsfeed lists.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.saveList
|
||||
func (vk *VK) NewsfeedSaveList(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.saveList", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedSearchResponse struct.
|
||||
type NewsfeedSearchResponse struct {
|
||||
Items []object.WallWallpost `json:"items"`
|
||||
Count int `json:"count"`
|
||||
TotalCount int `json:"total_count"`
|
||||
NextFrom string `json:"next_from"`
|
||||
}
|
||||
|
||||
// NewsfeedSearch returns search results by statuses.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.search
|
||||
func (vk *VK) NewsfeedSearch(params Params) (response NewsfeedSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.search", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedSearchExtendedResponse struct.
|
||||
type NewsfeedSearchExtendedResponse struct {
|
||||
Items []object.WallWallpost `json:"items"`
|
||||
Count int `json:"count"`
|
||||
TotalCount int `json:"total_count"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
Groups []object.GroupsGroup `json:"groups"`
|
||||
NextFrom string `json:"next_from"`
|
||||
}
|
||||
|
||||
// NewsfeedSearchExtended returns search results by statuses.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.search
|
||||
func (vk *VK) NewsfeedSearchExtended(params Params) (response NewsfeedSearchExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.search", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedUnignoreItem returns a hidden item to the newsfeed.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.unignoreItem
|
||||
func (vk *VK) NewsfeedUnignoreItem(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.unignoreItem", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NewsfeedUnsubscribe unsubscribes the current user from specified newsfeeds.
|
||||
//
|
||||
// https://vk.com/dev/newsfeed.unsubscribe
|
||||
func (vk *VK) NewsfeedUnsubscribe(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("newsfeed.unsubscribe", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,100 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// NotesAdd creates a new note for the current user.
|
||||
//
|
||||
// https://vk.com/dev/notes.add
|
||||
func (vk *VK) NotesAdd(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("notes.add", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotesCreateComment adds a new comment on a note.
|
||||
//
|
||||
// https://vk.com/dev/notes.createComment
|
||||
func (vk *VK) NotesCreateComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("notes.createComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotesDelete deletes a note of the current user.
|
||||
//
|
||||
// https://vk.com/dev/notes.delete
|
||||
func (vk *VK) NotesDelete(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("notes.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotesDeleteComment deletes a comment on a note.
|
||||
//
|
||||
// https://vk.com/dev/notes.deleteComment
|
||||
func (vk *VK) NotesDeleteComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("notes.deleteComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotesEdit edits a note of the current user.
|
||||
//
|
||||
// https://vk.com/dev/notes.edit
|
||||
func (vk *VK) NotesEdit(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("notes.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotesEditComment edits a comment on a note.
|
||||
//
|
||||
// https://vk.com/dev/notes.editComment
|
||||
func (vk *VK) NotesEditComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("notes.editComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotesGetResponse struct.
|
||||
type NotesGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.NotesNote `json:"items"`
|
||||
}
|
||||
|
||||
// NotesGet returns a list of notes created by a user.
|
||||
//
|
||||
// https://vk.com/dev/notes.get
|
||||
func (vk *VK) NotesGet(params Params) (response NotesGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("notes.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotesGetByIDResponse struct.
|
||||
type NotesGetByIDResponse object.NotesNote
|
||||
|
||||
// NotesGetByID returns a note by its ID.
|
||||
//
|
||||
// https://vk.com/dev/notes.getById
|
||||
func (vk *VK) NotesGetByID(params Params) (response NotesGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("notes.getById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotesGetCommentsResponse struct.
|
||||
type NotesGetCommentsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.NotesNoteComment `json:"items"`
|
||||
}
|
||||
|
||||
// NotesGetComments returns a list of comments on a note.
|
||||
//
|
||||
// https://vk.com/dev/notes.getComments
|
||||
func (vk *VK) NotesGetComments(params Params) (response NotesGetCommentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("notes.getComments", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotesRestoreComment restores a deleted comment on a note.
|
||||
//
|
||||
// https://vk.com/dev/notes.restoreComment
|
||||
func (vk *VK) NotesRestoreComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("notes.restoreComment", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,54 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// NotificationsGetResponse struct.
|
||||
type NotificationsGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.NotificationsNotification `json:"items"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
Groups []object.GroupsGroup `json:"groups"`
|
||||
Photos []object.PhotosPhoto `json:"photos"`
|
||||
Videos []object.VideoVideo `json:"videos"`
|
||||
Apps []object.AppsApp `json:"apps"`
|
||||
LastViewed int `json:"last_viewed"`
|
||||
NextFrom string `json:"next_from"`
|
||||
TTL int `json:"ttl"`
|
||||
}
|
||||
|
||||
// NotificationsGet returns a list of notifications about other users' feedback to the current user's wall posts.
|
||||
//
|
||||
// https://vk.com/dev/notifications.get
|
||||
func (vk *VK) NotificationsGet(params Params) (response NotificationsGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("notifications.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotificationsMarkAsViewed resets the counter of new notifications
|
||||
// about other users' feedback to the current user's wall posts.
|
||||
//
|
||||
// https://vk.com/dev/notifications.markAsViewed
|
||||
func (vk *VK) NotificationsMarkAsViewed(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("notifications.markAsViewed", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// NotificationsSendMessageResponse struct.
|
||||
type NotificationsSendMessageResponse []struct {
|
||||
UserID int `json:"user_id"`
|
||||
Status object.BaseBoolInt `json:"status"`
|
||||
Error struct {
|
||||
Code int `json:"code"`
|
||||
Description string `json:"description"`
|
||||
} `json:"error"`
|
||||
}
|
||||
|
||||
// NotificationsSendMessage sends notification to the VK Apps user.
|
||||
//
|
||||
// https://vk.com/dev/notifications.sendMessage
|
||||
func (vk *VK) NotificationsSendMessage(params Params) (response NotificationsSendMessageResponse, err error) {
|
||||
err = vk.RequestUnmarshal("notifications.sendMessage", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,90 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// OrdersCancelSubscription allows to cancel subscription.
|
||||
//
|
||||
// https://vk.com/dev/orders.cancelSubscription
|
||||
func (vk *VK) OrdersCancelSubscription(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("orders.cancelSubscription", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// OrdersChangeStateResponse struct.
|
||||
type OrdersChangeStateResponse string // New state
|
||||
|
||||
// OrdersChangeState changes order status.
|
||||
//
|
||||
// https://vk.com/dev/orders.changeState
|
||||
func (vk *VK) OrdersChangeState(params Params) (response OrdersChangeStateResponse, err error) {
|
||||
err = vk.RequestUnmarshal("orders.changeState", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// OrdersGetResponse struct.
|
||||
type OrdersGetResponse []object.OrdersOrder
|
||||
|
||||
// OrdersGet returns a list of orders.
|
||||
//
|
||||
// https://vk.com/dev/orders.get
|
||||
func (vk *VK) OrdersGet(params Params) (response OrdersGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("orders.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// OrdersGetAmountResponse struct.
|
||||
type OrdersGetAmountResponse []object.OrdersAmount
|
||||
|
||||
// OrdersGetAmount returns the cost of votes in the user's consent.
|
||||
//
|
||||
// https://vk.com/dev/orders.getAmount
|
||||
func (vk *VK) OrdersGetAmount(params Params) (response OrdersGetAmountResponse, err error) {
|
||||
err = vk.RequestUnmarshal("orders.getAmount", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// OrdersGetByIDResponse struct.
|
||||
type OrdersGetByIDResponse []object.OrdersOrder
|
||||
|
||||
// OrdersGetByID returns information about orders by their IDs.
|
||||
//
|
||||
// https://vk.com/dev/orders.getByID
|
||||
func (vk *VK) OrdersGetByID(params Params) (response OrdersGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("orders.getById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// OrdersGetUserSubscriptionByIDResponse struct.
|
||||
type OrdersGetUserSubscriptionByIDResponse object.OrdersSubscription
|
||||
|
||||
// OrdersGetUserSubscriptionByID allows to get subscription by its ID.
|
||||
//
|
||||
// https://vk.com/dev/orders.getUserSubscriptionById
|
||||
func (vk *VK) OrdersGetUserSubscriptionByID(params Params) (response OrdersGetUserSubscriptionByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("orders.getUserSubscriptionById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// OrdersGetUserSubscriptionsResponse struct.
|
||||
type OrdersGetUserSubscriptionsResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.OrdersSubscription `json:"items"`
|
||||
}
|
||||
|
||||
// OrdersGetUserSubscriptions allows to get user's active subscriptions.
|
||||
//
|
||||
// https://vk.com/dev/orders.getUserSubscriptions
|
||||
func (vk *VK) OrdersGetUserSubscriptions(params Params) (response OrdersGetUserSubscriptionsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("orders.getUserSubscriptions", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// OrdersUpdateSubscription allows to update subscription price.
|
||||
//
|
||||
// https://vk.com/dev/orders.updateSubscription
|
||||
func (vk *VK) OrdersUpdateSubscription(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("orders.updateSubscription", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,81 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// PagesClearCache allows to clear the cache of particular external pages which may be attached to VK posts.
|
||||
//
|
||||
// https://vk.com/dev/pages.clearCache
|
||||
func (vk *VK) PagesClearCache(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("pages.clearCache", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PagesGetResponse struct.
|
||||
type PagesGetResponse object.PagesWikipageFull
|
||||
|
||||
// PagesGet returns information about a wiki page.
|
||||
//
|
||||
// https://vk.com/dev/pages.get
|
||||
func (vk *VK) PagesGet(params Params) (response PagesGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("pages.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PagesGetHistoryResponse struct.
|
||||
type PagesGetHistoryResponse []object.PagesWikipageHistory
|
||||
|
||||
// PagesGetHistory returns a list of all previous versions of a wiki page.
|
||||
//
|
||||
// https://vk.com/dev/pages.getHistory
|
||||
func (vk *VK) PagesGetHistory(params Params) (response PagesGetHistoryResponse, err error) {
|
||||
err = vk.RequestUnmarshal("pages.getHistory", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PagesGetTitlesResponse struct.
|
||||
type PagesGetTitlesResponse []object.PagesWikipageFull
|
||||
|
||||
// PagesGetTitles returns a list of wiki pages in a group.
|
||||
//
|
||||
// https://vk.com/dev/pages.getTitles
|
||||
func (vk *VK) PagesGetTitles(params Params) (response PagesGetTitlesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("pages.getTitles", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PagesGetVersionResponse struct.
|
||||
type PagesGetVersionResponse object.PagesWikipageFull
|
||||
|
||||
// PagesGetVersion returns the text of one of the previous versions of a wiki page.
|
||||
//
|
||||
// https://vk.com/dev/pages.getVersion
|
||||
func (vk *VK) PagesGetVersion(params Params) (response PagesGetVersionResponse, err error) {
|
||||
err = vk.RequestUnmarshal("pages.getVersion", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PagesParseWiki returns HTML representation of the wiki markup.
|
||||
//
|
||||
// https://vk.com/dev/pages.parseWiki
|
||||
func (vk *VK) PagesParseWiki(params Params) (response string, err error) {
|
||||
err = vk.RequestUnmarshal("pages.parseWiki", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PagesSave saves the text of a wiki page.
|
||||
//
|
||||
// https://vk.com/dev/pages.save
|
||||
func (vk *VK) PagesSave(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("pages.save", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PagesSaveAccess saves modified read and edit access settings for a wiki page.
|
||||
//
|
||||
// https://vk.com/dev/pages.saveAccess
|
||||
func (vk *VK) PagesSaveAccess(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("pages.saveAccess", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,613 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// PhotosConfirmTag confirms a tag on a photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.confirmTag
|
||||
func (vk *VK) PhotosConfirmTag(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.confirmTag", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosCopy allows to copy a photo to the "Saved photos" album.
|
||||
//
|
||||
// https://vk.com/dev/photos.copy
|
||||
func (vk *VK) PhotosCopy(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.copy", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosCreateAlbumResponse struct.
|
||||
type PhotosCreateAlbumResponse object.PhotosPhotoAlbumFull
|
||||
|
||||
// PhotosCreateAlbum creates an empty photo album.
|
||||
//
|
||||
// https://vk.com/dev/photos.createAlbum
|
||||
func (vk *VK) PhotosCreateAlbum(params Params) (response PhotosCreateAlbumResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.createAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosCreateComment adds a new comment on the photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.createComment
|
||||
func (vk *VK) PhotosCreateComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.createComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosDelete deletes a photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.delete
|
||||
func (vk *VK) PhotosDelete(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosDeleteAlbum deletes a photo album belonging to the current user.
|
||||
//
|
||||
// https://vk.com/dev/photos.deleteAlbum
|
||||
func (vk *VK) PhotosDeleteAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.deleteAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosDeleteComment deletes a comment on the photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.deleteComment
|
||||
func (vk *VK) PhotosDeleteComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.deleteComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosEdit edits the caption of a photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.edit
|
||||
func (vk *VK) PhotosEdit(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosEditAlbum edits information about a photo album.
|
||||
//
|
||||
// https://vk.com/dev/photos.editAlbum
|
||||
func (vk *VK) PhotosEditAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.editAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosEditComment edits a comment on a photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.editComment
|
||||
func (vk *VK) PhotosEditComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.editComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetResponse struct.
|
||||
type PhotosGetResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosPhoto `json:"items"`
|
||||
}
|
||||
|
||||
// PhotosGet returns a list of a user's or community's photos.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/photos.get
|
||||
func (vk *VK) PhotosGet(params Params) (response PhotosGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.get", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetExtendedResponse struct.
|
||||
type PhotosGetExtendedResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosPhotoFull `json:"items"`
|
||||
}
|
||||
|
||||
// PhotosGetExtended returns a list of a user's or community's photos.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/photos.get
|
||||
func (vk *VK) PhotosGetExtended(params Params) (response PhotosGetExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.get", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetAlbumsResponse struct.
|
||||
type PhotosGetAlbumsResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosPhotoAlbumFull `json:"items"`
|
||||
}
|
||||
|
||||
// PhotosGetAlbums returns a list of a user's or community's photo albums.
|
||||
//
|
||||
// https://vk.com/dev/photos.getAlbums
|
||||
func (vk *VK) PhotosGetAlbums(params Params) (response PhotosGetAlbumsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getAlbums", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetAlbumsCount returns the number of photo albums belonging to a user or community.
|
||||
//
|
||||
// https://vk.com/dev/photos.getAlbumsCount
|
||||
func (vk *VK) PhotosGetAlbumsCount(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getAlbumsCount", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetAllResponse struct.
|
||||
type PhotosGetAllResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosPhotoXtrRealOffset `json:"items"`
|
||||
More object.BaseBoolInt `json:"more"` // Information whether next page is presented
|
||||
}
|
||||
|
||||
// PhotosGetAll returns a list of photos belonging to a user or community, in reverse chronological order.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/photos.getAll
|
||||
func (vk *VK) PhotosGetAll(params Params) (response PhotosGetAllResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getAll", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetAllExtendedResponse struct.
|
||||
type PhotosGetAllExtendedResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosPhotoFullXtrRealOffset `json:"items"`
|
||||
More object.BaseBoolInt `json:"more"` // Information whether next page is presented
|
||||
}
|
||||
|
||||
// PhotosGetAllExtended returns a list of photos belonging to a user or community, in reverse chronological order.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/photos.getAll
|
||||
func (vk *VK) PhotosGetAllExtended(params Params) (response PhotosGetAllExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getAll", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetAllCommentsResponse struct.
|
||||
type PhotosGetAllCommentsResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosCommentXtrPid `json:"items"`
|
||||
}
|
||||
|
||||
// PhotosGetAllComments returns a list of comments on a specific
|
||||
// photo album or all albums of the user sorted in reverse chronological order.
|
||||
//
|
||||
// https://vk.com/dev/photos.getAllComments
|
||||
func (vk *VK) PhotosGetAllComments(params Params) (response PhotosGetAllCommentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getAllComments", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetByIDResponse struct.
|
||||
type PhotosGetByIDResponse []object.PhotosPhoto
|
||||
|
||||
// PhotosGetByID returns information about photos by their IDs.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/photos.getById
|
||||
func (vk *VK) PhotosGetByID(params Params) (response PhotosGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getById", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetByIDExtendedResponse struct.
|
||||
type PhotosGetByIDExtendedResponse []object.PhotosPhotoFull
|
||||
|
||||
// PhotosGetByIDExtended returns information about photos by their IDs.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/photos.getById
|
||||
func (vk *VK) PhotosGetByIDExtended(params Params) (response PhotosGetByIDExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getById", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetChatUploadServerResponse struct.
|
||||
type PhotosGetChatUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// PhotosGetChatUploadServer returns an upload link for chat cover pictures.
|
||||
//
|
||||
// https://vk.com/dev/photos.getChatUploadServer
|
||||
func (vk *VK) PhotosGetChatUploadServer(params Params) (response PhotosGetChatUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getChatUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetCommentsResponse struct.
|
||||
type PhotosGetCommentsResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
RealOffset int `json:"real_offset"` // Real offset of the comments
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
}
|
||||
|
||||
// PhotosGetComments returns a list of comments on a photo.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/photos.getComments
|
||||
func (vk *VK) PhotosGetComments(params Params) (response PhotosGetCommentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getComments", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetCommentsExtendedResponse struct.
|
||||
type PhotosGetCommentsExtendedResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
RealOffset int `json:"real_offset"` // Real offset of the comments
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
Groups []object.GroupsGroup `json:"groups"`
|
||||
}
|
||||
|
||||
// PhotosGetCommentsExtended returns a list of comments on a photo.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/photos.getComments
|
||||
func (vk *VK) PhotosGetCommentsExtended(params Params) (response PhotosGetCommentsExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getComments", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetMarketAlbumUploadServerResponse struct.
|
||||
type PhotosGetMarketAlbumUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// PhotosGetMarketAlbumUploadServer returns the server address for market album photo upload.
|
||||
//
|
||||
// https://vk.com/dev/photos.getMarketAlbumUploadServer
|
||||
func (vk *VK) PhotosGetMarketAlbumUploadServer(params Params) (
|
||||
response PhotosGetMarketAlbumUploadServerResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("photos.getMarketAlbumUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetMarketUploadServerResponse struct.
|
||||
type PhotosGetMarketUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// PhotosGetMarketUploadServer returns the server address for market photo upload.
|
||||
//
|
||||
// https://vk.com/dev/photos.getMarketUploadServer
|
||||
func (vk *VK) PhotosGetMarketUploadServer(params Params) (response PhotosGetMarketUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getMarketUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetMessagesUploadServerResponse struct.
|
||||
type PhotosGetMessagesUploadServerResponse struct {
|
||||
AlbumID int `json:"album_id"`
|
||||
UploadURL string `json:"upload_url"`
|
||||
UserID int `json:"user_id,omitempty"`
|
||||
GroupID int `json:"group_id,omitempty"`
|
||||
}
|
||||
|
||||
// PhotosGetMessagesUploadServer returns the server address for photo upload onto a messages.
|
||||
//
|
||||
// https://vk.com/dev/photos.getMessagesUploadServer
|
||||
func (vk *VK) PhotosGetMessagesUploadServer(params Params) (response PhotosGetMessagesUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getMessagesUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetNewTagsResponse struct.
|
||||
type PhotosGetNewTagsResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosPhotoXtrTagInfo `json:"items"`
|
||||
}
|
||||
|
||||
// PhotosGetNewTags returns a list of photos with tags that have not been viewed.
|
||||
//
|
||||
// https://vk.com/dev/photos.getNewTags
|
||||
func (vk *VK) PhotosGetNewTags(params Params) (response PhotosGetNewTagsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getNewTags", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetOwnerCoverPhotoUploadServerResponse struct.
|
||||
type PhotosGetOwnerCoverPhotoUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// PhotosGetOwnerCoverPhotoUploadServer receives server address for uploading community cover.
|
||||
//
|
||||
// https://vk.com/dev/photos.getOwnerCoverPhotoUploadServer
|
||||
func (vk *VK) PhotosGetOwnerCoverPhotoUploadServer(params Params) (
|
||||
response PhotosGetOwnerCoverPhotoUploadServerResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("photos.getOwnerCoverPhotoUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetOwnerPhotoUploadServerResponse struct.
|
||||
type PhotosGetOwnerPhotoUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// PhotosGetOwnerPhotoUploadServer returns an upload server address for a
|
||||
// profile or community photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.getOwnerPhotoUploadServer
|
||||
func (vk *VK) PhotosGetOwnerPhotoUploadServer(params Params) (
|
||||
response PhotosGetOwnerPhotoUploadServerResponse,
|
||||
err error,
|
||||
) {
|
||||
err = vk.RequestUnmarshal("photos.getOwnerPhotoUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetTagsResponse struct.
|
||||
type PhotosGetTagsResponse []object.PhotosPhotoTag
|
||||
|
||||
// PhotosGetTags returns a list of tags on a photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.getTags
|
||||
func (vk *VK) PhotosGetTags(params Params) (response PhotosGetTagsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getTags", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetUploadServerResponse struct.
|
||||
type PhotosGetUploadServerResponse object.PhotosPhotoUpload
|
||||
|
||||
// PhotosGetUploadServer returns the server address for photo upload.
|
||||
//
|
||||
// https://vk.com/dev/photos.getUploadServer
|
||||
func (vk *VK) PhotosGetUploadServer(params Params) (response PhotosGetUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetUserPhotosResponse struct.
|
||||
type PhotosGetUserPhotosResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosPhoto `json:"items"`
|
||||
}
|
||||
|
||||
// PhotosGetUserPhotos returns a list of photos in which a user is tagged.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/photos.getUserPhotos
|
||||
func (vk *VK) PhotosGetUserPhotos(params Params) (response PhotosGetUserPhotosResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getUserPhotos", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetUserPhotosExtendedResponse struct.
|
||||
type PhotosGetUserPhotosExtendedResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosPhotoFull `json:"items"`
|
||||
}
|
||||
|
||||
// PhotosGetUserPhotosExtended returns a list of photos in which a user is tagged.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/photos.getUserPhotos
|
||||
func (vk *VK) PhotosGetUserPhotosExtended(params Params) (response PhotosGetUserPhotosExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getUserPhotos", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosGetWallUploadServerResponse struct.
|
||||
type PhotosGetWallUploadServerResponse object.PhotosPhotoUpload
|
||||
|
||||
// PhotosGetWallUploadServer returns the server address for photo upload onto a user's wall.
|
||||
//
|
||||
// https://vk.com/dev/photos.getWallUploadServer
|
||||
func (vk *VK) PhotosGetWallUploadServer(params Params) (response PhotosGetWallUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.getWallUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosMakeCover makes a photo into an album cover.
|
||||
//
|
||||
// https://vk.com/dev/photos.makeCover
|
||||
func (vk *VK) PhotosMakeCover(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.makeCover", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosMove a photo from one album to another.
|
||||
//
|
||||
// https://vk.com/dev/photos.moveMoves
|
||||
func (vk *VK) PhotosMove(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.move", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosPutTag adds a tag on the photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.putTag
|
||||
func (vk *VK) PhotosPutTag(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.putTag", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosRemoveTag removes a tag from a photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.removeTag
|
||||
func (vk *VK) PhotosRemoveTag(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.removeTag", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosReorderAlbums reorders the album in the list of user albums.
|
||||
//
|
||||
// https://vk.com/dev/photos.reorderAlbums
|
||||
func (vk *VK) PhotosReorderAlbums(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.reorderAlbums", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosReorderPhotos reorders the photo in the list of photos of the user album.
|
||||
//
|
||||
// https://vk.com/dev/photos.reorderPhotos
|
||||
func (vk *VK) PhotosReorderPhotos(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.reorderPhotos", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosReport reports (submits a complaint about) a photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.report
|
||||
func (vk *VK) PhotosReport(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.report", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosReportComment reports (submits a complaint about) a comment on a photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.reportComment
|
||||
func (vk *VK) PhotosReportComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.reportComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosRestore restores a deleted photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.restore
|
||||
func (vk *VK) PhotosRestore(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.restore", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosRestoreComment restores a deleted comment on a photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.restoreComment
|
||||
func (vk *VK) PhotosRestoreComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("photos.restoreComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosSaveResponse struct.
|
||||
type PhotosSaveResponse []object.PhotosPhoto
|
||||
|
||||
// PhotosSave saves photos after successful uploading.
|
||||
//
|
||||
// https://vk.com/dev/photos.save
|
||||
func (vk *VK) PhotosSave(params Params) (response PhotosSaveResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.save", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosSaveMarketAlbumPhotoResponse struct.
|
||||
type PhotosSaveMarketAlbumPhotoResponse []object.PhotosPhoto
|
||||
|
||||
// PhotosSaveMarketAlbumPhoto photo Saves market album photos after successful uploading.
|
||||
//
|
||||
// https://vk.com/dev/photos.saveMarketAlbumPhoto
|
||||
func (vk *VK) PhotosSaveMarketAlbumPhoto(params Params) (response PhotosSaveMarketAlbumPhotoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.saveMarketAlbumPhoto", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosSaveMarketPhotoResponse struct.
|
||||
type PhotosSaveMarketPhotoResponse []object.PhotosPhoto
|
||||
|
||||
// PhotosSaveMarketPhoto saves market photos after successful uploading.
|
||||
//
|
||||
// https://vk.com/dev/photos.saveMarketPhoto
|
||||
func (vk *VK) PhotosSaveMarketPhoto(params Params) (response PhotosSaveMarketPhotoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.saveMarketPhoto", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosSaveMessagesPhotoResponse struct.
|
||||
type PhotosSaveMessagesPhotoResponse []object.PhotosPhoto
|
||||
|
||||
// PhotosSaveMessagesPhoto saves a photo after being successfully.
|
||||
//
|
||||
// https://vk.com/dev/photos.saveMessagesPhoto
|
||||
func (vk *VK) PhotosSaveMessagesPhoto(params Params) (response PhotosSaveMessagesPhotoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.saveMessagesPhoto", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosSaveOwnerCoverPhotoResponse struct.
|
||||
type PhotosSaveOwnerCoverPhotoResponse struct {
|
||||
Images []object.PhotosImage `json:"images"`
|
||||
}
|
||||
|
||||
// PhotosSaveOwnerCoverPhoto saves cover photo after successful uploading.
|
||||
//
|
||||
// https://vk.com/dev/photos.saveOwnerCoverPhoto
|
||||
func (vk *VK) PhotosSaveOwnerCoverPhoto(params Params) (response PhotosSaveOwnerCoverPhotoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.saveOwnerCoverPhoto", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosSaveOwnerPhotoResponse struct.
|
||||
type PhotosSaveOwnerPhotoResponse struct {
|
||||
PhotoHash string `json:"photo_hash"`
|
||||
PhotoSrc string `json:"photo_src"`
|
||||
PhotoSrcBig string `json:"photo_src_big"`
|
||||
PhotoSrcSmall string `json:"photo_src_small"`
|
||||
Saved int `json:"saved"`
|
||||
PostID int `json:"post_id"`
|
||||
}
|
||||
|
||||
// PhotosSaveOwnerPhoto saves a profile or community photo.
|
||||
//
|
||||
// https://vk.com/dev/photos.saveOwnerPhoto
|
||||
func (vk *VK) PhotosSaveOwnerPhoto(params Params) (response PhotosSaveOwnerPhotoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.saveOwnerPhoto", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosSaveWallPhotoResponse struct.
|
||||
type PhotosSaveWallPhotoResponse []object.PhotosPhoto
|
||||
|
||||
// PhotosSaveWallPhoto saves a photo to a user's or community's wall after being uploaded.
|
||||
//
|
||||
// https://vk.com/dev/photos.saveWallPhoto
|
||||
func (vk *VK) PhotosSaveWallPhoto(params Params) (response PhotosSaveWallPhotoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.saveWallPhoto", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosSearchResponse struct.
|
||||
type PhotosSearchResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PhotosPhotoFull `json:"items"`
|
||||
}
|
||||
|
||||
// PhotosSearch returns a list of photos.
|
||||
//
|
||||
// https://vk.com/dev/photos.search
|
||||
func (vk *VK) PhotosSearch(params Params) (response PhotosSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("photos.search", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,179 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// PodcastsGetCatalogResponse struct.
|
||||
type PodcastsGetCatalogResponse struct {
|
||||
Items []object.PodcastsItem `json:"items"`
|
||||
}
|
||||
|
||||
// PodcastsGetCatalog method.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/podcasts.getCatalog
|
||||
func (vk *VK) PodcastsGetCatalog(params Params) (response PodcastsGetCatalogResponse, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.getCatalog", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsGetCatalogExtendedResponse struct.
|
||||
type PodcastsGetCatalogExtendedResponse struct {
|
||||
Items []object.PodcastsItem `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// PodcastsGetCatalogExtended method.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/podcasts.getCatalog
|
||||
func (vk *VK) PodcastsGetCatalogExtended(params Params) (response PodcastsGetCatalogExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.getCatalog", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsGetCategoriesResponse struct.
|
||||
type PodcastsGetCategoriesResponse []object.PodcastsCategory
|
||||
|
||||
// PodcastsGetCategories method.
|
||||
//
|
||||
// https://vk.com/dev/podcasts.getCategories
|
||||
func (vk *VK) PodcastsGetCategories(params Params) (response PodcastsGetCategoriesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.getCategories", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsGetEpisodesResponse struct.
|
||||
type PodcastsGetEpisodesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.PodcastsEpisode `json:"items"`
|
||||
}
|
||||
|
||||
// PodcastsGetEpisodes method.
|
||||
//
|
||||
// https://vk.com/dev/podcasts.getEpisodes
|
||||
func (vk *VK) PodcastsGetEpisodes(params Params) (response PodcastsGetEpisodesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.getEpisodes", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsGetFeedResponse struct.
|
||||
type PodcastsGetFeedResponse struct {
|
||||
Items []object.PodcastsEpisode `json:"items"`
|
||||
NextFrom string `json:"next_from"`
|
||||
}
|
||||
|
||||
// PodcastsGetFeed method.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/podcasts.getFeed
|
||||
func (vk *VK) PodcastsGetFeed(params Params) (response PodcastsGetFeedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.getFeed", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsGetFeedExtendedResponse struct.
|
||||
type PodcastsGetFeedExtendedResponse struct {
|
||||
Items []object.PodcastsEpisode `json:"items"`
|
||||
NextFrom string `json:"next_from"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// PodcastsGetFeedExtended method.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/podcasts.getFeed
|
||||
func (vk *VK) PodcastsGetFeedExtended(params Params) (response PodcastsGetFeedExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.getFeed", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsGetStartPageResponse struct.
|
||||
type PodcastsGetStartPageResponse struct {
|
||||
Order []string `json:"order"`
|
||||
InProgress []object.PodcastsEpisode `json:"in_progress"`
|
||||
Bookmarks []object.PodcastsEpisode `json:"bookmarks"`
|
||||
Articles []object.Article `json:"articles"`
|
||||
StaticHowTo []bool `json:"static_how_to"`
|
||||
FriendsLiked []object.PodcastsEpisode `json:"friends_liked"`
|
||||
Subscriptions []object.PodcastsEpisode `json:"subscriptions"`
|
||||
CategoriesList []object.PodcastsCategory `json:"categories_list"`
|
||||
RecommendedEpisodes []object.PodcastsEpisode `json:"recommended_episodes"`
|
||||
Catalog []struct {
|
||||
Category object.PodcastsCategory `json:"category"`
|
||||
Items []object.PodcastsItem `json:"items"`
|
||||
} `json:"catalog"`
|
||||
}
|
||||
|
||||
// PodcastsGetStartPage method.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/podcasts.getStartPage
|
||||
func (vk *VK) PodcastsGetStartPage(params Params) (response PodcastsGetStartPageResponse, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.getStartPage", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsGetStartPageExtendedResponse struct.
|
||||
type PodcastsGetStartPageExtendedResponse struct {
|
||||
Order []string `json:"order"`
|
||||
InProgress []object.PodcastsEpisode `json:"in_progress"`
|
||||
Bookmarks []object.PodcastsEpisode `json:"bookmarks"`
|
||||
Articles []object.Article `json:"articles"`
|
||||
StaticHowTo []bool `json:"static_how_to"`
|
||||
FriendsLiked []object.PodcastsEpisode `json:"friends_liked"`
|
||||
Subscriptions []object.PodcastsEpisode `json:"subscriptions"`
|
||||
CategoriesList []object.PodcastsCategory `json:"categories_list"`
|
||||
RecommendedEpisodes []object.PodcastsEpisode `json:"recommended_episodes"`
|
||||
Catalog []struct {
|
||||
Category object.PodcastsCategory `json:"category"`
|
||||
Items []object.PodcastsItem `json:"items"`
|
||||
} `json:"catalog"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// PodcastsGetStartPageExtended method.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/podcasts.getStartPage
|
||||
func (vk *VK) PodcastsGetStartPageExtended(params Params) (response PodcastsGetStartPageExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.getStartPage", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsMarkAsListened method.
|
||||
//
|
||||
// https://vk.com/dev/podcasts.markAsListened
|
||||
func (vk *VK) PodcastsMarkAsListened(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.markAsListened", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsSubscribe method.
|
||||
//
|
||||
// https://vk.com/dev/podcasts.subscribe
|
||||
func (vk *VK) PodcastsSubscribe(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.subscribe", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PodcastsUnsubscribe method.
|
||||
//
|
||||
// https://vk.com/dev/podcasts.unsubscribe
|
||||
func (vk *VK) PodcastsUnsubscribe(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("podcasts.unsubscribe", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,106 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// PollsAddVote adds the current user's vote to the selected answer in the poll.
|
||||
//
|
||||
// https://vk.com/dev/polls.addVote
|
||||
func (vk *VK) PollsAddVote(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("polls.addVote", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PollsCreateResponse struct.
|
||||
type PollsCreateResponse object.PollsPoll
|
||||
|
||||
// PollsCreate creates polls that can be attached to the users' or communities' posts.
|
||||
//
|
||||
// https://vk.com/dev/polls.create
|
||||
func (vk *VK) PollsCreate(params Params) (response PollsCreateResponse, err error) {
|
||||
err = vk.RequestUnmarshal("polls.create", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PollsDeleteVote deletes the current user's vote from the selected answer in the poll.
|
||||
//
|
||||
// https://vk.com/dev/polls.deleteVote
|
||||
func (vk *VK) PollsDeleteVote(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("polls.deleteVote", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PollsEdit edits created polls.
|
||||
//
|
||||
// https://vk.com/dev/polls.edit
|
||||
func (vk *VK) PollsEdit(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("polls.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PollsGetBackgroundsResponse struct.
|
||||
type PollsGetBackgroundsResponse []object.PollsBackground
|
||||
|
||||
// PollsGetBackgrounds return default backgrounds for polls.
|
||||
//
|
||||
// https://vk.com/dev/polls.getBackgrounds
|
||||
func (vk *VK) PollsGetBackgrounds(params Params) (response PollsGetBackgroundsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("polls.getBackgrounds", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PollsGetByIDResponse struct.
|
||||
type PollsGetByIDResponse object.PollsPoll
|
||||
|
||||
// PollsGetByID returns detailed information about a poll by its ID.
|
||||
//
|
||||
// https://vk.com/dev/polls.getById
|
||||
func (vk *VK) PollsGetByID(params Params) (response PollsGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("polls.getById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PollsGetPhotoUploadServerResponse struct.
|
||||
type PollsGetPhotoUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
}
|
||||
|
||||
// PollsGetPhotoUploadServer returns a URL for uploading a photo to a poll.
|
||||
//
|
||||
// https://vk.com/dev/polls.getPhotoUploadServer
|
||||
func (vk *VK) PollsGetPhotoUploadServer(params Params) (response PollsGetPhotoUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("polls.getPhotoUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PollsGetVotersResponse struct.
|
||||
type PollsGetVotersResponse []object.PollsVoters
|
||||
|
||||
// PollsGetVoters returns a list of IDs of users who selected specific answers in the poll.
|
||||
//
|
||||
// https://vk.com/dev/polls.getVoters
|
||||
func (vk *VK) PollsGetVoters(params Params) (response PollsGetVotersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("polls.getVoters", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PollsGetVotersFieldsResponse struct.
|
||||
type PollsGetVotersFieldsResponse []object.PollsVotersFields
|
||||
|
||||
// PollsGetVotersFields returns a list of IDs of users who selected specific answers in the poll.
|
||||
//
|
||||
// https://vk.com/dev/polls.getVoters
|
||||
func (vk *VK) PollsGetVotersFields(params Params) (response PollsGetVotersFieldsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("polls.getVoters", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PollsSavePhotoResponse struct.
|
||||
type PollsSavePhotoResponse object.PollsPhoto
|
||||
|
||||
// PollsSavePhoto allows to save poll's uploaded photo.
|
||||
//
|
||||
// https://vk.com/dev/polls.savePhoto
|
||||
func (vk *VK) PollsSavePhoto(params Params) (response PollsSavePhotoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("polls.savePhoto", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,79 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// PrettyCardsCreateResponse struct.
|
||||
type PrettyCardsCreateResponse struct {
|
||||
OwnerID int `json:"owner_id"` // Owner ID of created pretty card
|
||||
CardID string `json:"card_id"` // Card ID of created pretty card
|
||||
}
|
||||
|
||||
// PrettyCardsCreate method.
|
||||
//
|
||||
// https://vk.com/dev/prettyCards.create
|
||||
func (vk *VK) PrettyCardsCreate(params Params) (response PrettyCardsCreateResponse, err error) {
|
||||
err = vk.RequestUnmarshal("prettyCards.create", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PrettyCardsDeleteResponse struct.
|
||||
type PrettyCardsDeleteResponse struct {
|
||||
OwnerID int `json:"owner_id"` // Owner ID of created pretty card
|
||||
CardID string `json:"card_id"` // Card ID of created pretty card
|
||||
Error string `json:"error"` // Error reason if error happened
|
||||
}
|
||||
|
||||
// PrettyCardsDelete method.
|
||||
//
|
||||
// https://vk.com/dev/prettyCards.delete
|
||||
func (vk *VK) PrettyCardsDelete(params Params) (response PrettyCardsDeleteResponse, err error) {
|
||||
err = vk.RequestUnmarshal("prettyCards.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PrettyCardsEditResponse struct.
|
||||
type PrettyCardsEditResponse struct {
|
||||
OwnerID int `json:"owner_id"` // Owner ID of created pretty card
|
||||
CardID string `json:"card_id"` // Card ID of created pretty card
|
||||
}
|
||||
|
||||
// PrettyCardsEdit method.
|
||||
//
|
||||
// https://vk.com/dev/prettyCards.edit
|
||||
func (vk *VK) PrettyCardsEdit(params Params) (response PrettyCardsEditResponse, err error) {
|
||||
err = vk.RequestUnmarshal("prettyCards.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PrettyCardsGetResponse struct.
|
||||
type PrettyCardsGetResponse struct {
|
||||
Count int `json:"count"` // Total number
|
||||
Items []object.PrettyCardsPrettyCard `json:"items"`
|
||||
}
|
||||
|
||||
// PrettyCardsGet method.
|
||||
//
|
||||
// https://vk.com/dev/prettyCards.get
|
||||
func (vk *VK) PrettyCardsGet(params Params) (response PrettyCardsGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("prettyCards.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PrettyCardsGetByIDResponse struct.
|
||||
type PrettyCardsGetByIDResponse []object.PrettyCardsPrettyCard
|
||||
|
||||
// PrettyCardsGetByID method.
|
||||
//
|
||||
// https://vk.com/dev/prettyCards.getById
|
||||
func (vk *VK) PrettyCardsGetByID(params Params) (response PrettyCardsGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("prettyCards.getById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// PrettyCardsGetUploadURL method.
|
||||
//
|
||||
// https://vk.com/dev/prettyCards.getUploadURL
|
||||
func (vk *VK) PrettyCardsGetUploadURL(params Params) (response string, err error) {
|
||||
err = vk.RequestUnmarshal("prettyCards.getUploadURL", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,17 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// SearchGetHintsResponse struct.
|
||||
type SearchGetHintsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.SearchHint `json:"items"`
|
||||
}
|
||||
|
||||
// SearchGetHints allows the programmer to do a quick search for any substring.
|
||||
//
|
||||
// https://vk.com/dev/search.getHints
|
||||
func (vk *VK) SearchGetHints(params Params) (response SearchGetHintsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("search.getHints", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,110 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// SecureAddAppEventResponse struct.
|
||||
type SecureAddAppEventResponse int // FIXME: not found documentation. https://github.com/VKCOM/vk-api-schema/issues/98
|
||||
|
||||
// SecureAddAppEvent adds user activity information to an application.
|
||||
//
|
||||
// https://vk.com/dev/secure.addAppEvent
|
||||
func (vk *VK) SecureAddAppEvent(params Params) (response SecureAddAppEventResponse, err error) {
|
||||
err = vk.RequestUnmarshal("secure.addAppEvent", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// SecureCheckTokenResponse struct.
|
||||
type SecureCheckTokenResponse object.SecureTokenChecked
|
||||
|
||||
// SecureCheckToken checks the user authentication in IFrame and Flash apps using the access_token parameter.
|
||||
//
|
||||
// https://vk.com/dev/secure.checkToken
|
||||
func (vk *VK) SecureCheckToken(params Params) (response SecureCheckTokenResponse, err error) {
|
||||
err = vk.RequestUnmarshal("secure.checkToken", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// SecureGetAppBalance returns payment balance of the application in hundredth of a vote.
|
||||
//
|
||||
// https://vk.com/dev/secure.getAppBalance
|
||||
func (vk *VK) SecureGetAppBalance(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("secure.getAppBalance", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// SecureGetSMSHistoryResponse struct.
|
||||
type SecureGetSMSHistoryResponse []object.SecureSmsNotification
|
||||
|
||||
// SecureGetSMSHistory shows a list of SMS notifications sent by the
|
||||
// application using secure.sendSMSNotification method.
|
||||
//
|
||||
// https://vk.com/dev/secure.getSMSHistory
|
||||
func (vk *VK) SecureGetSMSHistory(params Params) (response SecureGetSMSHistoryResponse, err error) {
|
||||
err = vk.RequestUnmarshal("secure.getSMSHistory", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// SecureGetTransactionsHistoryResponse struct.
|
||||
type SecureGetTransactionsHistoryResponse []object.SecureTransaction
|
||||
|
||||
// SecureGetTransactionsHistory shows history of votes transaction between users and the application.
|
||||
//
|
||||
// https://vk.com/dev/secure.getTransactionsHistory
|
||||
func (vk *VK) SecureGetTransactionsHistory(params Params) (response SecureGetTransactionsHistoryResponse, err error) {
|
||||
err = vk.RequestUnmarshal("secure.getTransactionsHistory", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// SecureGetUserLevelResponse struct.
|
||||
type SecureGetUserLevelResponse []object.SecureLevel
|
||||
|
||||
// SecureGetUserLevel returns one of the previously set game levels of one or more users in the application.
|
||||
//
|
||||
// https://vk.com/dev/secure.getUserLevel
|
||||
func (vk *VK) SecureGetUserLevel(params Params) (response SecureGetUserLevelResponse, err error) {
|
||||
err = vk.RequestUnmarshal("secure.getUserLevel", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// SecureGiveEventStickerResponse struct.
|
||||
type SecureGiveEventStickerResponse []struct {
|
||||
UserID int `json:"user_id"`
|
||||
Status string `json:"status"`
|
||||
}
|
||||
|
||||
// SecureGiveEventSticker method.
|
||||
//
|
||||
// https://vk.com/dev/secure.giveEventSticker
|
||||
func (vk *VK) SecureGiveEventSticker(params Params) (response SecureGiveEventStickerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("secure.giveEventSticker", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// SecureSendNotificationResponse struct.
|
||||
type SecureSendNotificationResponse []int // User ID
|
||||
|
||||
// SecureSendNotification sends notification to the user.
|
||||
//
|
||||
// https://vk.com/dev/secure.sendNotification
|
||||
func (vk *VK) SecureSendNotification(params Params) (response SecureSendNotificationResponse, err error) {
|
||||
err = vk.RequestUnmarshal("secure.sendNotification", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// SecureSendSMSNotification sends SMS notification to a user's mobile device.
|
||||
//
|
||||
// https://vk.com/dev/secure.sendSMSNotification
|
||||
func (vk *VK) SecureSendSMSNotification(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("secure.sendSMSNotification", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// SecureSetCounter sets a counter which is shown to the user in bold in the left menu.
|
||||
//
|
||||
// https://vk.com/dev/secure.setCounter
|
||||
func (vk *VK) SecureSetCounter(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("secure.setCounter", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,35 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// StatsGetResponse struct.
|
||||
type StatsGetResponse []object.StatsPeriod
|
||||
|
||||
// StatsGet returns statistics of a community or an application.
|
||||
//
|
||||
// https://vk.com/dev/stats.get
|
||||
func (vk *VK) StatsGet(params Params) (response StatsGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stats.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StatsGetPostReachResponse struct.
|
||||
type StatsGetPostReachResponse []object.StatsWallpostStat
|
||||
|
||||
// StatsGetPostReach returns stats for a wall post.
|
||||
//
|
||||
// https://vk.com/dev/stats.getPostReach
|
||||
func (vk *VK) StatsGetPostReach(params Params) (response StatsGetPostReachResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stats.getPostReach", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StatsTrackVisitor adds current session's data in the application statistics.
|
||||
//
|
||||
// https://vk.com/dev/stats.trackVisitor
|
||||
func (vk *VK) StatsTrackVisitor(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("stats.trackVisitor", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,23 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// StatusGetResponse struct.
|
||||
type StatusGetResponse struct {
|
||||
Audio object.AudioAudio `json:"audio"`
|
||||
Text string `json:"text"`
|
||||
}
|
||||
|
||||
// StatusGet returns data required to show the status of a user or community.
|
||||
func (vk *VK) StatusGet(params Params) (response StatusGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("status.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StatusSet sets a new status for the current user.
|
||||
func (vk *VK) StatusSet(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("status.set", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,48 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// StorageGetResponse struct.
|
||||
type StorageGetResponse []object.BaseRequestParam
|
||||
|
||||
// ToMap return map from StorageGetResponse.
|
||||
func (s StorageGetResponse) ToMap() map[string]string {
|
||||
m := make(map[string]string)
|
||||
for _, item := range s {
|
||||
m[item.Key] = item.Value
|
||||
}
|
||||
|
||||
return m
|
||||
}
|
||||
|
||||
// StorageGet returns a value of variable with the name set by key parameter.
|
||||
//
|
||||
// StorageGet always return array!
|
||||
//
|
||||
// https://vk.com/dev/storage.get
|
||||
func (vk *VK) StorageGet(params Params) (response StorageGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("storage.get", &response, params)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StorageGetKeysResponse struct.
|
||||
type StorageGetKeysResponse []string
|
||||
|
||||
// StorageGetKeys returns the names of all variables.
|
||||
//
|
||||
// https://vk.com/dev/storage.getKeys
|
||||
func (vk *VK) StorageGetKeys(params Params) (response StorageGetKeysResponse, err error) {
|
||||
err = vk.RequestUnmarshal("storage.getKeys", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StorageSet saves a value of variable with the name set by key parameter.
|
||||
//
|
||||
// https://vk.com/dev/storage.set
|
||||
func (vk *VK) StorageSet(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("storage.set", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,305 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// StoriesBanOwner allows to hide stories from chosen sources from current user's feed.
|
||||
//
|
||||
// https://vk.com/dev/stories.banOwner
|
||||
func (vk *VK) StoriesBanOwner(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("stories.banOwner", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesDelete allows to delete story.
|
||||
//
|
||||
// https://vk.com/dev/stories.delete
|
||||
func (vk *VK) StoriesDelete(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("stories.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetResponse struct.
|
||||
type StoriesGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesFeedItem `json:"items"`
|
||||
PromoData object.StoriesPromoData `json:"promo_data"`
|
||||
NeedUploadScreen object.BaseBoolInt `json:"need_upload_screen"`
|
||||
}
|
||||
|
||||
// StoriesGet returns stories available for current user.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/stories.get
|
||||
func (vk *VK) StoriesGet(params Params) (response StoriesGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.get", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetExtendedResponse struct.
|
||||
type StoriesGetExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesFeedItem `json:"items"`
|
||||
PromoData object.StoriesPromoData `json:"promo_data"`
|
||||
NeedUploadScreen object.BaseBoolInt `json:"need_upload_screen"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// StoriesGetExtended returns stories available for current user.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/stories.get
|
||||
func (vk *VK) StoriesGetExtended(params Params) (response StoriesGetExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.get", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetBannedResponse struct.
|
||||
type StoriesGetBannedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// StoriesGetBanned returns list of sources hidden from current user's feed.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/stories.getBanned
|
||||
func (vk *VK) StoriesGetBanned(params Params) (response StoriesGetBannedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getBanned", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetBannedExtendedResponse struct.
|
||||
type StoriesGetBannedExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// StoriesGetBannedExtended returns list of sources hidden from current user's feed.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/stories.getBanned
|
||||
func (vk *VK) StoriesGetBannedExtended(params Params) (response StoriesGetBannedExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getBanned", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetByIDResponse struct.
|
||||
type StoriesGetByIDResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesStory `json:"items"`
|
||||
}
|
||||
|
||||
// StoriesGetByID returns story by its ID.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/stories.getById
|
||||
func (vk *VK) StoriesGetByID(params Params) (response StoriesGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getById", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetByIDExtendedResponse struct.
|
||||
type StoriesGetByIDExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesStory `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// StoriesGetByIDExtended returns story by its ID.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/stories.getById
|
||||
func (vk *VK) StoriesGetByIDExtended(params Params) (response StoriesGetByIDExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getById", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetPhotoUploadServerResponse struct.
|
||||
type StoriesGetPhotoUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
PeerIDs []int `json:"peer_ids"`
|
||||
UserIDs []int `json:"user_ids"`
|
||||
}
|
||||
|
||||
// StoriesGetPhotoUploadServer returns URL for uploading a story with photo.
|
||||
//
|
||||
// https://vk.com/dev/stories.getPhotoUploadServer
|
||||
func (vk *VK) StoriesGetPhotoUploadServer(params Params) (response StoriesGetPhotoUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getPhotoUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetRepliesResponse struct.
|
||||
type StoriesGetRepliesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesFeedItem `json:"items"`
|
||||
}
|
||||
|
||||
// StoriesGetReplies returns replies to the story.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/stories.getReplies
|
||||
func (vk *VK) StoriesGetReplies(params Params) (response StoriesGetRepliesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getReplies", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetRepliesExtendedResponse struct.
|
||||
type StoriesGetRepliesExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesFeedItem `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// StoriesGetRepliesExtended returns replies to the story.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/stories.getReplies
|
||||
func (vk *VK) StoriesGetRepliesExtended(params Params) (response StoriesGetRepliesExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getReplies", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetStatsResponse struct.
|
||||
type StoriesGetStatsResponse object.StoriesStoryStats
|
||||
|
||||
// StoriesGetStats return statistics data for the story.
|
||||
//
|
||||
// https://vk.com/dev/stories.getStats
|
||||
func (vk *VK) StoriesGetStats(params Params) (response StoriesGetStatsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getStats", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetVideoUploadServerResponse struct.
|
||||
type StoriesGetVideoUploadServerResponse struct {
|
||||
UploadURL string `json:"upload_url"`
|
||||
PeerIDs []int `json:"peer_ids"`
|
||||
UserIDs []int `json:"user_ids"`
|
||||
}
|
||||
|
||||
// StoriesGetVideoUploadServer allows to receive URL for uploading story with video.
|
||||
//
|
||||
// https://vk.com/dev/stories.getVideoUploadServer
|
||||
func (vk *VK) StoriesGetVideoUploadServer(params Params) (response StoriesGetVideoUploadServerResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getVideoUploadServer", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesGetViewersResponse struct.
|
||||
type StoriesGetViewersResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesViewer `json:"items"`
|
||||
}
|
||||
|
||||
// StoriesGetViewers returns a list of story viewers.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/stories.getViewers
|
||||
func (vk *VK) StoriesGetViewers(params Params) (response StoriesGetViewersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.getViewers", &response, params)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesHideAllReplies hides all replies in the last 24 hours from the user to current user's stories.
|
||||
//
|
||||
// https://vk.com/dev/stories.hideAllReplies
|
||||
func (vk *VK) StoriesHideAllReplies(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("stories.hideAllReplies", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesHideReply hides the reply to the current user's story.
|
||||
//
|
||||
// https://vk.com/dev/stories.hideReply
|
||||
func (vk *VK) StoriesHideReply(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("stories.hideReply", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesSaveResponse struct.
|
||||
type StoriesSaveResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesStory `json:"items"`
|
||||
}
|
||||
|
||||
// StoriesSave method.
|
||||
//
|
||||
// https://vk.com/dev/stories.save
|
||||
func (vk *VK) StoriesSave(params Params) (response StoriesSaveResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.save", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesSearchResponse struct.
|
||||
type StoriesSearchResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesFeedItem `json:"items"`
|
||||
}
|
||||
|
||||
// StoriesSearch returns search results for stories.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/stories.search
|
||||
func (vk *VK) StoriesSearch(params Params) (response StoriesSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.search", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesSearchExtendedResponse struct.
|
||||
type StoriesSearchExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.StoriesFeedItem `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// StoriesSearchExtended returns search results for stories.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/stories.search
|
||||
func (vk *VK) StoriesSearchExtended(params Params) (response StoriesSearchExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("stories.search", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesSendInteraction sends feedback to the story.
|
||||
//
|
||||
// Available for applications with type VK Mini Apps. The default method is
|
||||
// not available to applications.
|
||||
//
|
||||
// https://vk.com/dev/stories.sendInteraction
|
||||
func (vk *VK) StoriesSendInteraction(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("stories.sendInteraction", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StoriesUnbanOwner allows to show stories from hidden sources in current user's feed.
|
||||
//
|
||||
// https://vk.com/dev/stories.unbanOwner
|
||||
func (vk *VK) StoriesUnbanOwner(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("stories.unbanOwner", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,67 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
// StreamingGetServerURLResponse struct.
|
||||
type StreamingGetServerURLResponse struct {
|
||||
Endpoint string `json:"endpoint"`
|
||||
Key string `json:"key"`
|
||||
}
|
||||
|
||||
// StreamingGetServerURL allows to receive data for the connection to Streaming API.
|
||||
//
|
||||
// https://vk.com/dev/streaming.getServerUrl
|
||||
func (vk *VK) StreamingGetServerURL(params Params) (response StreamingGetServerURLResponse, err error) {
|
||||
err = vk.RequestUnmarshal("streaming.getServerUrl", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StreamingGetSettingsResponse struct.
|
||||
type StreamingGetSettingsResponse struct {
|
||||
MonthlyLimit string `json:"monthly_limit"`
|
||||
}
|
||||
|
||||
// StreamingGetSettings allows to receive monthly tier for Streaming API.
|
||||
//
|
||||
// https://vk.com/dev/streaming.getSettings
|
||||
func (vk *VK) StreamingGetSettings(params Params) (response StreamingGetSettingsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("streaming.getSettings", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StreamingGetStatsResponse struct.
|
||||
type StreamingGetStatsResponse []struct {
|
||||
EventType string `json:"event_type"`
|
||||
Stats []struct {
|
||||
Timestamp int `json:"timestamp"`
|
||||
Value int `json:"value"`
|
||||
} `json:"stats"`
|
||||
}
|
||||
|
||||
// StreamingGetStats allows to receive statistics for prepared and received events in Streaming API.
|
||||
//
|
||||
// https://vk.com/dev/streaming.getStats
|
||||
func (vk *VK) StreamingGetStats(params Params) (response StreamingGetStatsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("streaming.getStats", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StreamingGetStemResponse struct.
|
||||
type StreamingGetStemResponse struct {
|
||||
Stem string `json:"stem"`
|
||||
}
|
||||
|
||||
// StreamingGetStem allows to receive the stem of the word.
|
||||
//
|
||||
// https://vk.com/dev/streaming.getStem
|
||||
func (vk *VK) StreamingGetStem(params Params) (response StreamingGetStemResponse, err error) {
|
||||
err = vk.RequestUnmarshal("streaming.getStem", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// StreamingSetSettings allows to set monthly tier for Streaming API.
|
||||
//
|
||||
// https://vk.com/dev/streaming.setSettings
|
||||
func (vk *VK) StreamingSetSettings(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("streaming.setSettings", &response, params)
|
||||
|
||||
return
|
||||
}
|
@ -0,0 +1,104 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// UsersGetResponse users.get response.
|
||||
type UsersGetResponse []object.UsersUser
|
||||
|
||||
// UsersGet returns detailed information on users.
|
||||
//
|
||||
// https://vk.com/dev/users.get
|
||||
func (vk *VK) UsersGet(params Params) (response UsersGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("users.get", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// UsersGetFollowersResponse struct.
|
||||
type UsersGetFollowersResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// UsersGetFollowers returns a list of IDs of followers of the user in
|
||||
// question, sorted by date added, most recent first.
|
||||
//
|
||||
// fields="";
|
||||
//
|
||||
// https://vk.com/dev/users.getFollowers
|
||||
func (vk *VK) UsersGetFollowers(params Params) (response UsersGetFollowersResponse, err error) {
|
||||
err = vk.RequestUnmarshal("users.getFollowers", &response, params, Params{"fields": ""})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// UsersGetFollowersFieldsResponse struct.
|
||||
type UsersGetFollowersFieldsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// UsersGetFollowersFields returns a list of IDs of followers of the user in
|
||||
// question, sorted by date added, most recent first.
|
||||
//
|
||||
// fields not empty.
|
||||
//
|
||||
// https://vk.com/dev/users.getFollowers
|
||||
func (vk *VK) UsersGetFollowersFields(params Params) (response UsersGetFollowersFieldsResponse, err error) {
|
||||
reqParams := make(Params)
|
||||
if v, prs := params["fields"]; v == "" || !prs {
|
||||
reqParams["fields"] = "id"
|
||||
}
|
||||
|
||||
err = vk.RequestUnmarshal("users.getFollowers", &response, params, reqParams)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// UsersGetSubscriptionsResponse struct.
|
||||
type UsersGetSubscriptionsResponse struct {
|
||||
Users struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
} `json:"users"`
|
||||
Groups struct {
|
||||
Count int `json:"count"`
|
||||
Items []int `json:"items"`
|
||||
} `json:"groups"`
|
||||
}
|
||||
|
||||
// UsersGetSubscriptions returns a list of IDs of users and public pages followed by the user.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/users.getSubscriptions
|
||||
//
|
||||
// BUG(SevereCloud): UsersGetSubscriptions bad response with extended=1.
|
||||
func (vk *VK) UsersGetSubscriptions(params Params) (response UsersGetSubscriptionsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("users.getSubscriptions", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// UsersReport reports (submits a complain about) a user.
|
||||
//
|
||||
// https://vk.com/dev/users.report
|
||||
func (vk *VK) UsersReport(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("users.report", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// UsersSearchResponse struct.
|
||||
type UsersSearchResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// UsersSearch returns a list of users matching the search criteria.
|
||||
//
|
||||
// https://vk.com/dev/users.search
|
||||
func (vk *VK) UsersSearch(params Params) (response UsersSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("users.search", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,105 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// UtilsCheckLinkResponse struct.
|
||||
type UtilsCheckLinkResponse object.UtilsLinkChecked
|
||||
|
||||
// UtilsCheckLink checks whether a link is blocked in VK.
|
||||
//
|
||||
// https://vk.com/dev/utils.checkLink
|
||||
func (vk *VK) UtilsCheckLink(params Params) (response UtilsCheckLinkResponse, err error) {
|
||||
err = vk.RequestUnmarshal("utils.checkLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// UtilsDeleteFromLastShortened deletes shortened link from user's list.
|
||||
//
|
||||
// https://vk.com/dev/utils.deleteFromLastShortened
|
||||
func (vk *VK) UtilsDeleteFromLastShortened(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("utils.deleteFromLastShortened", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// UtilsGetLastShortenedLinksResponse struct.
|
||||
type UtilsGetLastShortenedLinksResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.UtilsLastShortenedLink `json:"items"`
|
||||
}
|
||||
|
||||
// UtilsGetLastShortenedLinks returns a list of user's shortened links.
|
||||
//
|
||||
// https://vk.com/dev/utils.getLastShortenedLinks
|
||||
func (vk *VK) UtilsGetLastShortenedLinks(params Params) (response UtilsGetLastShortenedLinksResponse, err error) {
|
||||
err = vk.RequestUnmarshal("utils.getLastShortenedLinks", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// UtilsGetLinkStatsResponse struct.
|
||||
type UtilsGetLinkStatsResponse object.UtilsLinkStats
|
||||
|
||||
// UtilsGetLinkStats returns stats data for shortened link.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/utils.getLinkStats
|
||||
func (vk *VK) UtilsGetLinkStats(params Params) (response UtilsGetLinkStatsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("utils.getLinkStats", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// UtilsGetLinkStatsExtendedResponse struct.
|
||||
type UtilsGetLinkStatsExtendedResponse object.UtilsLinkStatsExtended
|
||||
|
||||
// UtilsGetLinkStatsExtended returns stats data for shortened link.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/utils.getLinkStats
|
||||
func (vk *VK) UtilsGetLinkStatsExtended(params Params) (response UtilsGetLinkStatsExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("utils.getLinkStats", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// UtilsGetServerTime returns the current time of the VK server.
|
||||
//
|
||||
// https://vk.com/dev/utils.getServerTime
|
||||
func (vk *VK) UtilsGetServerTime(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("utils.getServerTime", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// UtilsGetShortLinkResponse struct.
|
||||
type UtilsGetShortLinkResponse object.UtilsShortLink
|
||||
|
||||
// UtilsGetShortLink allows to receive a link shortened via vk.cc.
|
||||
//
|
||||
// https://vk.com/dev/utils.getShortLink
|
||||
func (vk *VK) UtilsGetShortLink(params Params) (response UtilsGetShortLinkResponse, err error) {
|
||||
err = vk.RequestUnmarshal("utils.getShortLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// UtilsResolveScreenNameResponse struct.
|
||||
type UtilsResolveScreenNameResponse object.UtilsDomainResolved
|
||||
|
||||
// UtilsResolveScreenName detects a type of object (e.g., user, community, application) and its ID by screen name.
|
||||
//
|
||||
// https://vk.com/dev/utils.resolveScreenName
|
||||
func (vk *VK) UtilsResolveScreenName(params Params) (response UtilsResolveScreenNameResponse, err error) {
|
||||
rawResponse, err := vk.Request("utils.resolveScreenName", params)
|
||||
// Если короткое имя screen_name не занято, то будет возвращён пустой объект.
|
||||
if err != nil || string(rawResponse) == "[]" {
|
||||
return
|
||||
}
|
||||
|
||||
err = json.Unmarshal(rawResponse, &response)
|
||||
|
||||
return
|
||||
}
|
@ -0,0 +1,338 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// VideoAdd adds a video to a user or community page.
|
||||
//
|
||||
// https://vk.com/dev/video.add
|
||||
func (vk *VK) VideoAdd(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.add", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoAddAlbumResponse struct.
|
||||
type VideoAddAlbumResponse struct {
|
||||
AlbumID int `json:"album_id"`
|
||||
}
|
||||
|
||||
// VideoAddAlbum creates an empty album for videos.
|
||||
//
|
||||
// https://vk.com/dev/video.addAlbum
|
||||
func (vk *VK) VideoAddAlbum(params Params) (response VideoAddAlbumResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.addAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoAddToAlbum allows you to add a video to the album.
|
||||
//
|
||||
// https://vk.com/dev/video.addToAlbum
|
||||
func (vk *VK) VideoAddToAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.addToAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoCreateComment adds a new comment on a video.
|
||||
//
|
||||
// https://vk.com/dev/video.createComment
|
||||
func (vk *VK) VideoCreateComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.createComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoDelete deletes a video from a user or community page.
|
||||
//
|
||||
// https://vk.com/dev/video.delete
|
||||
func (vk *VK) VideoDelete(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoDeleteAlbum deletes a video album.
|
||||
//
|
||||
// https://vk.com/dev/video.deleteAlbum
|
||||
func (vk *VK) VideoDeleteAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.deleteAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoDeleteComment deletes a comment on a video.
|
||||
//
|
||||
// https://vk.com/dev/video.deleteComment
|
||||
func (vk *VK) VideoDeleteComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.deleteComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoEdit edits information about a video on a user or community page.
|
||||
//
|
||||
// https://vk.com/dev/video.edit
|
||||
func (vk *VK) VideoEdit(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoEditAlbum edits the title of a video album.
|
||||
//
|
||||
// https://vk.com/dev/video.editAlbum
|
||||
func (vk *VK) VideoEditAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.editAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoEditComment edits the text of a comment on a video.
|
||||
//
|
||||
// https://vk.com/dev/video.editComment
|
||||
func (vk *VK) VideoEditComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.editComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoGetResponse struct.
|
||||
type VideoGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.VideoVideo `json:"items"`
|
||||
}
|
||||
|
||||
// VideoGet returns detailed information about videos.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/video.get
|
||||
func (vk *VK) VideoGet(params Params) (response VideoGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.get", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// VideoGetExtendedResponse struct.
|
||||
type VideoGetExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.VideoVideo `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// VideoGetExtended returns detailed information about videos.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/video.get
|
||||
func (vk *VK) VideoGetExtended(params Params) (response VideoGetExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.get", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// VideoGetAlbumByIDResponse struct.
|
||||
type VideoGetAlbumByIDResponse object.VideoVideoAlbumFull
|
||||
|
||||
// VideoGetAlbumByID returns video album info.
|
||||
//
|
||||
// https://vk.com/dev/video.getAlbumById
|
||||
func (vk *VK) VideoGetAlbumByID(params Params) (response VideoGetAlbumByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.getAlbumById", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoGetAlbumsResponse struct.
|
||||
type VideoGetAlbumsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.VideoVideoAlbum `json:"items"`
|
||||
}
|
||||
|
||||
// VideoGetAlbums returns a list of video albums owned by a user or community.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/video.getAlbums
|
||||
func (vk *VK) VideoGetAlbums(params Params) (response VideoGetAlbumsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.getAlbums", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// VideoGetAlbumsExtendedResponse struct.
|
||||
type VideoGetAlbumsExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.VideoVideoAlbumFull `json:"items"`
|
||||
}
|
||||
|
||||
// VideoGetAlbumsExtended returns a list of video albums owned by a user or community.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/video.getAlbums
|
||||
func (vk *VK) VideoGetAlbumsExtended(params Params) (response VideoGetAlbumsExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.getAlbums", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// VideoGetAlbumsByVideoResponse struct.
|
||||
type VideoGetAlbumsByVideoResponse []int
|
||||
|
||||
// VideoGetAlbumsByVideo returns a list of albums in which the video is located.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/video.getAlbumsByVideo
|
||||
func (vk *VK) VideoGetAlbumsByVideo(params Params) (response VideoGetAlbumsByVideoResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.getAlbumsByVideo", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// VideoGetAlbumsByVideoExtendedResponse struct.
|
||||
type VideoGetAlbumsByVideoExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.VideoVideoAlbumFull `json:"items"`
|
||||
}
|
||||
|
||||
// VideoGetAlbumsByVideoExtended returns a list of albums in which the video is located.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/video.getAlbumsByVideo
|
||||
func (vk *VK) VideoGetAlbumsByVideoExtended(params Params) (response VideoGetAlbumsByVideoExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.getAlbumsByVideo", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// VideoGetCommentsResponse struct.
|
||||
type VideoGetCommentsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
}
|
||||
|
||||
// VideoGetComments returns a list of comments on a video.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/video.getComments
|
||||
func (vk *VK) VideoGetComments(params Params) (response VideoGetCommentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.getComments", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// VideoGetCommentsExtendedResponse struct.
|
||||
type VideoGetCommentsExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// VideoGetCommentsExtended returns a list of comments on a video.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/video.getComments
|
||||
func (vk *VK) VideoGetCommentsExtended(params Params) (response VideoGetCommentsExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.getComments", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// VideoRemoveFromAlbum allows you to remove the video from the album.
|
||||
//
|
||||
// https://vk.com/dev/video.removeFromAlbum
|
||||
func (vk *VK) VideoRemoveFromAlbum(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.removeFromAlbum", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoReorderAlbums reorders the album in the list of user video albums.
|
||||
//
|
||||
// https://vk.com/dev/video.reorderAlbums
|
||||
func (vk *VK) VideoReorderAlbums(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.reorderAlbums", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoReorderVideos reorders the video in the video album.
|
||||
//
|
||||
// https://vk.com/dev/video.reorderVideos
|
||||
func (vk *VK) VideoReorderVideos(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.reorderVideos", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoReport reports (submits a complaint about) a video.
|
||||
//
|
||||
// https://vk.com/dev/video.report
|
||||
func (vk *VK) VideoReport(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.report", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoReportComment reports (submits a complaint about) a comment on a video.
|
||||
//
|
||||
// https://vk.com/dev/video.reportComment
|
||||
func (vk *VK) VideoReportComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.reportComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoRestore restores a previously deleted video.
|
||||
//
|
||||
// https://vk.com/dev/video.restore
|
||||
func (vk *VK) VideoRestore(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.restore", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoRestoreComment restores a previously deleted comment on a video.
|
||||
//
|
||||
// https://vk.com/dev/video.restoreComment
|
||||
func (vk *VK) VideoRestoreComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("video.restoreComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoSaveResponse struct.
|
||||
type VideoSaveResponse object.VideoSaveResult
|
||||
|
||||
// VideoSave returns a server address (required for upload) and video data.
|
||||
//
|
||||
// https://vk.com/dev/video.save
|
||||
func (vk *VK) VideoSave(params Params) (response VideoSaveResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.save", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// VideoSearchResponse struct.
|
||||
type VideoSearchResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.VideoVideo `json:"items"`
|
||||
}
|
||||
|
||||
// VideoSearch returns a list of videos under the set search criterion.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/video.search
|
||||
func (vk *VK) VideoSearch(params Params) (response VideoSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.search", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// VideoSearchExtendedResponse struct.
|
||||
type VideoSearchExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.VideoVideo `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// VideoSearchExtended returns a list of videos under the set search criterion.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/video.search
|
||||
func (vk *VK) VideoSearchExtended(params Params) (response VideoSearchExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("video.search", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
@ -0,0 +1,383 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// WallCheckCopyrightLink method.
|
||||
//
|
||||
// https://vk.com/dev/wall.checkCopyrightLink
|
||||
func (vk *VK) WallCheckCopyrightLink(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.checkCopyrightLink", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallCloseComments turn off post commenting.
|
||||
//
|
||||
// https://vk.com/dev/wall.closeComments
|
||||
func (vk *VK) WallCloseComments(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.closeComments", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallCreateCommentResponse struct.
|
||||
type WallCreateCommentResponse struct {
|
||||
CommentID int `json:"comment_id"`
|
||||
ParentsStack []int `json:"parents_stack"`
|
||||
}
|
||||
|
||||
// WallCreateComment adds a comment to a post on a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.createComment
|
||||
func (vk *VK) WallCreateComment(params Params) (response WallCreateCommentResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.createComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallDelete deletes a post from a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.delete
|
||||
func (vk *VK) WallDelete(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.delete", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallDeleteComment deletes a comment on a post on a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.deleteComment
|
||||
func (vk *VK) WallDeleteComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.deleteComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallEditResponse struct.
|
||||
type WallEditResponse struct {
|
||||
PostID int `json:"post_id"`
|
||||
}
|
||||
|
||||
// WallEdit edits a post on a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.edit
|
||||
func (vk *VK) WallEdit(params Params) (response WallEditResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.edit", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallEditAdsStealth allows to edit hidden post.
|
||||
//
|
||||
// https://vk.com/dev/wall.editAdsStealth
|
||||
func (vk *VK) WallEditAdsStealth(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.editAdsStealth", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallEditComment edits a comment on a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.editComment
|
||||
func (vk *VK) WallEditComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.editComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallGetResponse struct.
|
||||
type WallGetResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallpost `json:"items"`
|
||||
}
|
||||
|
||||
// WallGet returns a list of posts on a user wall or community wall.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/wall.get
|
||||
func (vk *VK) WallGet(params Params) (response WallGetResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.get", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallGetExtendedResponse struct.
|
||||
type WallGetExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallpost `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// WallGetExtended returns a list of posts on a user wall or community wall.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/wall.get
|
||||
func (vk *VK) WallGetExtended(params Params) (response WallGetExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.get", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallGetByIDResponse struct.
|
||||
type WallGetByIDResponse []object.WallWallpost
|
||||
|
||||
// WallGetByID returns a list of posts from user or community walls by their IDs.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/wall.getById
|
||||
func (vk *VK) WallGetByID(params Params) (response WallGetByIDResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.getById", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallGetByIDExtendedResponse struct.
|
||||
type WallGetByIDExtendedResponse struct {
|
||||
Items []object.WallWallpost `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// WallGetByIDExtended returns a list of posts from user or community walls by their IDs.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/wall.getById
|
||||
func (vk *VK) WallGetByIDExtended(params Params) (response WallGetByIDExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.getById", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallGetCommentResponse struct.
|
||||
type WallGetCommentResponse struct {
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
CanPost object.BaseBoolInt `json:"can_post"`
|
||||
ShowReplyButton object.BaseBoolInt `json:"show_reply_button"`
|
||||
GroupsCanPost object.BaseBoolInt `json:"groups_can_post"`
|
||||
CurrentLevelCount int `json:"current_level_count"`
|
||||
}
|
||||
|
||||
// WallGetComment allows to obtain wall comment info.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/wall.getComment
|
||||
func (vk *VK) WallGetComment(params Params) (response WallGetCommentResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.getComment", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallGetCommentExtendedResponse struct.
|
||||
type WallGetCommentExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
CanPost object.BaseBoolInt `json:"can_post"`
|
||||
ShowReplyButton object.BaseBoolInt `json:"show_reply_button"`
|
||||
GroupsCanPost object.BaseBoolInt `json:"groups_can_post"`
|
||||
CurrentLevelCount int `json:"current_level_count"`
|
||||
Profiles []object.UsersUser `json:"profiles"`
|
||||
Groups []object.GroupsGroup `json:"groups"`
|
||||
}
|
||||
|
||||
// WallGetCommentExtended allows to obtain wall comment info.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/wall.getComment
|
||||
func (vk *VK) WallGetCommentExtended(params Params) (response WallGetCommentExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.getComment", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallGetCommentsResponse struct.
|
||||
type WallGetCommentsResponse struct {
|
||||
CanPost object.BaseBoolInt `json:"can_post"`
|
||||
ShowReplyButton object.BaseBoolInt `json:"show_reply_button"`
|
||||
GroupsCanPost object.BaseBoolInt `json:"groups_can_post"`
|
||||
CurrentLevelCount int `json:"current_level_count"`
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
}
|
||||
|
||||
// WallGetComments returns a list of comments on a post on a user wall or community wall.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/wall.getComments
|
||||
func (vk *VK) WallGetComments(params Params) (response WallGetCommentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.getComments", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallGetCommentsExtendedResponse struct.
|
||||
type WallGetCommentsExtendedResponse struct {
|
||||
CanPost object.BaseBoolInt `json:"can_post"`
|
||||
ShowReplyButton object.BaseBoolInt `json:"show_reply_button"`
|
||||
GroupsCanPost object.BaseBoolInt `json:"groups_can_post"`
|
||||
CurrentLevelCount int `json:"current_level_count"`
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallComment `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// WallGetCommentsExtended returns a list of comments on a post on a user wall or community wall.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/wall.getComments
|
||||
func (vk *VK) WallGetCommentsExtended(params Params) (response WallGetCommentsExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.getComments", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallGetRepostsResponse struct.
|
||||
type WallGetRepostsResponse struct {
|
||||
Items []object.WallWallpost `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// WallGetReposts returns information about reposts of a post on user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.getReposts
|
||||
func (vk *VK) WallGetReposts(params Params) (response WallGetRepostsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.getReposts", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallOpenComments includes posting comments.
|
||||
//
|
||||
// https://vk.com/dev/wall.openComments
|
||||
func (vk *VK) WallOpenComments(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.openComments", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallPin pins the post on wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.pin
|
||||
func (vk *VK) WallPin(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.pin", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallPostResponse struct.
|
||||
type WallPostResponse struct {
|
||||
PostID int `json:"post_id"`
|
||||
}
|
||||
|
||||
// WallPost adds a new post on a user wall or community wall.Can also be used to publish suggested or scheduled posts.
|
||||
//
|
||||
// https://vk.com/dev/wall.post
|
||||
func (vk *VK) WallPost(params Params) (response WallPostResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.post", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallPostAdsStealthResponse struct.
|
||||
type WallPostAdsStealthResponse struct {
|
||||
PostID int `json:"post_id"`
|
||||
}
|
||||
|
||||
// WallPostAdsStealth allows to create hidden post which will
|
||||
// not be shown on the community's wall and can be used for creating
|
||||
// an ad with type "Community post".
|
||||
//
|
||||
// https://vk.com/dev/wall.postAdsStealth
|
||||
func (vk *VK) WallPostAdsStealth(params Params) (response WallPostAdsStealthResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.postAdsStealth", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallReportComment reports (submits a complaint about) a comment on a post on a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.reportComment
|
||||
func (vk *VK) WallReportComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.reportComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallReportPost reports (submits a complaint about) a post on a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.reportPost
|
||||
func (vk *VK) WallReportPost(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.reportPost", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallRepostResponse struct.
|
||||
type WallRepostResponse struct {
|
||||
Success int `json:"success"`
|
||||
PostID int `json:"post_id"`
|
||||
RepostsCount int `json:"reposts_count"`
|
||||
LikesCount int `json:"likes_count"`
|
||||
WallRepostCount int `json:"wall_repost_count"`
|
||||
MailRepostCount int `json:"mail_repost_count"`
|
||||
}
|
||||
|
||||
// WallRepost reposts ( copies) an object to a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.repost
|
||||
func (vk *VK) WallRepost(params Params) (response WallRepostResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.repost", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallRestore restores a post deleted from a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.restore
|
||||
func (vk *VK) WallRestore(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.restore", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallRestoreComment restores a comment deleted from a user wall or community wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.restoreComment
|
||||
func (vk *VK) WallRestoreComment(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.restoreComment", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WallSearchResponse struct.
|
||||
type WallSearchResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallpost `json:"items"`
|
||||
}
|
||||
|
||||
// WallSearch allows to search posts on user or community walls.
|
||||
//
|
||||
// extended=0
|
||||
//
|
||||
// https://vk.com/dev/wall.search
|
||||
func (vk *VK) WallSearch(params Params) (response WallSearchResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.search", &response, params, Params{"extended": false})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallSearchExtendedResponse struct.
|
||||
type WallSearchExtendedResponse struct {
|
||||
Count int `json:"count"`
|
||||
Items []object.WallWallpost `json:"items"`
|
||||
object.ExtendedResponse
|
||||
}
|
||||
|
||||
// WallSearchExtended allows to search posts on user or community walls.
|
||||
//
|
||||
// extended=1
|
||||
//
|
||||
// https://vk.com/dev/wall.search
|
||||
func (vk *VK) WallSearchExtended(params Params) (response WallSearchExtendedResponse, err error) {
|
||||
err = vk.RequestUnmarshal("wall.search", &response, params, Params{"extended": true})
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// WallUnpin unpins the post on wall.
|
||||
//
|
||||
// https://vk.com/dev/wall.unpin
|
||||
func (vk *VK) WallUnpin(params Params) (response int, err error) {
|
||||
err = vk.RequestUnmarshal("wall.unpin", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,33 @@
|
||||
package api // import "github.com/SevereCloud/vksdk/v2/api"
|
||||
|
||||
import (
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// WidgetsGetCommentsResponse struct.
|
||||
type WidgetsGetCommentsResponse struct {
|
||||
Count int `json:"count"`
|
||||
Posts []object.WidgetsWidgetComment `json:"posts"`
|
||||
}
|
||||
|
||||
// WidgetsGetComments gets a list of comments for the page added through the Comments widget.
|
||||
//
|
||||
// https://vk.com/dev/widgets.getComments
|
||||
func (vk *VK) WidgetsGetComments(params Params) (response WidgetsGetCommentsResponse, err error) {
|
||||
err = vk.RequestUnmarshal("widgets.getComments", &response, params)
|
||||
return
|
||||
}
|
||||
|
||||
// WidgetsGetPagesResponse struct.
|
||||
type WidgetsGetPagesResponse struct {
|
||||
Count int `json:"count"`
|
||||
Pages []object.WidgetsWidgetPage `json:"pages"`
|
||||
}
|
||||
|
||||
// WidgetsGetPages gets a list of application/site pages where the Comments widget or Like widget is installed.
|
||||
//
|
||||
// https://vk.com/dev/widgets.getPages
|
||||
func (vk *VK) WidgetsGetPages(params Params) (response WidgetsGetPagesResponse, err error) {
|
||||
err = vk.RequestUnmarshal("widgets.getPages", &response, params)
|
||||
return
|
||||
}
|
@ -0,0 +1,12 @@
|
||||
/*
|
||||
Package vksdk implements the basic VK API functions.
|
||||
|
||||
Source https://github.com/SevereCloud/vksdk
|
||||
*/
|
||||
package vksdk
|
||||
|
||||
// Module constants.
|
||||
const (
|
||||
Version = "2.9.0"
|
||||
API = "5.126"
|
||||
)
|
@ -0,0 +1,17 @@
|
||||
package events // import "github.com/SevereCloud/vksdk/v2/events"
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"github.com/SevereCloud/vksdk/v2/internal"
|
||||
)
|
||||
|
||||
// GroupIDFromContext returns the GroupID from context.
|
||||
func GroupIDFromContext(ctx context.Context) int {
|
||||
return ctx.Value(internal.GroupIDKey).(int)
|
||||
}
|
||||
|
||||
// EventIDFromContext returns the EventID from context.
|
||||
func EventIDFromContext(ctx context.Context) string {
|
||||
return ctx.Value(internal.EventIDKey).(string)
|
||||
}
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,359 @@
|
||||
package events // import "github.com/SevereCloud/vksdk/v2/events"
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
|
||||
"github.com/SevereCloud/vksdk/v2/object"
|
||||
)
|
||||
|
||||
// MessageNewObject struct.
|
||||
type MessageNewObject struct {
|
||||
Message object.MessagesMessage `json:"message"`
|
||||
ClientInfo object.ClientInfo `json:"client_info"`
|
||||
}
|
||||
|
||||
// MessageReplyObject struct.
|
||||
type MessageReplyObject object.MessagesMessage
|
||||
|
||||
// MessageEditObject struct.
|
||||
type MessageEditObject object.MessagesMessage
|
||||
|
||||
// MessageAllowObject struct.
|
||||
type MessageAllowObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
Key string `json:"key"`
|
||||
}
|
||||
|
||||
// MessageDenyObject struct.
|
||||
type MessageDenyObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
}
|
||||
|
||||
// MessageTypingStateObject struct.
|
||||
type MessageTypingStateObject struct {
|
||||
State string `json:"state"`
|
||||
FromID int `json:"from_id"`
|
||||
ToID int `json:"to_id"`
|
||||
}
|
||||
|
||||
// MessageEventObject struct.
|
||||
type MessageEventObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
PeerID int `json:"peer_id"`
|
||||
EventID string `json:"event_id"`
|
||||
Payload json.RawMessage `json:"payload"`
|
||||
ConversationMessageID int `json:"conversation_message_id"`
|
||||
}
|
||||
|
||||
// PhotoNewObject struct.
|
||||
type PhotoNewObject object.PhotosPhoto
|
||||
|
||||
// PhotoCommentNewObject struct.
|
||||
type PhotoCommentNewObject object.WallWallComment
|
||||
|
||||
// PhotoCommentEditObject struct.
|
||||
type PhotoCommentEditObject object.WallWallComment
|
||||
|
||||
// PhotoCommentRestoreObject struct.
|
||||
type PhotoCommentRestoreObject object.WallWallComment
|
||||
|
||||
// PhotoCommentDeleteObject struct.
|
||||
type PhotoCommentDeleteObject struct {
|
||||
OwnerID int `json:"owner_id"`
|
||||
ID int `json:"id"`
|
||||
UserID int `json:"user_id"`
|
||||
DeleterID int `json:"deleter_id"`
|
||||
PhotoID int `json:"photo_id"`
|
||||
}
|
||||
|
||||
// AudioNewObject struct.
|
||||
type AudioNewObject object.AudioAudio
|
||||
|
||||
// VideoNewObject struct.
|
||||
type VideoNewObject object.VideoVideo
|
||||
|
||||
// VideoCommentNewObject struct.
|
||||
type VideoCommentNewObject object.WallWallComment
|
||||
|
||||
// VideoCommentEditObject struct.
|
||||
type VideoCommentEditObject object.WallWallComment
|
||||
|
||||
// VideoCommentRestoreObject struct.
|
||||
type VideoCommentRestoreObject object.WallWallComment
|
||||
|
||||
// VideoCommentDeleteObject struct.
|
||||
type VideoCommentDeleteObject struct {
|
||||
OwnerID int `json:"owner_id"`
|
||||
ID int `json:"id"`
|
||||
UserID int `json:"user_id"`
|
||||
DeleterID int `json:"deleter_id"`
|
||||
VideoID int `json:"video_id"`
|
||||
}
|
||||
|
||||
// WallPostNewObject struct.
|
||||
type WallPostNewObject object.WallWallpost
|
||||
|
||||
// WallRepostObject struct.
|
||||
type WallRepostObject object.WallWallpost
|
||||
|
||||
// WallReplyNewObject struct.
|
||||
type WallReplyNewObject object.WallWallComment
|
||||
|
||||
// WallReplyEditObject struct.
|
||||
type WallReplyEditObject object.WallWallComment
|
||||
|
||||
// WallReplyRestoreObject struct.
|
||||
type WallReplyRestoreObject object.WallWallComment
|
||||
|
||||
// WallReplyDeleteObject struct.
|
||||
type WallReplyDeleteObject struct {
|
||||
OwnerID int `json:"owner_id"`
|
||||
ID int `json:"id"`
|
||||
DeleterID int `json:"deleter_id"`
|
||||
PostID int `json:"post_id"`
|
||||
}
|
||||
|
||||
// BoardPostNewObject struct.
|
||||
type BoardPostNewObject object.BoardTopicComment
|
||||
|
||||
// BoardPostEditObject struct.
|
||||
type BoardPostEditObject object.BoardTopicComment
|
||||
|
||||
// BoardPostRestoreObject struct.
|
||||
type BoardPostRestoreObject object.BoardTopicComment
|
||||
|
||||
// BoardPostDeleteObject struct.
|
||||
type BoardPostDeleteObject struct {
|
||||
TopicOwnerID int `json:"topic_owner_id"`
|
||||
TopicID int `json:"topic_id"`
|
||||
ID int `json:"id"`
|
||||
}
|
||||
|
||||
// MarketCommentNewObject struct.
|
||||
type MarketCommentNewObject object.WallWallComment
|
||||
|
||||
// MarketCommentEditObject struct.
|
||||
type MarketCommentEditObject object.WallWallComment
|
||||
|
||||
// MarketCommentRestoreObject struct.
|
||||
type MarketCommentRestoreObject object.WallWallComment
|
||||
|
||||
// MarketCommentDeleteObject struct.
|
||||
type MarketCommentDeleteObject struct {
|
||||
OwnerID int `json:"owner_id"`
|
||||
ID int `json:"id"`
|
||||
UserID int `json:"user_id"`
|
||||
DeleterID int `json:"deleter_id"`
|
||||
ItemID int `json:"item_id"`
|
||||
}
|
||||
|
||||
// MarketOrderNewObject struct.
|
||||
type MarketOrderNewObject object.MarketOrder
|
||||
|
||||
// MarketOrderEditObject struct.
|
||||
type MarketOrderEditObject object.MarketOrder
|
||||
|
||||
// GroupLeaveObject struct.
|
||||
type GroupLeaveObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
Self object.BaseBoolInt `json:"self"`
|
||||
}
|
||||
|
||||
// GroupJoinObject struct.
|
||||
type GroupJoinObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
JoinType string `json:"join_type"`
|
||||
}
|
||||
|
||||
// UserBlockObject struct.
|
||||
type UserBlockObject struct {
|
||||
AdminID int `json:"admin_id"`
|
||||
UserID int `json:"user_id"`
|
||||
UnblockDate int `json:"unblock_date"`
|
||||
Reason int `json:"reason"`
|
||||
Comment string `json:"comment"`
|
||||
}
|
||||
|
||||
// UserUnblockObject struct.
|
||||
type UserUnblockObject struct {
|
||||
AdminID int `json:"admin_id"`
|
||||
UserID int `json:"user_id"`
|
||||
ByEndDate int `json:"by_end_date"`
|
||||
}
|
||||
|
||||
// PollVoteNewObject struct.
|
||||
//
|
||||
// BUG(VK): при голосовании за несколько вариантов, возвращается только один.
|
||||
type PollVoteNewObject struct {
|
||||
OwnerID int `json:"owner_id"`
|
||||
PollID int `json:"poll_id"`
|
||||
OptionID int `json:"option_id"`
|
||||
UserID int `json:"user_id"`
|
||||
}
|
||||
|
||||
// GroupOfficersEditObject struct.
|
||||
type GroupOfficersEditObject struct {
|
||||
AdminID int `json:"admin_id"`
|
||||
UserID int `json:"user_id"`
|
||||
LevelOld int `json:"level_old"`
|
||||
LevelNew int `json:"level_new"`
|
||||
}
|
||||
|
||||
// Changes struct.
|
||||
type Changes struct {
|
||||
OldValue string `json:"old_value"`
|
||||
NewValue string `json:"new_value"`
|
||||
}
|
||||
|
||||
// ChangesInt struct.
|
||||
type ChangesInt struct {
|
||||
OldValue int `json:"old_value"`
|
||||
NewValue int `json:"new_value"`
|
||||
}
|
||||
|
||||
// GroupChangeSettingsObject struct.
|
||||
//
|
||||
// BUG(VK): Phone https://vk.com/bugtracker?act=show&id=64240
|
||||
//
|
||||
// BUG(VK): Email https://vk.com/bugtracker?act=show&id=86650
|
||||
type GroupChangeSettingsObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
Changes struct {
|
||||
Title Changes `json:"title"`
|
||||
Description Changes `json:"description"`
|
||||
Access ChangesInt `json:"access"`
|
||||
ScreenName Changes `json:"screen_name"`
|
||||
PublicCategory ChangesInt `json:"public_category"`
|
||||
PublicSubcategory ChangesInt `json:"public_subcategory"`
|
||||
AgeLimits ChangesInt `json:"age_limits"`
|
||||
Website Changes `json:"website"`
|
||||
StatusDefault Changes `json:"status_default"`
|
||||
Wall ChangesInt `json:"wall"` // на основе ответа
|
||||
Replies ChangesInt `json:"replies"` // на основе ответа
|
||||
Topics ChangesInt `json:"topics"` // на основе ответа
|
||||
Audio ChangesInt `json:"audio"` // на основе ответа
|
||||
Photos ChangesInt `json:"photos"` // на основе ответа
|
||||
Video ChangesInt `json:"video"` // на основе ответа
|
||||
Market ChangesInt `json:"market"` // на основе ответа
|
||||
Docs ChangesInt `json:"docs"` // на основе ответа
|
||||
Messages ChangesInt `json:"messages"` // на основе ответа
|
||||
EventGroupID ChangesInt `json:"event_group_id"` // на основе ответа
|
||||
Links Changes `json:"links"` // на основе ответа
|
||||
Email Changes `json:"email"` // на основе ответа
|
||||
EventStartDate ChangesInt `json:"event_start_date::"` // на основе ответа
|
||||
EventFinishDate ChangesInt `json:"event_finish_date:"` // на основе ответа
|
||||
Subject Changes `json:"subject"` // на основе ответа
|
||||
MarketWiki Changes `json:"market_wiki"` // на основе ответа
|
||||
DisableMarketComments ChangesInt `json:"disable_market_comments"` // на основе ответа
|
||||
Phone ChangesInt `json:"phone"` // на основе ответа
|
||||
CountryID ChangesInt `json:"country_id"` // на основе ответа
|
||||
CityID ChangesInt `json:"city_id"` // на основе ответа
|
||||
} `json:"Changes"`
|
||||
}
|
||||
|
||||
// GroupChangePhotoObject struct.
|
||||
type GroupChangePhotoObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
Photo object.PhotosPhoto `json:"photo"`
|
||||
}
|
||||
|
||||
// VkpayTransactionObject struct.
|
||||
type VkpayTransactionObject struct {
|
||||
FromID int `json:"from_id"`
|
||||
Amount int `json:"amount"`
|
||||
Description string `json:"description"`
|
||||
Date int `json:"date"`
|
||||
}
|
||||
|
||||
// LeadFormsNewObject struct.
|
||||
type LeadFormsNewObject struct {
|
||||
LeadID int `json:"lead_id"`
|
||||
GroupID int `json:"group_id"`
|
||||
UserID int `json:"user_id"`
|
||||
FormID int `json:"form_id"`
|
||||
FormName string `json:"form_name"`
|
||||
AdID int `json:"ad_id"`
|
||||
Answers []struct {
|
||||
Key string `json:"key"`
|
||||
Question string `json:"question"`
|
||||
Answer string `json:"answer"`
|
||||
} `json:"answers"`
|
||||
}
|
||||
|
||||
// AppPayloadObject struct.
|
||||
type AppPayloadObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
AppID int `json:"app_id"`
|
||||
Payload string `json:"payload"`
|
||||
}
|
||||
|
||||
// MessageReadObject struct.
|
||||
type MessageReadObject struct {
|
||||
FromID int `json:"from_id"`
|
||||
PeerID int `json:"peer_id"`
|
||||
ReadMessageID int `json:"read_message_id"`
|
||||
}
|
||||
|
||||
// LikeAddObject struct.
|
||||
type LikeAddObject struct {
|
||||
LikerID int `json:"liker_id"`
|
||||
ObjectType string `json:"object_type"`
|
||||
ObjectOwnerID int `json:"object_owner_id"`
|
||||
ObjectID int `json:"object_id"`
|
||||
ThreadReplyID int `json:"thread_reply_id"`
|
||||
PostID int `json:"post_id"` // for comment
|
||||
}
|
||||
|
||||
// LikeRemoveObject struct.
|
||||
type LikeRemoveObject struct {
|
||||
LikerID int `json:"liker_id"`
|
||||
ObjectType string `json:"object_type"`
|
||||
ObjectOwnerID int `json:"object_owner_id"`
|
||||
ObjectID int `json:"object_id"`
|
||||
ThreadReplyID int `json:"thread_reply_id"`
|
||||
PostID int `json:"post_id"` // for comment
|
||||
}
|
||||
|
||||
// DonutSubscriptionCreateObject struct.
|
||||
type DonutSubscriptionCreateObject struct {
|
||||
Amount int `json:"amount"`
|
||||
AmountWithoutFee float64 `json:"amount_without_fee"`
|
||||
UserID int `json:"user_id"`
|
||||
}
|
||||
|
||||
// DonutSubscriptionProlongedObject struct.
|
||||
type DonutSubscriptionProlongedObject struct {
|
||||
Amount int `json:"amount"`
|
||||
AmountWithoutFee float64 `json:"amount_without_fee"`
|
||||
UserID int `json:"user_id"`
|
||||
}
|
||||
|
||||
// DonutSubscriptionExpiredObject struct.
|
||||
type DonutSubscriptionExpiredObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
}
|
||||
|
||||
// DonutSubscriptionCancelledObject struct.
|
||||
type DonutSubscriptionCancelledObject struct {
|
||||
UserID int `json:"user_id"`
|
||||
}
|
||||
|
||||
// DonutSubscriptionPriceChangedObject struct.
|
||||
type DonutSubscriptionPriceChangedObject struct {
|
||||
AmountOld int `json:"amount_old"`
|
||||
AmountNew int `json:"amount_new"`
|
||||
AmountDiff float64 `json:"amount_diff"`
|
||||
AmountDiffWithoutFee float64 `json:"amount_diff_without_fee"`
|
||||
UserID int `json:"user_id"`
|
||||
}
|
||||
|
||||
// DonutMoneyWithdrawObject struct.
|
||||
type DonutMoneyWithdrawObject struct {
|
||||
Amount int `json:"amount"`
|
||||
AmountWithoutFee float64 `json:"amount_without_fee"`
|
||||
}
|
||||
|
||||
// DonutMoneyWithdrawErrorObject struct.
|
||||
type DonutMoneyWithdrawErrorObject struct {
|
||||
Reason string `json:"reason"`
|
||||
}
|
@ -0,0 +1,10 @@
|
||||
module github.com/SevereCloud/vksdk/v2
|
||||
|
||||
go 1.13
|
||||
|
||||
require (
|
||||
github.com/gorilla/schema v1.2.0
|
||||
github.com/gorilla/websocket v1.4.2
|
||||
github.com/stretchr/testify v1.6.1
|
||||
golang.org/x/text v0.3.4
|
||||
)
|
@ -0,0 +1,18 @@
|
||||
github.com/davecgh/go-spew v1.1.0 h1:ZDRjVQ15GmhC3fiQ8ni8+OwkZQO4DARzQgrnXU1Liz8=
|
||||
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/gorilla/schema v1.2.0 h1:YufUaxZYCKGFuAq3c96BOhjgd5nmXiOY9NGzF247Tsc=
|
||||
github.com/gorilla/schema v1.2.0/go.mod h1:kgLaKoK1FELgZqMAVxx/5cbj0kT+57qxUrAlIO2eleU=
|
||||
github.com/gorilla/websocket v1.4.2 h1:+/TMaTYc4QFitKJxsQ7Yye35DkWvkdLcvGKqM+x0Ufc=
|
||||
github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE=
|
||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||
github.com/stretchr/testify v1.6.1 h1:hDPOHmpOpP40lSULcqw7IrRb/u7w6RpDC9399XyoNd0=
|
||||
github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||
golang.org/x/text v0.3.4 h1:0YWbFKbhXG/wIiuHDSKpS0Iy7FSA+u45VtBMfQcFTTc=
|
||||
golang.org/x/text v0.3.4/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
|
||||
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
|
||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM=
|
||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie2QXMNeKRTHCNY2nXvo=
|
||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
@ -0,0 +1,60 @@
|
||||
/*
|
||||
Package internal unimportable
|
||||
*/
|
||||
package internal // import "github.com/SevereCloud/vksdk/v2/internal"
|
||||
|
||||
import (
|
||||
"io"
|
||||
"strings"
|
||||
|
||||
"golang.org/x/text/encoding/charmap"
|
||||
"golang.org/x/text/runes"
|
||||
"golang.org/x/text/transform"
|
||||
)
|
||||
|
||||
// illegal is a collection of runes.
|
||||
type illegal struct{}
|
||||
|
||||
// Contains return true.
|
||||
func (i illegal) Contains(r rune) bool {
|
||||
return !(r == 0x09 ||
|
||||
r == 0x0A ||
|
||||
r == 0x0D ||
|
||||
r >= 0x20 && r <= 0xDF77 ||
|
||||
r >= 0xE000 && r <= 0xFFFD ||
|
||||
r >= 0x10000 && r <= 0x10FFFF)
|
||||
}
|
||||
|
||||
// XMLSanitizerReader creates an io.Reader that
|
||||
// wraps another io.Reader and removes illegal xml
|
||||
// characters from the io stream.
|
||||
func XMLSanitizerReader(xml io.Reader) io.Reader {
|
||||
var i illegal
|
||||
t := transform.Chain(runes.Remove(i))
|
||||
|
||||
return transform.NewReader(xml, t)
|
||||
}
|
||||
|
||||
// CharsetUnknownError unknown charset.
|
||||
type CharsetUnknownError struct {
|
||||
Name string
|
||||
}
|
||||
|
||||
// Error returns the message of a CharsetUnknownError.
|
||||
func (c *CharsetUnknownError) Error() string {
|
||||
return "unknown charset: " + c.Name
|
||||
}
|
||||
|
||||
// CharsetReader if non-nil, defines a function to generate
|
||||
// charset-conversion readers, converting from the provided
|
||||
// non-UTF-8 charset into UTF-8. If CharsetReader is nil or
|
||||
// returns an error, parsing stops with an error. One of the
|
||||
// the CharsetReader's result values must be non-nil.
|
||||
func CharsetReader(charset string, input io.Reader) (io.Reader, error) {
|
||||
switch strings.ToLower(charset) {
|
||||
case "windows-1251":
|
||||
return charmap.Windows1251.NewDecoder().Reader(input), nil
|
||||
default:
|
||||
return nil, &CharsetUnknownError{Name: charset}
|
||||
}
|
||||
}
|
@ -0,0 +1,74 @@
|
||||
/*
|
||||
Package internal unimportable
|
||||
*/
|
||||
package internal // import "github.com/SevereCloud/vksdk/v2/internal"
|
||||
|
||||
import (
|
||||
"context"
|
||||
"net/http"
|
||||
|
||||
"github.com/SevereCloud/vksdk/v2"
|
||||
)
|
||||
|
||||
// UserAgent module.
|
||||
const UserAgent = "vksdk/" + vksdk.Version + " (+https://github.com/SevereCloud/vksdk)"
|
||||
|
||||
// ContextKey is just an empty struct. It exists so HTTPClient can be
|
||||
// an immutable public variable with a unique type. It's immutable
|
||||
// because nobody else can create a ContextKey, being unexported.
|
||||
type ContextKey int
|
||||
|
||||
// ContextKey list.
|
||||
const (
|
||||
HTTPClientKey ContextKey = iota
|
||||
UserAgentKey
|
||||
GroupIDKey
|
||||
EventIDKey
|
||||
LongPollTsKey
|
||||
CallbackRetryCounterKey
|
||||
CallbackRetryAfterKey
|
||||
)
|
||||
|
||||
// ContextClient return *http.Client.
|
||||
func ContextClient(ctx context.Context) *http.Client {
|
||||
if ctx != nil {
|
||||
if hc, ok := ctx.Value(HTTPClientKey).(*http.Client); ok {
|
||||
return hc
|
||||
}
|
||||
}
|
||||
|
||||
return http.DefaultClient
|
||||
}
|
||||
|
||||
// ContextUserAgent return User-Agent from context.
|
||||
func ContextUserAgent(ctx context.Context) string {
|
||||
if ctx != nil {
|
||||
if hc, ok := ctx.Value(UserAgentKey).(string); ok {
|
||||
return hc
|
||||
}
|
||||
}
|
||||
|
||||
return UserAgent
|
||||
}
|
||||
|
||||
// DoRequest sends an HTTP request and returns an HTTP response.
|
||||
//
|
||||
// The provided ctx must be non-nil. If it is canceled or times out,
|
||||
// ctx.Err() will be returned.
|
||||
func DoRequest(ctx context.Context, req *http.Request) (*http.Response, error) {
|
||||
client := ContextClient(ctx)
|
||||
|
||||
if req.UserAgent() == "" {
|
||||
req.Header.Set("User-Agent", ContextUserAgent(ctx))
|
||||
}
|
||||
|
||||
resp, err := client.Do(req.WithContext(ctx))
|
||||
// If we got an error, and the context has been canceled,
|
||||
// the context's error is probably more useful.
|
||||
if err != nil {
|
||||
<-ctx.Done()
|
||||
err = ctx.Err()
|
||||
}
|
||||
|
||||
return resp, err
|
||||
}
|
@ -0,0 +1,12 @@
|
||||
package longpoll // import "github.com/SevereCloud/vksdk/v2/longpoll-bot"
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"github.com/SevereCloud/vksdk/v2/internal"
|
||||
)
|
||||
|
||||
// TsFromContext returns the ts from context.
|
||||
func TsFromContext(ctx context.Context) int {
|
||||
return ctx.Value(internal.LongPollTsKey).(int)
|
||||
}
|
@ -0,0 +1,18 @@
|
||||
package longpoll
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// Failed struct.
|
||||
type Failed struct {
|
||||
Code int
|
||||
}
|
||||
|
||||
// Error returns the message of a Failed.
|
||||
func (e Failed) Error() string {
|
||||
return fmt.Sprintf(
|
||||
"longpoll: failed code %d",
|
||||
e.Code,
|
||||
)
|
||||
}
|
@ -0,0 +1,219 @@
|
||||
/*
|
||||
Package longpoll implements Bots Long Poll API.
|
||||
|
||||
See more https://vk.com/dev/bots_longpoll
|
||||
*/
|
||||
package longpoll // import "github.com/SevereCloud/vksdk/v2/longpoll-bot"
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"net/http"
|
||||
|
||||
"github.com/SevereCloud/vksdk/v2"
|
||||
"github.com/SevereCloud/vksdk/v2/api"
|
||||
"github.com/SevereCloud/vksdk/v2/events"
|
||||
"github.com/SevereCloud/vksdk/v2/internal"
|
||||
)
|
||||
|
||||
// Response struct.
|
||||
type Response struct {
|
||||
Ts string `json:"ts"`
|
||||
Updates []events.GroupEvent `json:"updates"`
|
||||
Failed int `json:"failed"`
|
||||
}
|
||||
|
||||
// LongPoll struct.
|
||||
type LongPoll struct {
|
||||
GroupID int
|
||||
Server string
|
||||
Key string
|
||||
Ts string
|
||||
Wait int
|
||||
VK *api.VK
|
||||
Client *http.Client
|
||||
cancel context.CancelFunc
|
||||
|
||||
funcFullResponseList []func(Response)
|
||||
|
||||
events.FuncList
|
||||
}
|
||||
|
||||
// NewLongPoll returns a new LongPoll.
|
||||
//
|
||||
// The LongPoll will use the http.DefaultClient.
|
||||
// This means that if the http.DefaultClient is modified by other components
|
||||
// of your application the modifications will be picked up by the SDK as well.
|
||||
func NewLongPoll(vk *api.VK, groupID int) (*LongPoll, error) {
|
||||
lp := &LongPoll{
|
||||
VK: vk,
|
||||
GroupID: groupID,
|
||||
Wait: 25,
|
||||
Client: http.DefaultClient,
|
||||
}
|
||||
lp.FuncList = *events.NewFuncList()
|
||||
|
||||
err := lp.updateServer(true)
|
||||
|
||||
return lp, err
|
||||
}
|
||||
|
||||
// NewLongPollCommunity returns a new LongPoll for community token.
|
||||
//
|
||||
// The LongPoll will use the http.DefaultClient.
|
||||
// This means that if the http.DefaultClient is modified by other components
|
||||
// of your application the modifications will be picked up by the SDK as well.
|
||||
func NewLongPollCommunity(vk *api.VK) (*LongPoll, error) {
|
||||
resp, err := vk.GroupsGetByID(nil)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
lp := &LongPoll{
|
||||
VK: vk,
|
||||
GroupID: resp[0].ID,
|
||||
Wait: 25,
|
||||
Client: http.DefaultClient,
|
||||
}
|
||||
lp.FuncList = *events.NewFuncList()
|
||||
|
||||
err = lp.updateServer(true)
|
||||
|
||||
return lp, err
|
||||
}
|
||||
|
||||
func (lp *LongPoll) updateServer(updateTs bool) error {
|
||||
params := api.Params{
|
||||
"group_id": lp.GroupID,
|
||||
}
|
||||
|
||||
serverSetting, err := lp.VK.GroupsGetLongPollServer(params)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
lp.Key = serverSetting.Key
|
||||
lp.Server = serverSetting.Server
|
||||
|
||||
if updateTs {
|
||||
lp.Ts = serverSetting.Ts
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (lp *LongPoll) check(ctx context.Context) (response Response, err error) {
|
||||
u := fmt.Sprintf("%s?act=a_check&key=%s&ts=%s&wait=%d", lp.Server, lp.Key, lp.Ts, lp.Wait)
|
||||
|
||||
req, err := http.NewRequestWithContext(ctx, http.MethodGet, u, nil)
|
||||
if err != nil {
|
||||
return response, err
|
||||
}
|
||||
|
||||
resp, err := lp.Client.Do(req)
|
||||
if err != nil {
|
||||
return response, err
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
err = json.NewDecoder(resp.Body).Decode(&response)
|
||||
if err != nil {
|
||||
return response, err
|
||||
}
|
||||
|
||||
err = lp.checkResponse(response)
|
||||
|
||||
return response, err
|
||||
}
|
||||
|
||||
func (lp *LongPoll) checkResponse(response Response) (err error) {
|
||||
switch response.Failed {
|
||||
case 0:
|
||||
lp.Ts = response.Ts
|
||||
case 1:
|
||||
lp.Ts = response.Ts
|
||||
case 2:
|
||||
err = lp.updateServer(false)
|
||||
case 3:
|
||||
err = lp.updateServer(true)
|
||||
default:
|
||||
err = &Failed{response.Failed}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
func (lp *LongPoll) autoSetting(ctx context.Context) error {
|
||||
params := api.Params{
|
||||
"group_id": lp.GroupID,
|
||||
"enabled": true,
|
||||
"api_version": vksdk.API,
|
||||
}.WithContext(ctx)
|
||||
for _, event := range lp.ListEvents() {
|
||||
params[string(event)] = true
|
||||
}
|
||||
|
||||
// Updating LongPoll settings
|
||||
_, err := lp.VK.GroupsSetLongPollSettings(params)
|
||||
|
||||
return err
|
||||
}
|
||||
|
||||
// Run handler.
|
||||
func (lp *LongPoll) Run() error {
|
||||
return lp.RunWithContext(context.Background())
|
||||
}
|
||||
|
||||
// RunWithContext handler.
|
||||
func (lp *LongPoll) RunWithContext(ctx context.Context) error {
|
||||
return lp.run(ctx)
|
||||
}
|
||||
|
||||
func (lp *LongPoll) run(ctx context.Context) error {
|
||||
ctx, lp.cancel = context.WithCancel(ctx)
|
||||
|
||||
err := lp.autoSetting(ctx)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
for {
|
||||
select {
|
||||
case _, ok := <-ctx.Done():
|
||||
if !ok {
|
||||
return nil
|
||||
}
|
||||
default:
|
||||
resp, err := lp.check(ctx)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
ctx = context.WithValue(ctx, internal.LongPollTsKey, resp.Ts)
|
||||
|
||||
for _, event := range resp.Updates {
|
||||
err = lp.Handler(ctx, event)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
for _, f := range lp.funcFullResponseList {
|
||||
f(resp)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Shutdown gracefully shuts down the longpoll without interrupting any active connections.
|
||||
func (lp *LongPoll) Shutdown() {
|
||||
if lp.cancel != nil {
|
||||
lp.cancel()
|
||||
}
|
||||
}
|
||||
|
||||
// FullResponse handler.
|
||||
func (lp *LongPoll) FullResponse(f func(Response)) {
|
||||
lp.funcFullResponseList = append(lp.funcFullResponseList, f)
|
||||
}
|
@ -0,0 +1,142 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// AccountNameRequest struct.
|
||||
type AccountNameRequest struct {
|
||||
FirstName string `json:"first_name"` // First name in request
|
||||
ID int `json:"id"` // Request ID needed to cancel the request
|
||||
LastName string `json:"last_name"` // Last name in request
|
||||
Status string `json:"status"`
|
||||
}
|
||||
|
||||
// AccountPushConversations struct.
|
||||
type AccountPushConversations struct {
|
||||
Count int `json:"count"` // Items count
|
||||
Items []*AccountPushConversationsItem `json:"items"`
|
||||
}
|
||||
|
||||
// AccountPushConversationsItem struct.
|
||||
type AccountPushConversationsItem struct {
|
||||
DisabledUntil int `json:"disabled_until"` // Time until that notifications are disabled in seconds
|
||||
PeerID int `json:"peer_id"` // Peer ID
|
||||
Sound int `json:"sound"` // Information whether the sound are enabled
|
||||
}
|
||||
|
||||
// AccountPushParams struct.
|
||||
type AccountPushParams struct {
|
||||
AppRequest []string `json:"app_request"`
|
||||
Birthday []string `json:"birthday"`
|
||||
Chat []string `json:"chat"`
|
||||
Comment []string `json:"comment"`
|
||||
EventSoon []string `json:"event_soon"`
|
||||
Friend []string `json:"friend"`
|
||||
FriendAccepted []string `json:"friend_accepted"`
|
||||
FriendFound []string `json:"friend_found"`
|
||||
GroupAccepted []string `json:"group_accepted"`
|
||||
GroupInvite []string `json:"group_invite"`
|
||||
Like []string `json:"like"`
|
||||
Mention []string `json:"mention"`
|
||||
Msg []string `json:"msg"`
|
||||
NewPost []string `json:"new_post"`
|
||||
PhotosTag []string `json:"photos_tag"`
|
||||
Reply []string `json:"reply"`
|
||||
Repost []string `json:"repost"`
|
||||
SdkOpen []string `json:"sdk_open"`
|
||||
WallPost []string `json:"wall_post"`
|
||||
WallPublish []string `json:"wall_publish"`
|
||||
}
|
||||
|
||||
// AccountOffer struct.
|
||||
type AccountOffer struct {
|
||||
Description string `json:"description"` // Offer description
|
||||
ID int `json:"id"` // Offer ID
|
||||
Img string `json:"img"` // URL of the preview image
|
||||
Instruction string `json:"instruction"` // Instruction how to process the offer
|
||||
InstructionHTML string `json:"instruction_html"` // Instruction how to process the offer (HTML format)
|
||||
Price int `json:"price"` // Offer price
|
||||
ShortDescription string `json:"short_description"` // Offer short description
|
||||
Tag string `json:"tag"` // Offer tag
|
||||
Title string `json:"title"` // Offer title
|
||||
}
|
||||
|
||||
// AccountAccountCounters struct.
|
||||
type AccountAccountCounters struct {
|
||||
AppRequests int `json:"app_requests"` // New app requests number
|
||||
Events int `json:"events"` // New events number
|
||||
Friends int `json:"friends"` // New friends requests number
|
||||
FriendsRecommendations int `json:"friends_recommendations"` // New friends recommendations number
|
||||
FriendsSuggestions int `json:"friends_suggestions"` // New friends suggestions number
|
||||
Gifts int `json:"gifts"` // New gifts number
|
||||
Groups int `json:"groups"` // New groups number
|
||||
Messages int `json:"messages"` // New messages number
|
||||
Notifications int `json:"notifications"` // New notifications number
|
||||
Photos int `json:"photos"` // New photo tags number
|
||||
SDK int `json:"sdk"` // New SDK number
|
||||
MenuDiscoverBadge int `json:"menu_discover_badge"` // New menu discover badge number
|
||||
MenuClipsBadge int `json:"menu_clips_badge"` // New menu clips badge number
|
||||
Videos int `json:"videos"` // New video tags number
|
||||
Faves int `json:"faves"` // New faves number
|
||||
}
|
||||
|
||||
// AccountInfo struct.
|
||||
type AccountInfo struct {
|
||||
|
||||
// Country code.
|
||||
Country string `json:"country"`
|
||||
|
||||
// Language ID.
|
||||
Lang int `json:"lang"`
|
||||
|
||||
// Information whether HTTPS-only is enabled.
|
||||
HTTPSRequired BaseBoolInt `json:"https_required"`
|
||||
|
||||
// Information whether user has been processed intro.
|
||||
Intro BaseBoolInt `json:"intro"`
|
||||
|
||||
// Information whether wall comments should be hidden.
|
||||
NoWallReplies BaseBoolInt `json:"no_wall_replies"`
|
||||
|
||||
// Information whether only owners posts should be shown.
|
||||
OwnPostsDefault BaseBoolInt `json:"own_posts_default"`
|
||||
|
||||
// Two factor authentication is enabled.
|
||||
TwoFactorRequired BaseBoolInt `json:"2fa_required"`
|
||||
EuUser BaseBoolInt `json:"eu_user"`
|
||||
CommunityComments BaseBoolInt `json:"community_comments"`
|
||||
IsLiveStreamingEnabled BaseBoolInt `json:"is_live_streaming_enabled"`
|
||||
IsNewLiveStreamingEnabled BaseBoolInt `json:"is_new_live_streaming_enabled"`
|
||||
LinkRedirects map[string]string `json:"link_redirects"`
|
||||
}
|
||||
|
||||
// AccountPushSettings struct.
|
||||
type AccountPushSettings struct {
|
||||
Conversations AccountPushConversations `json:"conversations"`
|
||||
|
||||
// Information whether notifications are disabled.
|
||||
Disabled BaseBoolInt `json:"disabled"`
|
||||
|
||||
// Time until that notifications are disabled in Unixtime.
|
||||
DisabledUntil int `json:"disabled_until"`
|
||||
Settings AccountPushParams `json:"settings"`
|
||||
}
|
||||
|
||||
// AccountUserSettings struct.
|
||||
type AccountUserSettings struct {
|
||||
Bdate string `json:"bdate"` // User's date of birth
|
||||
BdateVisibility int `json:"bdate_visibility"` // Information whether user's birthdate are hidden
|
||||
City BaseObject `json:"city"`
|
||||
Country BaseCountry `json:"country"`
|
||||
FirstName string `json:"first_name"` // User first name
|
||||
HomeTown string `json:"home_town"` // User's hometown
|
||||
LastName string `json:"last_name"` // User last name
|
||||
MaidenName string `json:"maiden_name"` // User maiden name
|
||||
NameRequest AccountNameRequest `json:"name_request"`
|
||||
Phone string `json:"phone"` // User phone number with some hidden digits
|
||||
Relation int `json:"relation"` // User relationship status
|
||||
RelationPartner UsersUserMin `json:"relation_partner"`
|
||||
RelationPending BaseBoolInt `json:"relation_pending"` // Information whether relation status is pending
|
||||
RelationRequests []UsersUserMin `json:"relation_requests"`
|
||||
ScreenName string `json:"screen_name"` // Domain name of the user's page
|
||||
Sex int `json:"sex"` // User sex
|
||||
Status string `json:"status"` // User status
|
||||
ID int `json:"id"` // TODO: Check it https://vk.com/bug230405 (always return 0)
|
||||
}
|
@ -0,0 +1,321 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// AdsAccesses struct.
|
||||
type AdsAccesses struct {
|
||||
ClientID string `json:"client_id"`
|
||||
Role string `json:"role"`
|
||||
}
|
||||
|
||||
// AdsAccount struct.
|
||||
type AdsAccount struct {
|
||||
AccessRole string `json:"access_role"`
|
||||
AccountID int `json:"account_id"` // Account ID
|
||||
AccountName string `json:"account_name"`
|
||||
AccountStatus BaseBoolInt `json:"account_status"` // Information whether account is active
|
||||
CanViewBudget BaseBoolInt `json:"can_view_budget"`
|
||||
AccountType string `json:"account_type"`
|
||||
}
|
||||
|
||||
// AdsAdLayout struct.
|
||||
type AdsAdLayout struct {
|
||||
AdFormat interface{} `json:"ad_format"` // Ad format
|
||||
Description string `json:"description"` // Ad description
|
||||
ImageSrc string `json:"image_src"` // Image URL
|
||||
ImageSrc2x string `json:"image_src_2x"` // URL of the preview image in double size
|
||||
LinkDomain string `json:"link_domain"` // Domain of advertised object
|
||||
LinkURL string `json:"link_url"` // URL of advertised object
|
||||
PreviewLink string `json:"preview_link"` // preview an ad as it is shown on the website
|
||||
Title string `json:"title"` // Ad title
|
||||
Video BaseBoolInt `json:"video"` // Information whether the ad is a video
|
||||
ID string `json:"id"`
|
||||
CampaignID int `json:"campaign_id"`
|
||||
GoalType int `json:"goal_type"`
|
||||
CostType int `json:"cost_type"`
|
||||
AgeRestriction string `json:"age_restriction"`
|
||||
LinkType string `json:"link_type"`
|
||||
}
|
||||
|
||||
// AdsCampaign struct.
|
||||
type AdsCampaign struct {
|
||||
AllLimit string `json:"all_limit"` // Campaign's total limit, rubles
|
||||
DayLimit string `json:"day_limit"` // Campaign's day limit, rubles
|
||||
ID int `json:"id"` // Campaign ID
|
||||
Name string `json:"name"` // Campaign title
|
||||
StartTime int `json:"start_time"` // Campaign start time, as Unixtime
|
||||
Status int `json:"status"`
|
||||
StopTime int `json:"stop_time"` // Campaign stop time, as Unixtime
|
||||
Type string `json:"type"`
|
||||
}
|
||||
|
||||
// AdsCategory struct.
|
||||
type AdsCategory struct {
|
||||
ID int `json:"id"` // Category ID
|
||||
Name string `json:"name"` // Category name
|
||||
Subcategories []BaseObjectWithName `json:"subcategories"`
|
||||
}
|
||||
|
||||
// AdsClient struct.
|
||||
type AdsClient struct {
|
||||
AllLimit string `json:"all_limit"` // Client's total limit, rubles
|
||||
DayLimit string `json:"day_limit"` // Client's day limit, rubles
|
||||
ID int `json:"id"` // Client ID
|
||||
Name string `json:"name"` // Client name
|
||||
}
|
||||
|
||||
// AdsCriteria struct.
|
||||
type AdsCriteria struct {
|
||||
AgeFrom int `json:"age_from"` // Age from
|
||||
AgeTo int `json:"age_to"` // Age to
|
||||
Apps string `json:"apps"` // Apps IDs
|
||||
AppsNot string `json:"apps_not"` // Apps IDs to except
|
||||
Birthday int `json:"birthday"` // Days to birthday
|
||||
Cities string `json:"cities"` // Cities IDs
|
||||
CitiesNot string `json:"cities_not"` // Cities IDs to except
|
||||
Country int `json:"country"` // Country ID
|
||||
Districts string `json:"districts"` // Districts IDs
|
||||
Groups string `json:"groups"` // Communities IDs
|
||||
InterestCategories string `json:"interest_categories"` // Interests categories IDs
|
||||
Interests string `json:"interests"` // Interests
|
||||
|
||||
// Information whether the user has proceeded VK payments before.
|
||||
Paying BaseBoolInt `json:"paying"`
|
||||
Positions string `json:"positions"` // Positions IDs
|
||||
Religions string `json:"religions"` // Religions IDs
|
||||
RetargetingGroups string `json:"retargeting_groups"` // Retargeting groups IDs
|
||||
RetargetingGroupsNot string `json:"retargeting_groups_not"` // Retargeting groups IDs to except
|
||||
SchoolFrom int `json:"school_from"` // School graduation year from
|
||||
SchoolTo int `json:"school_to"` // School graduation year to
|
||||
Schools string `json:"schools"` // Schools IDs
|
||||
Sex int `json:"sex"`
|
||||
Stations string `json:"stations"` // Stations IDs
|
||||
Statuses string `json:"statuses"` // Relationship statuses
|
||||
Streets string `json:"streets"` // Streets IDs
|
||||
Travellers int `json:"travellers"` // Travellers only
|
||||
UniFrom int `json:"uni_from"` // University graduation year from
|
||||
UniTo int `json:"uni_to"` // University graduation year to
|
||||
UserBrowsers string `json:"user_browsers"` // Browsers
|
||||
UserDevices string `json:"user_devices"` // Devices
|
||||
UserOs string `json:"user_os"` // Operating systems
|
||||
}
|
||||
|
||||
// AdsDemoStats struct.
|
||||
type AdsDemoStats struct {
|
||||
ID int `json:"id"` // Object ID
|
||||
Stats AdsDemostatsFormat `json:"stats"`
|
||||
Type string `json:"type"`
|
||||
}
|
||||
|
||||
// AdsDemostatsFormat struct.
|
||||
type AdsDemostatsFormat struct {
|
||||
Age []AdsStatsAge `json:"age"`
|
||||
Cities []AdsStatsCities `json:"cities"`
|
||||
Day string `json:"day"` // Day as YYYY-MM-DD
|
||||
Month string `json:"month"` // Month as YYYY-MM
|
||||
Overall int `json:"overall"` // 1 if period=overall
|
||||
Sex []AdsStatsSex `json:"sex"`
|
||||
SexAge []AdsStatsSexAge `json:"sex_age"`
|
||||
}
|
||||
|
||||
// AdsFloodStats struct.
|
||||
type AdsFloodStats struct {
|
||||
Left int `json:"left"` // Requests left
|
||||
Refresh int `json:"refresh"` // Time to refresh in seconds
|
||||
}
|
||||
|
||||
// AdsLinkStatus link status.
|
||||
type AdsLinkStatus string
|
||||
|
||||
// Possible values.
|
||||
const (
|
||||
// allowed to use in ads.
|
||||
AdsLinkAllowed AdsLinkStatus = "allowed"
|
||||
|
||||
// prohibited to use for this type of the object.
|
||||
AdsLinkDisallowed AdsLinkStatus = "disallowed"
|
||||
|
||||
// checking, wait please.
|
||||
AdsLinkInProgress AdsLinkStatus = "in_progress"
|
||||
)
|
||||
|
||||
// AdsParagraphs struct.
|
||||
type AdsParagraphs struct {
|
||||
Paragraph string `json:"paragraph"` // Rules paragraph
|
||||
}
|
||||
|
||||
// AdsRejectReason struct.
|
||||
type AdsRejectReason struct {
|
||||
Comment string `json:"comment"` // Comment text
|
||||
Rules []AdsRules `json:"rules"`
|
||||
}
|
||||
|
||||
// AdsRules struct.
|
||||
type AdsRules struct {
|
||||
Paragraphs []AdsParagraphs `json:"paragraphs"`
|
||||
Title string `json:"title"` // Comment
|
||||
}
|
||||
|
||||
// AdsStats struct.
|
||||
type AdsStats struct {
|
||||
ID int `json:"id"` // Object ID
|
||||
Stats AdsStatsFormat `json:"stats"`
|
||||
Type string `json:"type"`
|
||||
}
|
||||
|
||||
// AdsStatsAge struct.
|
||||
type AdsStatsAge struct {
|
||||
ClicksRate float64 `json:"clicks_rate"` // Clicks rate
|
||||
ImpressionsRate float64 `json:"impressions_rate"` // Impressions rate
|
||||
Value string `json:"value"` // Age interval
|
||||
}
|
||||
|
||||
// AdsStatsCities struct.
|
||||
type AdsStatsCities struct {
|
||||
ClicksRate float64 `json:"clicks_rate"` // Clicks rate
|
||||
ImpressionsRate float64 `json:"impressions_rate"` // Impressions rate
|
||||
Name string `json:"name"` // City name
|
||||
Value int `json:"value"` // City ID
|
||||
}
|
||||
|
||||
// AdsStatsFormat struct.
|
||||
type AdsStatsFormat struct {
|
||||
Clicks int `json:"clicks"` // Clicks number
|
||||
Day string `json:"day"` // Day as YYYY-MM-DD
|
||||
Impressions int `json:"impressions"` // Impressions number
|
||||
JoinRate int `json:"join_rate"` // Events number
|
||||
Month string `json:"month"` // Month as YYYY-MM
|
||||
Overall int `json:"overall"` // 1 if period=overall
|
||||
Reach int `json:"reach"` // Reach
|
||||
Spent int `json:"spent"` // Spent funds
|
||||
VideoClicksSite int `json:"video_clicks_site"` // Click-thoughts to the advertised site
|
||||
VideoViews int `json:"video_views"` // Video views number
|
||||
VideoViewsFull int `json:"video_views_full"` // Video views (full video)
|
||||
VideoViewsHalf int `json:"video_views_half"` // Video views (half of video)
|
||||
}
|
||||
|
||||
// AdsStatsSex struct.
|
||||
type AdsStatsSex struct {
|
||||
ClicksRate float64 `json:"clicks_rate"` // Clicks rate
|
||||
ImpressionsRate float64 `json:"impressions_rate"` // Impressions rate
|
||||
Value string `json:"value"`
|
||||
}
|
||||
|
||||
// AdsStatsSexAge struct.
|
||||
type AdsStatsSexAge struct {
|
||||
ClicksRate float64 `json:"clicks_rate"` // Clicks rate
|
||||
ImpressionsRate float64 `json:"impressions_rate"` // Impressions rate
|
||||
Value string `json:"value"` // Sex and age interval
|
||||
}
|
||||
|
||||
// AdsTargSettings struct.
|
||||
type AdsTargSettings struct {
|
||||
}
|
||||
|
||||
// AdsTargStats struct.
|
||||
type AdsTargStats struct {
|
||||
AudienceCount int `json:"audience_count"` // Audience
|
||||
RecommendedCpc float64 `json:"recommended_cpc"` // Recommended CPC value
|
||||
RecommendedCpm float64 `json:"recommended_cpm"` // Recommended CPM value
|
||||
}
|
||||
|
||||
// AdsTargSuggestions struct.
|
||||
type AdsTargSuggestions struct {
|
||||
ID int `json:"id"` // Object ID
|
||||
Name string `json:"name"` // Object name
|
||||
}
|
||||
|
||||
// AdsTargSuggestionsCities struct.
|
||||
type AdsTargSuggestionsCities struct {
|
||||
ID int `json:"id"` // Object ID
|
||||
Name string `json:"name"` // Object name
|
||||
Parent string `json:"parent"` // Parent object
|
||||
}
|
||||
|
||||
// AdsTargSuggestionsRegions struct.
|
||||
type AdsTargSuggestionsRegions struct {
|
||||
ID int `json:"id"` // Object ID
|
||||
Name string `json:"name"` // Object name
|
||||
Type string `json:"type"` // Object type
|
||||
}
|
||||
|
||||
// AdsTargSuggestionsSchools struct.
|
||||
type AdsTargSuggestionsSchools struct {
|
||||
Desc string `json:"desc"` // Full school title
|
||||
ID int `json:"id"` // School ID
|
||||
Name string `json:"name"` // School title
|
||||
Parent string `json:"parent"` // City name
|
||||
Type string `json:"type"`
|
||||
}
|
||||
|
||||
// AdsTargetGroup struct.
|
||||
type AdsTargetGroup struct {
|
||||
AudienceCount int `json:"audience_count"` // Audience
|
||||
ID int `json:"id"` // Group ID
|
||||
Lifetime int `json:"lifetime"` // Number of days for user to be in group
|
||||
Name string `json:"name"` // Group name
|
||||
LastUpdated int `json:"last_updated"`
|
||||
IsAudience BaseBoolInt `json:"is_audience"`
|
||||
IsShared BaseBoolInt `json:"is_shared"`
|
||||
FileSource BaseBoolInt `json:"file_source"`
|
||||
APISource BaseBoolInt `json:"api_source"`
|
||||
LookalikeSource BaseBoolInt `json:"lookalike_source"`
|
||||
Domain string `json:"domain,omitempty"` // Site domain
|
||||
Pixel string `json:"pixel,omitempty"` // Pixel code
|
||||
}
|
||||
|
||||
// AdsUsers struct.
|
||||
type AdsUsers struct {
|
||||
Accesses []AdsAccesses `json:"accesses"`
|
||||
UserID int `json:"user_id"` // User ID
|
||||
}
|
||||
|
||||
// AdsAd struct.
|
||||
type AdsAd struct {
|
||||
Approved string `json:"approved"`
|
||||
AllLimit string `json:"all_limit"`
|
||||
Category1ID string `json:"category1_id"`
|
||||
Category2ID string `json:"category2_id"`
|
||||
Cpm string `json:"cpm"`
|
||||
AdFormat int `json:"ad_format"` // Ad format
|
||||
AdPlatform interface{} `json:"ad_platform"` // Ad platform
|
||||
CampaignID int `json:"campaign_id"` // Campaign ID
|
||||
CostType int `json:"cost_type"`
|
||||
Cpc int `json:"cpc"` // Cost of a click, kopecks
|
||||
DisclaimerMedical BaseBoolInt `json:"disclaimer_medical"` // Information whether disclaimer is enabled
|
||||
DisclaimerSpecialist BaseBoolInt `json:"disclaimer_specialist"` // Information whether disclaimer is enabled
|
||||
DisclaimerSupplements BaseBoolInt `json:"disclaimer_supplements"` // Information whether disclaimer is enabled
|
||||
Video BaseBoolInt `json:"video"` // Information whether the ad is a video
|
||||
ImpressionsLimited BaseBoolInt `json:"impressions_limited"` // Information whether impressions are limited
|
||||
Autobidding BaseBoolInt `json:"autobidding"`
|
||||
ImpressionsLimit int `json:"impressions_limit"` // Impressions limit
|
||||
ID string `json:"id"` // Ad ID
|
||||
Name string `json:"name"` // Ad title
|
||||
Status int `json:"status"`
|
||||
CreateTime string `json:"create_time"`
|
||||
UpdateTime string `json:"update_time"`
|
||||
GoalType int `json:"goal_type"`
|
||||
DayLimit string `json:"day_limit"`
|
||||
StartTime string `json:"start_time"`
|
||||
StopTime string `json:"stop_time"`
|
||||
AgeRestriction string `json:"age_restriction"`
|
||||
EventsRetargetingGroups interface{} `json:"events_retargeting_groups"`
|
||||
ImpressionsLimitPeriod string `json:"impressions_limit_period"`
|
||||
}
|
||||
|
||||
// AdsPromotedPostReach struct.
|
||||
type AdsPromotedPostReach struct {
|
||||
Hide int `json:"hide"` // Hides amount
|
||||
ID int `json:"id"` // Object ID from 'ids' parameter
|
||||
JoinGroup int `json:"join_group"` // Community joins
|
||||
Links int `json:"links"` // Link clicks
|
||||
ReachSubscribers int `json:"reach_subscribers"` // Subscribers reach
|
||||
ReachTotal int `json:"reach_total"` // Total reach
|
||||
Report int `json:"report"` // Reports amount
|
||||
ToGroup int `json:"to_group"` // Community clicks
|
||||
Unsubscribe int `json:"unsubscribe"` // 'Unsubscribe' events amount
|
||||
VideoViews100p int `json:"video_views_100p"` // Video views for 100 percent
|
||||
VideoViews25p int `json:"video_views_25p"` // Video views for 25 percent
|
||||
VideoViews3s int `json:"video_views_3s"` // Video views for 3 seconds
|
||||
VideoViews50p int `json:"video_views_50p"` // Video views for 50 percent
|
||||
VideoViews75p int `json:"video_views_75p"` // Video views for 75 percent
|
||||
VideoViewsStart int `json:"video_views_start"` // Video starts
|
||||
}
|
@ -0,0 +1,20 @@
|
||||
package object
|
||||
|
||||
// AppWidgetsAppImageUploadResponse struct.
|
||||
type AppWidgetsAppImageUploadResponse struct {
|
||||
Image string `json:"image"`
|
||||
Hash string `json:"hash"`
|
||||
}
|
||||
|
||||
// AppWidgetsGroupImageUploadResponse struct.
|
||||
type AppWidgetsGroupImageUploadResponse struct {
|
||||
Image string `json:"image"`
|
||||
Hash string `json:"hash"`
|
||||
}
|
||||
|
||||
// AppWidgetsImage struct.
|
||||
type AppWidgetsImage struct {
|
||||
ID string `json:"id"`
|
||||
Type string `json:"type"`
|
||||
Images []BaseImage `json:"images"`
|
||||
}
|
@ -0,0 +1,67 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// AudioAudio struct.
|
||||
type AudioAudio struct {
|
||||
AccessKey string `json:"access_key"` // Access key for the audio
|
||||
ID int `json:"id"`
|
||||
OwnerID int `json:"owner_id"`
|
||||
Artist string `json:"artist"`
|
||||
Title string `json:"title"`
|
||||
Duration int `json:"duration"`
|
||||
Date int `json:"date"`
|
||||
URL string `json:"url"`
|
||||
IsHq BaseBoolInt `json:"is_hq"`
|
||||
IsExplicit BaseBoolInt `json:"is_explicit"`
|
||||
StoriesAllowed BaseBoolInt `json:"stories_allowed"`
|
||||
ShortVideosAllowed BaseBoolInt `json:"short_videos_allowed"`
|
||||
IsFocusTrack BaseBoolInt `json:"is_focus_track"`
|
||||
IsLicensed BaseBoolInt `json:"is_licensed"`
|
||||
StoriesCoverAllowed BaseBoolInt `json:"stories_cover_allowed"`
|
||||
LyricsID int `json:"lyrics_id"`
|
||||
AlbumID int `json:"album_id"`
|
||||
GenreID int `json:"genre_id"`
|
||||
TrackCode string `json:"track_code"`
|
||||
NoSearch int `json:"no_search"`
|
||||
MainArtists []AudioAudioArtist `json:"main_artists"`
|
||||
Ads AudioAds `json:"ads"`
|
||||
Subtitle string `json:"subtitle"`
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (audio AudioAudio) ToAttachment() string {
|
||||
return fmt.Sprintf("audio%d_%d", audio.OwnerID, audio.ID)
|
||||
}
|
||||
|
||||
// AudioAds struct.
|
||||
type AudioAds struct {
|
||||
ContentID string `json:"content_id"`
|
||||
Duration string `json:"duration"`
|
||||
AccountAgeType string `json:"account_age_type"`
|
||||
PUID1 string `json:"puid1"`
|
||||
PUID22 string `json:"puid22"`
|
||||
}
|
||||
|
||||
// AudioAudioArtist struct.
|
||||
type AudioAudioArtist struct {
|
||||
Name string `json:"name"`
|
||||
ID string `json:"id"`
|
||||
Domain string `json:"domain"`
|
||||
}
|
||||
|
||||
// AudioAudioUploadResponse struct.
|
||||
type AudioAudioUploadResponse struct {
|
||||
Audio string `json:"audio"`
|
||||
Hash string `json:"hash"`
|
||||
Redirect string `json:"redirect"`
|
||||
Server int `json:"server"`
|
||||
}
|
||||
|
||||
// AudioLyrics struct.
|
||||
type AudioLyrics struct {
|
||||
LyricsID int `json:"lyrics_id"`
|
||||
Text string `json:"text"`
|
||||
}
|
@ -0,0 +1,40 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// BoardTopic struct.
|
||||
type BoardTopic struct {
|
||||
Comments int `json:"comments"` // Comments number
|
||||
Created int `json:"created"` // Date when the topic has been created in Unixtime
|
||||
CreatedBy int `json:"created_by"` // Creator ID
|
||||
ID int `json:"id"` // Topic ID
|
||||
IsClosed BaseBoolInt `json:"is_closed"` // Information whether the topic is closed
|
||||
IsFixed BaseBoolInt `json:"is_fixed"` // Information whether the topic is fixed
|
||||
Title string `json:"title"` // Topic title
|
||||
Updated int `json:"updated"` // Date when the topic has been updated in Unixtime
|
||||
UpdatedBy int `json:"updated_by"` // ID of user who updated the topic
|
||||
}
|
||||
|
||||
// BoardTopicComment struct.
|
||||
type BoardTopicComment struct {
|
||||
Attachments []WallCommentAttachment `json:"attachments"`
|
||||
Date int `json:"date"` // Date when the comment has been added in Unixtime
|
||||
FromID int `json:"from_id"` // Author ID
|
||||
ID int `json:"id"` // Comment ID
|
||||
// RealOffset int `json:"real_offset"` // Real position of the comment
|
||||
Text string `json:"text"` // Comment text
|
||||
// TopicID int `json:"topic_id"`
|
||||
// TopicOwnerID int `json:"topic_owner_id"`
|
||||
Likes BaseLikesInfo `json:"likes"`
|
||||
CanEdit BaseBoolInt `json:"can_edit"` // Information whether current user can edit the comment
|
||||
}
|
||||
|
||||
// BoardTopicPoll struct.
|
||||
type BoardTopicPoll struct {
|
||||
AnswerID int `json:"answer_id"` // Current user's answer ID
|
||||
Answers []PollsAnswer `json:"answers"`
|
||||
Created int `json:"created"` // Date when poll has been created in Unixtime
|
||||
IsClosed BaseBoolInt `json:"is_closed"` // Information whether the poll is closed
|
||||
OwnerID int `json:"owner_id"` // Poll owner's ID
|
||||
PollID int `json:"poll_id"` // Poll ID
|
||||
Question string `json:"question"` // Poll question
|
||||
Votes string `json:"votes"` // Votes number
|
||||
}
|
@ -0,0 +1,50 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// DatabaseCity struct.
|
||||
type DatabaseCity struct {
|
||||
ID int `json:"id"` // City ID
|
||||
Title string `json:"title"` // City title
|
||||
Area string `json:"area"`
|
||||
Region string `json:"region"`
|
||||
Important BaseBoolInt `json:"important"`
|
||||
}
|
||||
|
||||
// DatabaseMetroStation struct.
|
||||
type DatabaseMetroStation struct {
|
||||
ID int `json:"id"` // Metro station ID
|
||||
Name string `json:"name"` // Metro station name
|
||||
Color string `json:"color"` // Metro station color
|
||||
CityID int `json:"city_id"` // Metro station city ID
|
||||
}
|
||||
|
||||
// DatabaseFaculty struct.
|
||||
type DatabaseFaculty struct {
|
||||
ID int `json:"id"` // Faculty ID
|
||||
Title string `json:"title"` // Faculty title
|
||||
}
|
||||
|
||||
// DatabaseRegion struct.
|
||||
type DatabaseRegion struct {
|
||||
ID int `json:"id"` // Region ID
|
||||
Title string `json:"title"` // Region title
|
||||
}
|
||||
|
||||
// DatabaseSchool struct.
|
||||
type DatabaseSchool struct {
|
||||
ID int `json:"id"` // School ID
|
||||
Title string `json:"title"` // School title
|
||||
}
|
||||
|
||||
// DatabaseStation struct.
|
||||
type DatabaseStation struct {
|
||||
CityID int `json:"city_id"` // City ID
|
||||
Color string `json:"color"` // Hex color code without #
|
||||
ID int `json:"id"` // Station ID
|
||||
Name string `json:"name"` // Station name
|
||||
}
|
||||
|
||||
// DatabaseUniversity struct.
|
||||
type DatabaseUniversity struct {
|
||||
ID int `json:"id"` // University ID
|
||||
Title string `json:"title"` // University title
|
||||
}
|
@ -0,0 +1,117 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// DocsDoc struct.
|
||||
type DocsDoc struct {
|
||||
AccessKey string `json:"access_key"` // Access key for the document
|
||||
Date int `json:"date"` // Date when file has been uploaded in Unixtime
|
||||
Ext string `json:"ext"` // File extension
|
||||
ID int `json:"id"` // Document ID
|
||||
IsLicensed BaseBoolInt `json:"is_licensed"`
|
||||
OwnerID int `json:"owner_id"` // Document owner ID
|
||||
Preview DocsDocPreview `json:"preview"`
|
||||
Size int `json:"size"` // File size in bites
|
||||
Title string `json:"title"` // Document title
|
||||
Type int `json:"type"` // Document type
|
||||
URL string `json:"url"` // File URL
|
||||
DocsDocPreviewAudioMessage
|
||||
DocsDocPreviewGraffiti
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (doc DocsDoc) ToAttachment() string {
|
||||
return fmt.Sprintf("doc%d_%d", doc.OwnerID, doc.ID)
|
||||
}
|
||||
|
||||
// DocsDocPreview struct.
|
||||
type DocsDocPreview struct {
|
||||
Photo DocsDocPreviewPhoto `json:"photo"`
|
||||
Graffiti DocsDocPreviewGraffiti `json:"graffiti"`
|
||||
Video DocsDocPreviewVideo `json:"video"`
|
||||
AudioMessage DocsDocPreviewAudioMessage `json:"audio_message"`
|
||||
}
|
||||
|
||||
// DocsDocPreviewPhoto struct.
|
||||
type DocsDocPreviewPhoto struct {
|
||||
Sizes []DocsDocPreviewPhotoSizes `json:"sizes"`
|
||||
}
|
||||
|
||||
// MaxSize return the largest DocsDocPreviewPhotoSizes.
|
||||
func (photo DocsDocPreviewPhoto) MaxSize() (maxPhotoSize DocsDocPreviewPhotoSizes) {
|
||||
var max float64
|
||||
|
||||
for _, photoSize := range photo.Sizes {
|
||||
size := photoSize.Height * photoSize.Width
|
||||
if size > max {
|
||||
max = size
|
||||
maxPhotoSize = photoSize
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MinSize return the smallest DocsDocPreviewPhotoSizes.
|
||||
func (photo DocsDocPreviewPhoto) MinSize() (minPhotoSize DocsDocPreviewPhotoSizes) {
|
||||
var min float64
|
||||
|
||||
for _, photoSize := range photo.Sizes {
|
||||
size := photoSize.Height * photoSize.Width
|
||||
if size < min || min == 0 {
|
||||
min = size
|
||||
minPhotoSize = photoSize
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// DocsDocPreviewPhotoSizes struct.
|
||||
type DocsDocPreviewPhotoSizes struct {
|
||||
// BUG(VK): json: cannot unmarshal number 162.000000 into Go struct field
|
||||
// DocsDocPreviewPhotoSizes.doc.preview.photo.sizes.height of type Int
|
||||
Height float64 `json:"height"` // Height in px
|
||||
Src string `json:"src"` // URL of the image
|
||||
Type string `json:"type"`
|
||||
Width float64 `json:"width"` // Width in px
|
||||
}
|
||||
|
||||
// DocsDocPreviewGraffiti struct.
|
||||
type DocsDocPreviewGraffiti struct {
|
||||
Src string `json:"src"`
|
||||
Width int `json:"width"`
|
||||
Height int `json:"height"`
|
||||
}
|
||||
|
||||
// DocsDocPreviewVideo struct.
|
||||
type DocsDocPreviewVideo struct {
|
||||
FileSize int `json:"file_size"` // Video file size in bites
|
||||
Height int `json:"height"` // Video's height in pixels
|
||||
Src string `json:"src"` // Video URL
|
||||
Width int `json:"width"` // Video's width in pixels
|
||||
}
|
||||
|
||||
// DocsDocPreviewAudioMessage struct.
|
||||
type DocsDocPreviewAudioMessage struct {
|
||||
Duration int `json:"duration"`
|
||||
Waveform []int `json:"waveform"`
|
||||
LinkOgg string `json:"link_ogg"`
|
||||
LinkMp3 string `json:"link_mp3"`
|
||||
Transcript string `json:"transcript"`
|
||||
TranscriptState string `json:"transcript_state"`
|
||||
}
|
||||
|
||||
// DocsDocTypes struct.
|
||||
type DocsDocTypes struct {
|
||||
Count int `json:"count"` // Number of docs
|
||||
ID int `json:"id"` // Doc type ID
|
||||
Name string `json:"name"` // Doc type Title
|
||||
}
|
||||
|
||||
// DocsDocUploadResponse struct.
|
||||
type DocsDocUploadResponse struct {
|
||||
File string `json:"file"` // Uploaded file data
|
||||
}
|
@ -0,0 +1,9 @@
|
||||
package object
|
||||
|
||||
// DonutDonatorSubscriptionInfo struct.
|
||||
type DonutDonatorSubscriptionInfo struct {
|
||||
OwnerID int `json:"owner_id"`
|
||||
NextPaymentDate int `json:"next_payment_date"`
|
||||
Amount int `json:"amount"`
|
||||
Status string `json:"status"`
|
||||
}
|
@ -0,0 +1,41 @@
|
||||
package object
|
||||
|
||||
// FaveTag struct.
|
||||
type FaveTag struct {
|
||||
ID int `json:"id"`
|
||||
Name string `json:"name"`
|
||||
}
|
||||
|
||||
// FavePage struct.
|
||||
type FavePage struct {
|
||||
Type string `json:"type"`
|
||||
Description string `json:"description"`
|
||||
Tags []FaveTag `json:"tags"`
|
||||
UpdatedDate int `json:"updated_date"`
|
||||
User UsersUser `json:"user"`
|
||||
Group GroupsGroup `json:"group"`
|
||||
}
|
||||
|
||||
// FaveFavesLink struct.
|
||||
type FaveFavesLink struct {
|
||||
URL string `json:"url"`
|
||||
Title string `json:"title"`
|
||||
Caption string `json:"caption"`
|
||||
Description string `json:"description"`
|
||||
Photo PhotosPhoto `json:"photo"`
|
||||
IsFavorite BaseBoolInt `json:"is_favorite"`
|
||||
ID string `json:"id"`
|
||||
}
|
||||
|
||||
// FaveItem struct.
|
||||
type FaveItem struct {
|
||||
Type string `json:"type"`
|
||||
Seen BaseBoolInt `json:"seen"`
|
||||
AddedDate int `json:"added_date"`
|
||||
Tags []FaveTag `json:"tags"`
|
||||
Link FaveFavesLink `json:"link,omitempty"`
|
||||
Post WallWallpost `json:"post,omitempty"`
|
||||
Video VideoVideo `json:"video,omitempty"`
|
||||
Product MarketMarketItem `json:"product,omitempty"`
|
||||
Article Article `json:"article,omitempty"`
|
||||
}
|
@ -0,0 +1,63 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// FriendsFriendStatus FriendStatus type.
|
||||
const (
|
||||
FriendsStatusNotFriend = iota // not a friend
|
||||
FriendsStatusOutComingRequest // out coming request
|
||||
FriendsStatusInComingRequest // incoming request
|
||||
FriendsStatusIsFriend // is friend
|
||||
)
|
||||
|
||||
// FriendsFriendStatus struct.
|
||||
type FriendsFriendStatus struct {
|
||||
FriendStatus int `json:"friend_status"`
|
||||
ReadState BaseBoolInt `json:"read_state"` // Information whether request is unviewed
|
||||
RequestMessage string `json:"request_message"` // Message sent with request
|
||||
Sign string `json:"sign"` // MD5 hash for the result validation
|
||||
UserID int `json:"user_id"` // User ID
|
||||
}
|
||||
|
||||
// FriendsFriendsList struct.
|
||||
type FriendsFriendsList struct {
|
||||
ID int `json:"id"` // List ID
|
||||
Name string `json:"name"` // List title
|
||||
}
|
||||
|
||||
// type friendsMutualFriend struct {
|
||||
// CommonCount int `json:"common_count"` // Total mutual friends number
|
||||
// CommonFriends []int `json:"common_friends"`
|
||||
// ID int `json:"id"` // User ID
|
||||
// }
|
||||
|
||||
// FriendsRequests struct.
|
||||
type FriendsRequests struct {
|
||||
UsersUser
|
||||
From string `json:"from"` // ID of the user by whom friend has been suggested
|
||||
Mutual FriendsRequestsMutual `json:"mutual"`
|
||||
UserID int `json:"user_id"` // User ID
|
||||
TrackCode string `json:"track_code"`
|
||||
}
|
||||
|
||||
// FriendsRequestsMutual struct.
|
||||
type FriendsRequestsMutual struct {
|
||||
Count int `json:"count"` // Total mutual friends number
|
||||
Users []int `json:"users"`
|
||||
}
|
||||
|
||||
// FriendsRequestsXtrMessage struct.
|
||||
type FriendsRequestsXtrMessage struct {
|
||||
FriendsRequests
|
||||
Message string `json:"message"` // Message sent with a request
|
||||
}
|
||||
|
||||
// FriendsUserXtrLists struct.
|
||||
type FriendsUserXtrLists struct {
|
||||
UsersUser
|
||||
Lists []int `json:"lists"` // IDs of friend lists with user
|
||||
}
|
||||
|
||||
// FriendsUserXtrPhone struct.
|
||||
type FriendsUserXtrPhone struct {
|
||||
UsersUser
|
||||
Phone string `json:"phone"` // User phone
|
||||
}
|
@ -0,0 +1,34 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// GiftsGift Privacy type.
|
||||
const (
|
||||
GiftsGiftPrivacyForAll = iota // name and message for all
|
||||
GiftsGiftPrivacyNameForAll // name for all
|
||||
GiftsGiftPrivacyRecipientOnly // name and message for recipient only
|
||||
)
|
||||
|
||||
// GiftsGift struct.
|
||||
type GiftsGift struct {
|
||||
Date int `json:"date"` // Date when gist has been sent in Unixtime
|
||||
FromID int `json:"from_id"` // Gift sender ID
|
||||
Gift GiftsLayout `json:"gift"`
|
||||
GiftHash string `json:"gift_hash"` // Hash
|
||||
ID int `json:"id"` // Gift ID
|
||||
Message string `json:"message"` // Comment text
|
||||
Privacy int `json:"privacy"`
|
||||
|
||||
Description string `json:"description"`
|
||||
PaymentType string `json:"payment_type"`
|
||||
Price int `json:"price"`
|
||||
PriceStr string `json:"price_str"`
|
||||
}
|
||||
|
||||
// GiftsLayout struct.
|
||||
type GiftsLayout struct {
|
||||
ID int `json:"id"`
|
||||
Thumb256 string `json:"thumb_256"` // URL of the preview image with 256 px in width
|
||||
Thumb48 string `json:"thumb_48"` // URL of the preview image with 48 px in width
|
||||
Thumb96 string `json:"thumb_96"` // URL of the preview image with 96 px in width
|
||||
StickersProductID int `json:"stickers_product_id"`
|
||||
IsStickersStyle BaseBoolInt `json:"is_stickers_style"`
|
||||
}
|
@ -0,0 +1,807 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"reflect"
|
||||
)
|
||||
|
||||
// GroupsAddress WorkInfoStatus of information about timetable.
|
||||
const (
|
||||
WorkStatusNoInformation = "no_information"
|
||||
WorkStatusTemporarilyClosed = "temporarily_closed"
|
||||
WorkStatusAlwaysOpened = "always_opened"
|
||||
WorkStatusTimetable = "timetable"
|
||||
WorkStatusForeverClosed = "forever_closed"
|
||||
)
|
||||
|
||||
// GroupsAddress struct.
|
||||
type GroupsAddress struct {
|
||||
// Additional address to the place (6 floor, left door).
|
||||
AdditionalAddress string `json:"additional_address"`
|
||||
Address string `json:"address"` // String address to the place (Nevsky, 28)
|
||||
CityID int `json:"city_id"` // City id of address
|
||||
CountryID int `json:"country_id"` // Country id of address
|
||||
Distance int `json:"distance"` // Distance from the point
|
||||
ID int `json:"id"` // Address id
|
||||
Latitude float64 `json:"latitude"` // Address latitude
|
||||
Longitude float64 `json:"longitude"` // Address longitude
|
||||
MetroStationID int `json:"metro_station_id"` // Metro id of address
|
||||
Phone string `json:"phone"` // Address phone
|
||||
TimeOffset int `json:"time_offset"` // Time offset int minutes from utc time
|
||||
Timetable GroupsAddressTimetable `json:"timetable"` // Week timetable for the address
|
||||
Title string `json:"title"` // Title of the place (Zinger, etc)
|
||||
WorkInfoStatus string `json:"work_info_status"` // Status of information about timetable
|
||||
}
|
||||
|
||||
// GroupsAddressTimetable Timetable for a week.
|
||||
type GroupsAddressTimetable struct {
|
||||
Fri GroupsAddressTimetableDay `json:"fri"` // Timetable for friday
|
||||
Mon GroupsAddressTimetableDay `json:"mon"` // Timetable for monday
|
||||
Sat GroupsAddressTimetableDay `json:"sat"` // Timetable for saturday
|
||||
Sun GroupsAddressTimetableDay `json:"sun"` // Timetable for sunday
|
||||
Thu GroupsAddressTimetableDay `json:"thu"` // Timetable for thursday
|
||||
Tue GroupsAddressTimetableDay `json:"tue"` // Timetable for tuesday
|
||||
Wed GroupsAddressTimetableDay `json:"wed"` // Timetable for wednesday
|
||||
}
|
||||
|
||||
// GroupsAddressTimetableDay Timetable for one day.
|
||||
type GroupsAddressTimetableDay struct {
|
||||
BreakCloseTime int `json:"break_close_time"` // Close time of the break in minutes
|
||||
BreakOpenTime int `json:"break_open_time"` // Start time of the break in minutes
|
||||
CloseTime int `json:"close_time"` // Close time in minutes
|
||||
OpenTime int `json:"open_time"` // Open time in minutes
|
||||
}
|
||||
|
||||
// GroupsAddressesInfo struct.
|
||||
type GroupsAddressesInfo struct {
|
||||
IsEnabled BaseBoolInt `json:"is_enabled"` // Information whether addresses is enabled
|
||||
MainAddressID int `json:"main_address_id"` // Main address id for group
|
||||
}
|
||||
|
||||
// GroupsGroup AdminLevel type.
|
||||
const (
|
||||
GroupsAdminLevelModerator = iota
|
||||
GroupsAdminLevelEditor
|
||||
GroupsAdminLevelAdministrator
|
||||
)
|
||||
|
||||
// GroupsGroup MainSection type.
|
||||
const (
|
||||
GroupsMainSectionAbsent = iota
|
||||
GroupsMainSectionPhotos
|
||||
GroupsMainSectionTopics
|
||||
GroupsMainSectionAudio
|
||||
GroupsMainSectionVideo
|
||||
GroupsMainSectionMarket
|
||||
)
|
||||
|
||||
// GroupsGroup MemberStatus(events_event_attach, newsfeed_event_activity).
|
||||
const (
|
||||
GroupsMemberStatusNotMember = iota
|
||||
GroupsMemberStatusMember
|
||||
GroupsMemberStatusNotSure
|
||||
GroupsMemberStatusDeclined
|
||||
GroupsMemberStatusHasSentRequest
|
||||
GroupsMemberStatusInvited
|
||||
)
|
||||
|
||||
// GroupsGroup Access or IsClosed type.
|
||||
const (
|
||||
GroupsGroupOpen = iota
|
||||
GroupsGroupClosed
|
||||
GroupsGroupPrivate
|
||||
)
|
||||
|
||||
// GroupsGroup AgeLimits.
|
||||
const (
|
||||
GroupsAgeLimitsNo = iota
|
||||
GroupsAgeLimitsOver16
|
||||
GroupsAgeLimitsOver18
|
||||
)
|
||||
|
||||
// GroupsGroup type.
|
||||
const (
|
||||
GroupsTypeGroup = "group"
|
||||
GroupsTypePage = "page"
|
||||
GroupsTypeEvent = "event"
|
||||
)
|
||||
|
||||
// GroupsGroup struct.
|
||||
type GroupsGroup struct {
|
||||
AdminLevel int `json:"admin_level"`
|
||||
Deactivated string `json:"deactivated"` // Information whether community is banned
|
||||
FinishDate int `json:"finish_date"` // Finish date in Unixtime format
|
||||
ID int `json:"id"` // Community ID
|
||||
Name string `json:"name"` // Community name
|
||||
Photo100 string `json:"photo_100"` // URL of square photo of the community with 100 pixels in width
|
||||
Photo200 string `json:"photo_200"` // URL of square photo of the community with 200 pixels in width
|
||||
Photo50 string `json:"photo_50"` // URL of square photo of the community with 50 pixels in width
|
||||
ScreenName string `json:"screen_name"` // Domain of the community page
|
||||
StartDate int `json:"start_date"` // Start date in Unixtime format
|
||||
Type string `json:"type"`
|
||||
Market GroupsMarketInfo `json:"market"`
|
||||
MemberStatus int `json:"member_status"` // Current user's member status
|
||||
IsClosed int `json:"is_closed"`
|
||||
City BaseObject `json:"city"`
|
||||
Country BaseCountry `json:"country"`
|
||||
|
||||
// Information whether current user is administrator.
|
||||
IsAdmin BaseBoolInt `json:"is_admin"`
|
||||
|
||||
// Information whether current user is advertiser.
|
||||
IsAdvertiser BaseBoolInt `json:"is_advertiser"`
|
||||
|
||||
// Information whether current user is member.
|
||||
IsMember BaseBoolInt `json:"is_member"`
|
||||
|
||||
// Information whether community is in faves.
|
||||
IsFavorite BaseBoolInt `json:"is_favorite"`
|
||||
|
||||
// Information whether community is adult.
|
||||
IsAdult BaseBoolInt `json:"is_adult"`
|
||||
|
||||
// Information whether current user is subscribed.
|
||||
IsSubscribed BaseBoolInt `json:"is_subscribed"`
|
||||
|
||||
// Information whether current user can post on community's wall.
|
||||
CanPost BaseBoolInt `json:"can_post"`
|
||||
|
||||
// Information whether current user can see all posts on community's wall.
|
||||
CanSeeAllPosts BaseBoolInt `json:"can_see_all_posts"`
|
||||
|
||||
// Information whether current user can create topic.
|
||||
CanCreateTopic BaseBoolInt `json:"can_create_topic"`
|
||||
|
||||
// Information whether current user can upload video.
|
||||
CanUploadVideo BaseBoolInt `json:"can_upload_video"`
|
||||
|
||||
// Information whether current user can upload doc.
|
||||
CanUploadDoc BaseBoolInt `json:"can_upload_doc"`
|
||||
|
||||
// Information whether community has photo.
|
||||
HasPhoto BaseBoolInt `json:"has_photo"`
|
||||
|
||||
// Information whether current user can send a message to community.
|
||||
CanMessage BaseBoolInt `json:"can_message"`
|
||||
|
||||
// Information whether community can send a message to current user.
|
||||
IsMessagesBlocked BaseBoolInt `json:"is_messages_blocked"`
|
||||
|
||||
// Information whether community can send notifications by phone number to current user.
|
||||
CanSendNotify BaseBoolInt `json:"can_send_notify"`
|
||||
|
||||
// Information whether current user is subscribed to podcasts.
|
||||
IsSubscribedPodcasts BaseBoolInt `json:"is_subscribed_podcasts"`
|
||||
|
||||
// Owner in whitelist or not.
|
||||
CanSubscribePodcasts BaseBoolInt `json:"can_subscribe_podcasts"`
|
||||
|
||||
// Can subscribe to wall.
|
||||
CanSubscribePosts BaseBoolInt `json:"can_subscribe_posts"`
|
||||
|
||||
// Information whether community has market app.
|
||||
HasMarketApp BaseBoolInt `json:"has_market_app"`
|
||||
IsHiddenFromFeed BaseBoolInt `json:"is_hidden_from_feed"`
|
||||
IsMarketCartEnabled BaseBoolInt `json:"is_market_cart_enabled"`
|
||||
Verified BaseBoolInt `json:"verified"` // Information whether community is verified
|
||||
|
||||
// Information whether the community has a fire pictogram.
|
||||
Trending BaseBoolInt `json:"trending"`
|
||||
Description string `json:"description"` // Community description
|
||||
WikiPage string `json:"wiki_page"` // Community's main wiki page title
|
||||
MembersCount int `json:"members_count"` // Community members number
|
||||
Counters GroupsCountersGroup `json:"counters"`
|
||||
Cover GroupsCover `json:"cover"`
|
||||
|
||||
// Type of group, start date of event or category of public page.
|
||||
Activity string `json:"activity"`
|
||||
FixedPost int `json:"fixed_post"` // Fixed post ID
|
||||
Status string `json:"status"` // Community status
|
||||
MainAlbumID int `json:"main_album_id"` // Community's main photo album ID
|
||||
Links []GroupsLinksItem `json:"links"`
|
||||
Contacts []GroupsContactsItem `json:"contacts"`
|
||||
Site string `json:"site"` // Community's website
|
||||
MainSection int `json:"main_section"`
|
||||
OnlineStatus GroupsOnlineStatus `json:"online_status"` // Status of replies in community messages
|
||||
AgeLimits int `json:"age_limits"` // Information whether age limit
|
||||
BanInfo GroupsGroupBanInfo `json:"ban_info"` // User ban info
|
||||
Addresses GroupsAddressesInfo `json:"addresses"` // Info about addresses in Groups
|
||||
LiveCovers GroupsLiveCovers `json:"live_covers"`
|
||||
CropPhoto UsersCropPhoto `json:"crop_photo"`
|
||||
Wall int `json:"wall"`
|
||||
ActionButton GroupsActionButton `json:"action_button"`
|
||||
TrackCode string `json:"track_code"`
|
||||
PublicDateLabel string `json:"public_date_label"`
|
||||
AuthorID int `json:"author_id"`
|
||||
Phone string `json:"phone"`
|
||||
}
|
||||
|
||||
// ToMention return mention.
|
||||
func (group GroupsGroup) ToMention() string {
|
||||
return fmt.Sprintf("[club%d|%s]", group.ID, group.Name)
|
||||
}
|
||||
|
||||
// GroupsLiveCovers struct.
|
||||
type GroupsLiveCovers struct {
|
||||
IsEnabled BaseBoolInt `json:"is_enabled"`
|
||||
IsScalable BaseBoolInt `json:"is_scalable"`
|
||||
StoryIds []string `json:"story_ids"`
|
||||
}
|
||||
|
||||
// GroupsBanInfo reason type.
|
||||
const (
|
||||
GroupsBanReasonOther = iota
|
||||
GroupsBanReasonSpam
|
||||
GroupsBanReasonVerbalAbuse
|
||||
GroupsBanReasonStrongLanguage
|
||||
GroupsBanReasonFlood
|
||||
)
|
||||
|
||||
// GroupsBanInfo struct.
|
||||
type GroupsBanInfo struct {
|
||||
AdminID int `json:"admin_id"` // Administrator ID
|
||||
Comment string `json:"comment"` // Comment for a ban
|
||||
Date int `json:"date"` // Date when user has been added to blacklist in Unixtime
|
||||
EndDate int `json:"end_date"` // Date when user will be removed from blacklist in Unixtime
|
||||
Reason int `json:"reason"`
|
||||
CommentVisible BaseBoolInt `json:"comment_visible"`
|
||||
}
|
||||
|
||||
// GroupsCallbackServer struct.
|
||||
type GroupsCallbackServer struct {
|
||||
CreatorID int `json:"creator_id"`
|
||||
ID int `json:"id"`
|
||||
SecretKey string `json:"secret_key"`
|
||||
Status string `json:"status"`
|
||||
Title string `json:"title"`
|
||||
URL string `json:"url"`
|
||||
}
|
||||
|
||||
// GroupsCallbackSettings struct.
|
||||
type GroupsCallbackSettings struct {
|
||||
APIVersion string `json:"api_version"` // API version used for the events
|
||||
Events GroupsLongPollEvents `json:"events"`
|
||||
}
|
||||
|
||||
// GroupsContactsItem struct.
|
||||
type GroupsContactsItem struct {
|
||||
Desc string `json:"desc"` // Contact description
|
||||
Email string `json:"email"` // Contact email
|
||||
Phone string `json:"phone"` // Contact phone
|
||||
UserID int `json:"user_id"` // User ID
|
||||
}
|
||||
|
||||
// GroupsCountersGroup struct.
|
||||
type GroupsCountersGroup struct {
|
||||
Addresses int `json:"addresses"` // Addresses number
|
||||
Albums int `json:"albums"` // Photo albums number
|
||||
Articles int `json:"articles"` // Articles number
|
||||
Audios int `json:"audios"` // Audios number
|
||||
Docs int `json:"docs"` // Docs number
|
||||
Market int `json:"market"` // Market items number
|
||||
Photos int `json:"photos"` // Photos number
|
||||
Topics int `json:"topics"` // Topics number
|
||||
Videos int `json:"videos"` // Videos number
|
||||
Narratives int `json:"narratives"` // Narratives number
|
||||
}
|
||||
|
||||
// GroupsCover struct.
|
||||
type GroupsCover struct {
|
||||
Enabled BaseBoolInt `json:"enabled"` // Information whether cover is enabled
|
||||
Images []BaseImage `json:"images"`
|
||||
}
|
||||
|
||||
// GroupsGroupBanInfo struct.
|
||||
type GroupsGroupBanInfo struct {
|
||||
Comment string `json:"comment"` // Ban comment
|
||||
EndDate int `json:"end_date"` // End date of ban in Unixtime
|
||||
}
|
||||
|
||||
// GroupsGroupCategory struct.
|
||||
type GroupsGroupCategory struct {
|
||||
ID int `json:"id"` // Category ID
|
||||
Name string `json:"name"` // Category name
|
||||
Subcategories []BaseObjectWithName `json:"subcategories"`
|
||||
}
|
||||
|
||||
// GroupsGroupCategoryFull struct.
|
||||
type GroupsGroupCategoryFull struct {
|
||||
ID int `json:"id"` // Category ID
|
||||
Name string `json:"name"` // Category name
|
||||
PageCount int `json:"page_count"` // Pages number
|
||||
PagePreviews []GroupsGroup `json:"page_previews"`
|
||||
Subcategories []GroupsGroupCategoryFull `json:"subcategories"`
|
||||
}
|
||||
|
||||
// GroupsGroupCategoryType struct.
|
||||
type GroupsGroupCategoryType struct {
|
||||
ID int `json:"id"`
|
||||
Name string `json:"name"`
|
||||
}
|
||||
|
||||
// GroupsGroupLink struct.
|
||||
type GroupsGroupLink struct {
|
||||
Desc string `json:"desc"` // Link description
|
||||
EditTitle BaseBoolInt `json:"edit_title"` // Information whether the title can be edited
|
||||
ImageProcessing BaseBoolInt `json:"image_processing"` // Information whether the image on processing
|
||||
Name string `json:"name"`
|
||||
ID int `json:"id"` // Link ID
|
||||
URL string `json:"url"` // Link URL
|
||||
}
|
||||
|
||||
// GroupsGroupPublicCategoryList struct.
|
||||
type GroupsGroupPublicCategoryList struct {
|
||||
ID int `json:"id"`
|
||||
Name string `json:"name"`
|
||||
Subcategories []GroupsGroupCategoryType `json:"subcategories"`
|
||||
}
|
||||
|
||||
// GroupsGroupSettings Photos type.
|
||||
const (
|
||||
GroupsGroupPhotosDisabled = iota
|
||||
GroupsGroupPhotosOpen
|
||||
GroupsGroupPhotosLimited
|
||||
)
|
||||
|
||||
// GroupsGroupSettings Subject type.
|
||||
const (
|
||||
_ = iota
|
||||
GroupsGroupSubjectAuto
|
||||
GroupsGroupSubjectActivityHolidays
|
||||
GroupsGroupSubjectBusiness
|
||||
GroupsGroupSubjectPets
|
||||
GroupsGroupSubjectHealth
|
||||
GroupsGroupSubjectDatingAndCommunication
|
||||
GroupsGroupSubjectGames
|
||||
GroupsGroupSubjectIt
|
||||
GroupsGroupSubjectCinema
|
||||
GroupsGroupSubjectBeautyAndFashion
|
||||
GroupsGroupSubjectCooking
|
||||
GroupsGroupSubjectArtAndCulture
|
||||
GroupsGroupSubjectLiterature
|
||||
GroupsGroupSubjectMobileServicesAndInternet
|
||||
GroupsGroupSubjectMusic
|
||||
GroupsGroupSubjectScienceAndTechnology
|
||||
GroupsGroupSubjectRealEstate
|
||||
GroupsGroupSubjectNewsAndMedia
|
||||
GroupsGroupSubjectSecurity
|
||||
GroupsGroupSubjectEducation
|
||||
GroupsGroupSubjectHomeAndRenovations
|
||||
GroupsGroupSubjectPolitics
|
||||
GroupsGroupSubjectFood
|
||||
GroupsGroupSubjectIndustry
|
||||
GroupsGroupSubjectTravel
|
||||
GroupsGroupSubjectWork
|
||||
GroupsGroupSubjectEntertainment
|
||||
GroupsGroupSubjectReligion
|
||||
GroupsGroupSubjectFamily
|
||||
GroupsGroupSubjectSports
|
||||
GroupsGroupSubjectInsurance
|
||||
GroupsGroupSubjectTelevision
|
||||
GroupsGroupSubjectGoodsAndServices
|
||||
GroupsGroupSubjectHobbies
|
||||
GroupsGroupSubjectFinance
|
||||
GroupsGroupSubjectPhoto
|
||||
GroupsGroupSubjectEsoterics
|
||||
GroupsGroupSubjectElectronicsAndAppliances
|
||||
GroupsGroupSubjectErotic
|
||||
GroupsGroupSubjectHumor
|
||||
GroupsGroupSubjectSocietyHumanities
|
||||
GroupsGroupSubjectDesignAndGraphics
|
||||
)
|
||||
|
||||
// GroupsGroupSettings Topics type.
|
||||
const (
|
||||
GroupsGroupTopicsDisabled = iota
|
||||
GroupsGroupTopicsOpen
|
||||
GroupsGroupTopicsLimited
|
||||
)
|
||||
|
||||
// GroupsGroupSettings Docs type.
|
||||
const (
|
||||
GroupsGroupDocsDisabled = iota
|
||||
GroupsGroupDocsOpen
|
||||
GroupsGroupDocsLimited
|
||||
)
|
||||
|
||||
// GroupsGroupSettings Audio type.
|
||||
const (
|
||||
GroupsGroupAudioDisabled = iota
|
||||
GroupsGroupAudioOpen
|
||||
GroupsGroupAudioLimited
|
||||
)
|
||||
|
||||
// GroupsGroupSettings Video type.
|
||||
const (
|
||||
GroupsGroupVideoDisabled = iota
|
||||
GroupsGroupVideoOpen
|
||||
GroupsGroupVideoLimited
|
||||
)
|
||||
|
||||
// GroupsGroupSettings Wall type.
|
||||
const (
|
||||
GroupsGroupWallDisabled = iota
|
||||
GroupsGroupWallOpen
|
||||
GroupsGroupWallLimited
|
||||
GroupsGroupWallClosed
|
||||
)
|
||||
|
||||
// GroupsGroupSettings Wiki type.
|
||||
const (
|
||||
GroupsGroupWikiDisabled = iota
|
||||
GroupsGroupWikiOpen
|
||||
GroupsGroupWikiLimited
|
||||
)
|
||||
|
||||
// GroupsGroupSettings struct.
|
||||
type GroupsGroupSettings struct {
|
||||
Access int `json:"access"` // Community access settings
|
||||
Address string `json:"address"` // Community's page domain
|
||||
Audio int `json:"audio"` // Audio settings
|
||||
Description string `json:"description"` // Community description
|
||||
Docs int `json:"docs"` // Docs settings
|
||||
ObsceneWords []string `json:"obscene_words"` // The list of stop words
|
||||
Photos int `json:"photos"` // Photos settings
|
||||
PublicCategory int `json:"public_category"` // Information about the group category
|
||||
PublicCategoryList []GroupsGroupPublicCategoryList `json:"public_category_list"`
|
||||
|
||||
// Information about the group subcategory.
|
||||
PublicSubcategory int `json:"public_subcategory"`
|
||||
Rss string `json:"rss"` // URL of the RSS feed
|
||||
Subject int `json:"subject"` // Community subject ID
|
||||
SubjectList []GroupsSubjectItem `json:"subject_list"`
|
||||
Title string `json:"title"` // Community title
|
||||
Topics int `json:"topics"` // Topics settings
|
||||
Video int `json:"video"` // Video settings
|
||||
Wall int `json:"wall"` // Wall settings
|
||||
Website string `json:"website"` // Community website
|
||||
Wiki int `json:"wiki"` // Wiki settings
|
||||
CountryID int `json:"country_id"`
|
||||
CityID int `json:"city_id"`
|
||||
Messages int `json:"messages"`
|
||||
Articles int `json:"articles"`
|
||||
Events int `json:"events"`
|
||||
AgeLimits int `json:"age_limits"`
|
||||
|
||||
// Information whether the obscene filter is enabled.
|
||||
ObsceneFilter BaseBoolInt `json:"obscene_filter"`
|
||||
|
||||
// Information whether the stopwords filter is enabled.
|
||||
ObsceneStopwords BaseBoolInt `json:"obscene_stopwords"`
|
||||
LiveCovers struct {
|
||||
IsEnabled BaseBoolInt `json:"is_enabled"`
|
||||
} `json:"live_covers"`
|
||||
Market GroupsMarketInfo `json:"market"`
|
||||
SectionsList []GroupsSectionsList `json:"sections_list"`
|
||||
MainSection int `json:"main_section"`
|
||||
SecondarySection int `json:"secondary_section"`
|
||||
ActionButton GroupsActionButton `json:"action_button"`
|
||||
Phone string `json:"phone"`
|
||||
}
|
||||
|
||||
// GroupsSectionsList struct.
|
||||
type GroupsSectionsList struct {
|
||||
ID int `json:"id"`
|
||||
Name string `json:"name"`
|
||||
}
|
||||
|
||||
// UnmarshalJSON need for unmarshal dynamic array (Example: [1, "Фотографии"]) to struct.
|
||||
//
|
||||
// To unmarshal JSON into a value implementing the Unmarshaler interface,
|
||||
// Unmarshal calls that value's UnmarshalJSON method.
|
||||
// See more https://golang.org/pkg/encoding/json/#Unmarshal
|
||||
func (g *GroupsSectionsList) UnmarshalJSON(data []byte) error {
|
||||
var alias []interface{}
|
||||
if err := json.Unmarshal(data, &alias); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if len(alias) != 2 {
|
||||
return &json.UnmarshalTypeError{
|
||||
Value: string(data),
|
||||
Type: reflect.TypeOf((*GroupsSectionsList)(nil)),
|
||||
}
|
||||
}
|
||||
|
||||
// default concrete Go type float64 for JSON numbers
|
||||
id, ok := alias[0].(float64)
|
||||
if !ok {
|
||||
return &json.UnmarshalTypeError{
|
||||
Value: string(data),
|
||||
Type: reflect.TypeOf((*GroupsSectionsList)(nil)),
|
||||
Struct: "GroupsSectionsList",
|
||||
Field: "ID",
|
||||
}
|
||||
}
|
||||
|
||||
name, ok := alias[1].(string)
|
||||
if !ok {
|
||||
return &json.UnmarshalTypeError{
|
||||
Value: string(data),
|
||||
Type: reflect.TypeOf((*GroupsSectionsList)(nil)),
|
||||
Struct: "GroupsSectionsList",
|
||||
Field: "Name",
|
||||
}
|
||||
}
|
||||
|
||||
g.ID = int(id)
|
||||
g.Name = name
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// GroupsActionType for action_button in groups.
|
||||
type GroupsActionType string
|
||||
|
||||
// GroupsActionType enums.
|
||||
const (
|
||||
GroupsActionTypeOpenURL GroupsActionType = "open_url"
|
||||
GroupsActionTypeSendEmail GroupsActionType = "send_email"
|
||||
GroupsActionTypeCallPhone GroupsActionType = "call_phone"
|
||||
GroupsActionTypeCallVK GroupsActionType = "call_vk"
|
||||
GroupsActionTypeOpenGroupApp GroupsActionType = "open_group_app"
|
||||
GroupsActionTypeOpenApp GroupsActionType = "open_app"
|
||||
)
|
||||
|
||||
// GroupsActionButton struct.
|
||||
type GroupsActionButton struct {
|
||||
ActionType GroupsActionType `json:"action_type"`
|
||||
Target GroupsActionButtonTarget `json:"target"`
|
||||
Title string `json:"title"`
|
||||
|
||||
// IsEnabled for GroupsGroupSettings
|
||||
IsEnabled BaseBoolInt `json:"is_enabled,omitempty"`
|
||||
}
|
||||
|
||||
// GroupsActionButtonTarget struct.
|
||||
type GroupsActionButtonTarget struct {
|
||||
// ActionType == ActionTypeSendEmail
|
||||
Email string `json:"email"`
|
||||
|
||||
// ActionType == ActionTypeCallPhone
|
||||
Phone string `json:"phone"`
|
||||
|
||||
// ActionType == ActionTypeCallVK
|
||||
UserID int `json:"user_id"`
|
||||
|
||||
// ActionType == ActionTypeOpenURL
|
||||
URL string `json:"url"`
|
||||
|
||||
// ActionType == ActionTypeOpenApp
|
||||
GoogleStoreURL string `json:"google_store_url"`
|
||||
ItunesURL string `json:"itunes_url"`
|
||||
// URL string `json:"url"`
|
||||
|
||||
// ActionType == ActionTypeOpenGroupApp
|
||||
AppID int `json:"app_id"`
|
||||
|
||||
IsInternal BaseBoolInt `json:"is_internal"`
|
||||
}
|
||||
|
||||
// GroupsGroupXtrInvitedBy struct.
|
||||
type GroupsGroupXtrInvitedBy struct {
|
||||
AdminLevel int `json:"admin_level"`
|
||||
ID int `json:"id"` // Community ID
|
||||
InvitedBy int `json:"invited_by"` // Inviter ID
|
||||
Name string `json:"name"` // Community name
|
||||
Photo100 string `json:"photo_100"` // URL of square photo of the community with 100 pixels in width
|
||||
Photo200 string `json:"photo_200"` // URL of square photo of the community with 200 pixels in width
|
||||
Photo50 string `json:"photo_50"` // URL of square photo of the community with 50 pixels in width
|
||||
ScreenName string `json:"screen_name"` // Domain of the community page
|
||||
Type string `json:"type"`
|
||||
IsClosed int `json:"is_closed"` // Information whether community is closed
|
||||
IsAdmin BaseBoolInt `json:"is_admin"` // Information whether current user is manager
|
||||
IsMember BaseBoolInt `json:"is_member"` // Information whether current user is member
|
||||
IsAdvertiser BaseBoolInt `json:"is_advertiser"` // Information whether current user is advertiser
|
||||
}
|
||||
|
||||
// ToMention return mention.
|
||||
func (group GroupsGroupXtrInvitedBy) ToMention() string {
|
||||
return fmt.Sprintf("[club%d|%s]", group.ID, group.Name)
|
||||
}
|
||||
|
||||
// GroupsLinksItem struct.
|
||||
type GroupsLinksItem struct {
|
||||
Desc string `json:"desc"` // Link description
|
||||
EditTitle BaseBoolInt `json:"edit_title"` // Information whether the link title can be edited
|
||||
ID int `json:"id"` // Link ID
|
||||
Name string `json:"name"` // Link title
|
||||
Photo100 string `json:"photo_100"` // URL of square image of the link with 100 pixels in width
|
||||
Photo50 string `json:"photo_50"` // URL of square image of the link with 50 pixels in width
|
||||
URL string `json:"url"` // Link URL
|
||||
}
|
||||
|
||||
// GroupsLongPollEvents struct.
|
||||
type GroupsLongPollEvents struct {
|
||||
MessageNew BaseBoolInt `json:"message_new"`
|
||||
MessageReply BaseBoolInt `json:"message_reply"`
|
||||
PhotoNew BaseBoolInt `json:"photo_new"`
|
||||
AudioNew BaseBoolInt `json:"audio_new"`
|
||||
VideoNew BaseBoolInt `json:"video_new"`
|
||||
WallReplyNew BaseBoolInt `json:"wall_reply_new"`
|
||||
WallReplyEdit BaseBoolInt `json:"wall_reply_edit"`
|
||||
WallReplyDelete BaseBoolInt `json:"wall_reply_delete"`
|
||||
WallReplyRestore BaseBoolInt `json:"wall_reply_restore"`
|
||||
WallPostNew BaseBoolInt `json:"wall_post_new"`
|
||||
BoardPostNew BaseBoolInt `json:"board_post_new"`
|
||||
BoardPostEdit BaseBoolInt `json:"board_post_edit"`
|
||||
BoardPostRestore BaseBoolInt `json:"board_post_restore"`
|
||||
BoardPostDelete BaseBoolInt `json:"board_post_delete"`
|
||||
PhotoCommentNew BaseBoolInt `json:"photo_comment_new"`
|
||||
PhotoCommentEdit BaseBoolInt `json:"photo_comment_edit"`
|
||||
PhotoCommentDelete BaseBoolInt `json:"photo_comment_delete"`
|
||||
PhotoCommentRestore BaseBoolInt `json:"photo_comment_restore"`
|
||||
VideoCommentNew BaseBoolInt `json:"video_comment_new"`
|
||||
VideoCommentEdit BaseBoolInt `json:"video_comment_edit"`
|
||||
VideoCommentDelete BaseBoolInt `json:"video_comment_delete"`
|
||||
VideoCommentRestore BaseBoolInt `json:"video_comment_restore"`
|
||||
MarketCommentNew BaseBoolInt `json:"market_comment_new"`
|
||||
MarketCommentEdit BaseBoolInt `json:"market_comment_edit"`
|
||||
MarketCommentDelete BaseBoolInt `json:"market_comment_delete"`
|
||||
MarketCommentRestore BaseBoolInt `json:"market_comment_restore"`
|
||||
MarketOrderNew BaseBoolInt `json:"market_order_new"`
|
||||
MarketOrderEdit BaseBoolInt `json:"market_order_edit"`
|
||||
PollVoteNew BaseBoolInt `json:"poll_vote_new"`
|
||||
GroupJoin BaseBoolInt `json:"group_join"`
|
||||
GroupLeave BaseBoolInt `json:"group_leave"`
|
||||
GroupChangeSettings BaseBoolInt `json:"group_change_settings"`
|
||||
GroupChangePhoto BaseBoolInt `json:"group_change_photo"`
|
||||
GroupOfficersEdit BaseBoolInt `json:"group_officers_edit"`
|
||||
MessageAllow BaseBoolInt `json:"message_allow"`
|
||||
MessageDeny BaseBoolInt `json:"message_deny"`
|
||||
WallRepost BaseBoolInt `json:"wall_repost"`
|
||||
UserBlock BaseBoolInt `json:"user_block"`
|
||||
UserUnblock BaseBoolInt `json:"user_unblock"`
|
||||
MessageEdit BaseBoolInt `json:"message_edit"`
|
||||
MessageTypingState BaseBoolInt `json:"message_typing_state"`
|
||||
LeadFormsNew BaseBoolInt `json:"lead_forms_new"`
|
||||
LikeAdd BaseBoolInt `json:"like_add"`
|
||||
LikeRemove BaseBoolInt `json:"like_remove"`
|
||||
VkpayTransaction BaseBoolInt `json:"vkpay_transaction"`
|
||||
AppPayload BaseBoolInt `json:"app_payload"`
|
||||
MessageRead BaseBoolInt `json:"message_read"`
|
||||
MessageEvent BaseBoolInt `json:"message_event"`
|
||||
DonutSubscriptionCreate BaseBoolInt `json:"donut_subscription_create"`
|
||||
DonutSubscriptionProlonged BaseBoolInt `json:"donut_subscription_prolonged"`
|
||||
DonutSubscriptionExpired BaseBoolInt `json:"donut_subscription_expired"`
|
||||
DonutSubscriptionCancelled BaseBoolInt `json:"donut_subscription_cancelled"`
|
||||
DonutSubscriptionPriceChanged BaseBoolInt `json:"donut_subscription_price_changed"`
|
||||
DonutMoneyWithdraw BaseBoolInt `json:"donut_money_withdraw"`
|
||||
DonutMoneyWithdrawError BaseBoolInt `json:"donut_money_withdraw_error"`
|
||||
|
||||
// Bugs
|
||||
// MessagesEdit BaseBoolInt `json:"messages_edit"`
|
||||
// WallNew BaseBoolInt `json:"wall_new"`
|
||||
// WallNewReply BaseBoolInt `json:"wall_new_reply"`
|
||||
// WallEditReply BaseBoolInt `json:"wall_edit_reply"`
|
||||
}
|
||||
|
||||
// GroupsLongPollServer struct.
|
||||
type GroupsLongPollServer struct {
|
||||
Key string `json:"key"` // Long Poll key
|
||||
Server string `json:"server"` // Long Poll server address
|
||||
Ts string `json:"ts"` // Number of the last event
|
||||
}
|
||||
|
||||
// TODO: func (g GroupsLongPollServer) GetURL() string {
|
||||
|
||||
// GroupsLongPollSettings struct.
|
||||
type GroupsLongPollSettings struct {
|
||||
APIVersion string `json:"api_version"` // API version used for the events
|
||||
Events GroupsLongPollEvents `json:"events"`
|
||||
IsEnabled BaseBoolInt `json:"is_enabled"` // Shows whether Long Poll is enabled
|
||||
}
|
||||
|
||||
// GroupsMarketType ...
|
||||
type GroupsMarketType string
|
||||
|
||||
// Possible values.
|
||||
const (
|
||||
GroupsMarketBasic GroupsMarketType = "basic"
|
||||
GroupsMarketAdvanced GroupsMarketType = "advanced"
|
||||
)
|
||||
|
||||
// GroupsMarketInfo struct.
|
||||
type GroupsMarketInfo struct {
|
||||
// information about the type of store. Returned if the group includes
|
||||
// the "Products" section.
|
||||
Type GroupsMarketType `json:"type,omitempty"`
|
||||
ContactID int `json:"contact_id,omitempty"` // Contact person ID
|
||||
Currency MarketCurrency `json:"currency,omitempty"`
|
||||
CurrencyText string `json:"currency_text,omitempty"` // Currency name
|
||||
Enabled BaseBoolInt `json:"enabled"` // Information whether the market is enabled
|
||||
CommentsEnabled BaseBoolInt `json:"comments_enabled,omitempty"`
|
||||
CanMessage BaseBoolInt `json:"can_message,omitempty"`
|
||||
MainAlbumID int `json:"main_album_id,omitempty"` // Main market album ID
|
||||
PriceMax string `json:"price_max,omitempty"` // Maximum price
|
||||
PriceMin string `json:"price_min,omitempty"` // Minimum price
|
||||
Wiki PagesWikipageFull `json:"wiki,omitempty"`
|
||||
CityIDs []int `json:"city_ids"`
|
||||
CountryIDs []int `json:"country_ids,omitempty"`
|
||||
}
|
||||
|
||||
// GroupsGroupRole Role type.
|
||||
const (
|
||||
GroupsGroupRoleModerator = "moderator"
|
||||
GroupsGroupRoleEditor = "editor"
|
||||
GroupsGroupRoleAdministrator = "administrator"
|
||||
GroupsGroupRoleCreator = "creator"
|
||||
)
|
||||
|
||||
// GroupsMemberRole struct.
|
||||
type GroupsMemberRole struct {
|
||||
ID int `json:"id"` // User ID
|
||||
Role string `json:"role"`
|
||||
Permissions []string `json:"permissions"`
|
||||
}
|
||||
|
||||
// GroupsMemberRoleXtrUsersUser struct.
|
||||
type GroupsMemberRoleXtrUsersUser struct {
|
||||
UsersUser
|
||||
Role string `json:"role"`
|
||||
Permissions []string `json:"permissions"`
|
||||
}
|
||||
|
||||
// GroupsMemberStatus struct.
|
||||
type GroupsMemberStatus struct {
|
||||
Member BaseBoolInt `json:"member"` // Information whether user is a member of the group
|
||||
UserID int `json:"user_id"` // User ID
|
||||
Permissions []string `json:"permissions"`
|
||||
}
|
||||
|
||||
// GroupsMemberStatusFull struct.
|
||||
type GroupsMemberStatusFull struct {
|
||||
Invitation BaseBoolInt `json:"invitation"` // Information whether user has been invited to the group
|
||||
Member BaseBoolInt `json:"member"` // Information whether user is a member of the group
|
||||
Request BaseBoolInt `json:"request"` // Information whether user has send request to the group
|
||||
CanInvite BaseBoolInt `json:"can_invite"` // Information whether user can be invite
|
||||
CanRecall BaseBoolInt `json:"can_recall"` // Information whether user's invite to the group can be recalled
|
||||
UserID int `json:"user_id"` // User ID
|
||||
}
|
||||
|
||||
// GroupsOnlineStatus Status type.
|
||||
const (
|
||||
GroupsOnlineStatusTypeNone = "none"
|
||||
GroupsOnlineStatusTypeOnline = "online"
|
||||
GroupsOnlineStatusTypeAnswerMark = "answer_mark"
|
||||
)
|
||||
|
||||
// GroupsOnlineStatus struct.
|
||||
type GroupsOnlineStatus struct {
|
||||
Minutes int `json:"minutes"` // Estimated time of answer (for status = answer_mark)
|
||||
Status string `json:"status"`
|
||||
}
|
||||
|
||||
// GroupsOwnerXtrBanInfo struct.
|
||||
type GroupsOwnerXtrBanInfo struct {
|
||||
BanInfo GroupsBanInfo `json:"ban_info"`
|
||||
Group GroupsGroup `json:"group"`
|
||||
Profile UsersUser `json:"profile"`
|
||||
Type string `json:"type"`
|
||||
}
|
||||
|
||||
// GroupsSubjectItem struct.
|
||||
type GroupsSubjectItem struct {
|
||||
ID int `json:"id"`
|
||||
Name string `json:"name"`
|
||||
}
|
||||
|
||||
// GroupsTokenPermissionSetting struct.
|
||||
type GroupsTokenPermissionSetting struct {
|
||||
Name string `json:"name"`
|
||||
Setting int `json:"setting"`
|
||||
}
|
||||
|
||||
// GroupsTokenPermissions struct.
|
||||
type GroupsTokenPermissions struct {
|
||||
Mask int `json:"mask"`
|
||||
Permissions []GroupsTokenPermissionSetting `json:"permissions"`
|
||||
}
|
||||
|
||||
// GroupsTag struct.
|
||||
type GroupsTag struct {
|
||||
ID int `json:"id"`
|
||||
Name string `json:"name"`
|
||||
Color string `json:"color"`
|
||||
}
|
@ -0,0 +1,44 @@
|
||||
package object
|
||||
|
||||
// LeadFormsForm struct.
|
||||
type LeadFormsForm struct {
|
||||
FormID int `json:"form_id"`
|
||||
GroupID int `json:"group_id"`
|
||||
Photo interface{} `json:"photo"`
|
||||
Name string `json:"name"`
|
||||
Title string `json:"title"`
|
||||
Description string `json:"description"`
|
||||
Confirmation string `json:"confirmation"`
|
||||
SiteLinkURL string `json:"site_link_url"`
|
||||
PolicyLinkURL string `json:"policy_link_url"`
|
||||
Questions []struct {
|
||||
Type string `json:"type"`
|
||||
Key string `json:"key"`
|
||||
Label string `json:"label,omitempty"`
|
||||
Options []struct {
|
||||
Label string `json:"label"`
|
||||
Key string `json:"key"`
|
||||
} `json:"options,omitempty"`
|
||||
} `json:"questions"`
|
||||
Active int `json:"active"`
|
||||
LeadsCount int `json:"leads_count"`
|
||||
PixelCode string `json:"pixel_code"`
|
||||
OncePerUser int `json:"once_per_user"`
|
||||
NotifyAdmins string `json:"notify_admins"`
|
||||
NotifyEmails string `json:"notify_emails"`
|
||||
URL string `json:"url"`
|
||||
}
|
||||
|
||||
// LeadFormsLead struct.
|
||||
type LeadFormsLead struct {
|
||||
LeadID string `json:"lead_id"`
|
||||
UserID string `json:"user_id"`
|
||||
Date string `json:"date"`
|
||||
Answers []struct {
|
||||
Key string `json:"key"`
|
||||
Answer struct {
|
||||
Value string `json:"value"`
|
||||
} `json:"answer"`
|
||||
} `json:"answers"`
|
||||
AdID string `json:"ad_id"`
|
||||
}
|
@ -0,0 +1,55 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// LeadsChecked struct.
|
||||
type LeadsChecked struct {
|
||||
Reason string `json:"reason"` // Reason why user can't start the lead
|
||||
Result string `json:"result"`
|
||||
Sid string `json:"sid"` // Session ID
|
||||
StartLink string `json:"start_link"` // URL user should open to start the lead
|
||||
}
|
||||
|
||||
// LeadsComplete struct.
|
||||
type LeadsComplete struct {
|
||||
Cost int `json:"cost"` // Offer cost
|
||||
Limit int `json:"limit"` // Offer limit
|
||||
Spent int `json:"spent"` // Amount of spent votes
|
||||
Success BaseBoolInt `json:"success"`
|
||||
TestMode BaseBoolInt `json:"test_mode"` // Information whether test mode is enabled
|
||||
}
|
||||
|
||||
// LeadsEntry struct.
|
||||
type LeadsEntry struct {
|
||||
Aid int `json:"aid"` // Application ID
|
||||
Comment string `json:"comment"` // Comment text
|
||||
Date int `json:"date"` // Date when the action has been started in Unixtime
|
||||
Sid string `json:"sid"` // Session string ID
|
||||
StartDate int `json:"start_date"` // Start date in Unixtime (for status=2)
|
||||
Status int `json:"status"` // Action type
|
||||
TestMode BaseBoolInt `json:"test_mode"` // Information whether test mode is enabled
|
||||
UID int `json:"uid"` // User ID
|
||||
}
|
||||
|
||||
// LeadsLead struct.
|
||||
type LeadsLead struct {
|
||||
Completed int `json:"completed"` // Completed offers number
|
||||
Cost int `json:"cost"` // Offer cost
|
||||
Days LeadsLeadDays `json:"days"`
|
||||
Impressions int `json:"impressions"` // Impressions number
|
||||
Limit int `json:"limit"` // Lead limit
|
||||
Spent int `json:"spent"` // Amount of spent votes
|
||||
Started int `json:"started"` // Started offers number
|
||||
}
|
||||
|
||||
// LeadsLeadDays struct.
|
||||
type LeadsLeadDays struct {
|
||||
Completed int `json:"completed"` // Completed offers number
|
||||
Impressions int `json:"impressions"` // Impressions number
|
||||
Spent int `json:"spent"` // Amount of spent votes
|
||||
Started int `json:"started"` // Started offers number
|
||||
}
|
||||
|
||||
// LeadsStart struct.
|
||||
type LeadsStart struct {
|
||||
TestMode BaseBoolInt `json:"test_mode"` // Information whether test mode is enabled
|
||||
VkSid string `json:"vk_sid"` // Session data
|
||||
}
|
@ -0,0 +1,244 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// Information whether the MarketMarketItem is available.
|
||||
const (
|
||||
MarketItemAvailable = iota
|
||||
MarketItemRemoved
|
||||
MarketItemUnavailable
|
||||
)
|
||||
|
||||
// MarketCurrency struct.
|
||||
type MarketCurrency struct {
|
||||
ID int `json:"id"` // Currency ID
|
||||
Name string `json:"name"` // Currency sign
|
||||
}
|
||||
|
||||
// MarketMarketAlbum struct.
|
||||
type MarketMarketAlbum struct {
|
||||
Count int `json:"count"` // Items number
|
||||
ID int `json:"id"` // Market album ID
|
||||
OwnerID int `json:"owner_id"` // Market album owner's ID
|
||||
Photo PhotosPhoto `json:"photo"`
|
||||
Title string `json:"title"` // Market album title
|
||||
UpdatedTime int `json:"updated_time"` // Date when album has been updated last time in Unixtime
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (marketAlbum MarketMarketAlbum) ToAttachment() string {
|
||||
return fmt.Sprintf("market_album%d_%d", marketAlbum.OwnerID, marketAlbum.ID)
|
||||
}
|
||||
|
||||
// MarketMarketCategory struct.
|
||||
type MarketMarketCategory struct {
|
||||
ID int `json:"id"` // Category ID
|
||||
Name string `json:"name"` // Category name
|
||||
Section MarketSection `json:"section"`
|
||||
}
|
||||
|
||||
// MarketMarketItem struct.
|
||||
type MarketMarketItem struct {
|
||||
AccessKey string `json:"access_key"` // Access key for the market item
|
||||
Availability int `json:"availability"` // Information whether the item is available
|
||||
Category MarketMarketCategory `json:"category"`
|
||||
|
||||
// Date when the item has been created in Unixtime.
|
||||
Date int `json:"date,omitempty"`
|
||||
Description string `json:"description"` // Item description
|
||||
ID int `json:"id"` // Item ID
|
||||
OwnerID int `json:"owner_id"` // Item owner's ID
|
||||
Price MarketPrice `json:"price"`
|
||||
ThumbPhoto string `json:"thumb_photo"` // URL of the preview image
|
||||
Title string `json:"title"` // Item title
|
||||
CanComment BaseBoolInt `json:"can_comment"`
|
||||
CanRepost BaseBoolInt `json:"can_repost"`
|
||||
IsFavorite BaseBoolInt `json:"is_favorite"`
|
||||
IsMainVariant BaseBoolInt `json:"is_main_variant"`
|
||||
AlbumsIDs []int `json:"albums_ids"`
|
||||
Photos []PhotosPhoto `json:"photos"`
|
||||
Likes BaseLikesInfo `json:"likes"`
|
||||
Reposts BaseRepostsInfo `json:"reposts"`
|
||||
ViewsCount int `json:"views_count,omitempty"`
|
||||
URL string `json:"url"` // URL to item
|
||||
ButtonTitle string `json:"button_title"`
|
||||
ExternalID string `json:"external_id"`
|
||||
Dimensions MarketDimensions `json:"dimensions"`
|
||||
Weight int `json:"weight"`
|
||||
VariantsGroupingID int `json:"variants_grouping_id"`
|
||||
PropertyValues []MarketMarketItemProperty `json:"property_values"`
|
||||
CartQuantity int `json:"cart_quantity"`
|
||||
}
|
||||
|
||||
// UnmarshalJSON MarketMarketItem.
|
||||
//
|
||||
// BUG(VK): https://github.com/SevereCloud/vksdk/issues/147
|
||||
func (market *MarketMarketItem) UnmarshalJSON(data []byte) error {
|
||||
if bytes.Equal(data, []byte("false")) {
|
||||
return nil
|
||||
}
|
||||
|
||||
type renamedMarketMarketItem MarketMarketItem
|
||||
|
||||
var r renamedMarketMarketItem
|
||||
|
||||
err := json.Unmarshal(data, &r)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
*market = MarketMarketItem(r)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// MarketMarketItemProperty struct.
|
||||
type MarketMarketItemProperty struct {
|
||||
VariantID int `json:"variant_id"`
|
||||
VariantName string `json:"variant_name"`
|
||||
PropertyName string `json:"property_name"`
|
||||
}
|
||||
|
||||
// MarketDimensions struct.
|
||||
type MarketDimensions struct {
|
||||
Width int `json:"width"`
|
||||
Height int `json:"height"`
|
||||
Length int `json:"length"`
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (market MarketMarketItem) ToAttachment() string {
|
||||
return fmt.Sprintf("market%d_%d", market.OwnerID, market.ID)
|
||||
}
|
||||
|
||||
// MarketPrice struct.
|
||||
type MarketPrice struct {
|
||||
Amount string `json:"amount"` // Amount
|
||||
Currency MarketCurrency `json:"currency"`
|
||||
DiscountRate int `json:"discount_rate"`
|
||||
OldAmount string `json:"old_amount"`
|
||||
Text string `json:"text"` // Text
|
||||
OldAmountText string `json:"old_amount_text"`
|
||||
}
|
||||
|
||||
// UnmarshalJSON MarketPrice.
|
||||
//
|
||||
// BUG(VK): unavailable product, in fave.get return [].
|
||||
func (m *MarketPrice) UnmarshalJSON(data []byte) error {
|
||||
if bytes.Equal(data, []byte("[]")) {
|
||||
return nil
|
||||
}
|
||||
|
||||
type renamedMarketPrice MarketPrice
|
||||
|
||||
var r renamedMarketPrice
|
||||
|
||||
err := json.Unmarshal(data, &r)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
*m = MarketPrice(r)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// MarketSection struct.
|
||||
type MarketSection struct {
|
||||
ID int `json:"id"` // Section ID
|
||||
Name string `json:"name"` // Section name
|
||||
}
|
||||
|
||||
// MarketOrderStatus order status.
|
||||
type MarketOrderStatus int
|
||||
|
||||
// Possible values.
|
||||
const (
|
||||
MarketOrderNew MarketOrderStatus = iota
|
||||
MarketOrderPending
|
||||
MarketOrderProcessing
|
||||
MarketOrderShipped
|
||||
MarketOrderComplete
|
||||
MarketOrderCanceled
|
||||
MarketOrderRefund
|
||||
)
|
||||
|
||||
// MarketOrder struct.
|
||||
type MarketOrder struct {
|
||||
ID int `json:"id"`
|
||||
GroupID int `json:"group_id"`
|
||||
UserID int `json:"user_id"`
|
||||
Date int `json:"date"`
|
||||
Status MarketOrderStatus `json:"status"`
|
||||
ItemsCount int `json:"items_count"`
|
||||
TotalPrice MarketPrice `json:"total_price"`
|
||||
DisplayOrderID string `json:"display_order_id"`
|
||||
Comment string `json:"comment"`
|
||||
PreviewOrderItems []MarketOrderItem `json:"preview_order_items"`
|
||||
PriceDetails []MarketPriceDetail `json:"price_details"`
|
||||
Delivery MarketOrderDelivery `json:"delivery"`
|
||||
Recipient MarketOrderRecipient `json:"recipient"`
|
||||
}
|
||||
|
||||
// MarketOrderDelivery struct.
|
||||
type MarketOrderDelivery struct {
|
||||
TrackNumber string `json:"track_number"`
|
||||
TrackLink string `json:"track_link"`
|
||||
Address string `json:"address"`
|
||||
Type string `json:"type"`
|
||||
DeliveryPoint MarketDeliveryPoint `json:"delivery_point,omitempty"`
|
||||
}
|
||||
|
||||
// MarketDeliveryPoint struct.
|
||||
type MarketDeliveryPoint struct {
|
||||
ID int `json:"id"`
|
||||
ExternalID string `json:"external_id"`
|
||||
OutpostOnly BaseBoolInt `json:"outpost_only"`
|
||||
CashOnly BaseBoolInt `json:"cash_only"`
|
||||
Address MarketDeliveryPointAddress `json:"address"`
|
||||
DisplayTitle string `json:"display_title"`
|
||||
ServiceID int `json:"service_id"`
|
||||
}
|
||||
|
||||
// MarketDeliveryPointAddress struct.
|
||||
type MarketDeliveryPointAddress struct {
|
||||
ID int `json:"id"`
|
||||
Address string `json:"address"`
|
||||
CityID int `json:"city_id"`
|
||||
CountryID int `json:"country_id"`
|
||||
Latitude float64 `json:"latitude"`
|
||||
Longitude float64 `json:"longitude"`
|
||||
Phone string `json:"phone"`
|
||||
Title string `json:"title"`
|
||||
WorkInfoStatus string `json:"work_info_status"`
|
||||
}
|
||||
|
||||
// MarketOrderRecipient struct.
|
||||
type MarketOrderRecipient struct {
|
||||
Name string `json:"name"`
|
||||
Phone string `json:"phone"`
|
||||
DisplayText string `json:"display_text"`
|
||||
}
|
||||
|
||||
// MarketOrderItem struct.
|
||||
type MarketOrderItem struct {
|
||||
OwnerID int `json:"owner_id"`
|
||||
ItemID int `json:"item_id"`
|
||||
Price MarketPrice `json:"price"`
|
||||
Quantity int `json:"quantity"`
|
||||
Item MarketMarketItem `json:"item"`
|
||||
Title string `json:"title"`
|
||||
Photo PhotosPhoto `json:"photo"`
|
||||
Variants []string `json:"variants"`
|
||||
}
|
||||
|
||||
// MarketPriceDetail struct.
|
||||
type MarketPriceDetail struct {
|
||||
Title string `json:"title"`
|
||||
Price MarketPrice `json:"price"`
|
||||
IsAccent BaseBoolInt `json:"is_accent,omitempty"`
|
||||
}
|
@ -0,0 +1,756 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// MessagesAudioMessage struct.
|
||||
type MessagesAudioMessage struct {
|
||||
AccessKey string `json:"access_key"` // Access key for the document
|
||||
ID int `json:"id"` // Document ID
|
||||
OwnerID int `json:"owner_id"` // Document owner ID
|
||||
Duration int `json:"duration"` // Audio message duration in seconds
|
||||
LinkMp3 string `json:"link_mp3"` // MP3 file URL
|
||||
LinkOgg string `json:"link_ogg"` // OGG file URL
|
||||
Waveform []int `json:"waveform"` // Sound visualisation
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (doc MessagesAudioMessage) ToAttachment() string {
|
||||
return fmt.Sprintf("doc%d_%d", doc.OwnerID, doc.ID)
|
||||
}
|
||||
|
||||
// MessagesGraffiti struct.
|
||||
type MessagesGraffiti struct {
|
||||
AccessKey string `json:"access_key"` // Access key for the document
|
||||
ID int `json:"id"` // Document ID
|
||||
OwnerID int `json:"owner_id"` // Document owner ID
|
||||
URL string `json:"url"` // Graffiti URL
|
||||
Width int `json:"width"` // Graffiti width
|
||||
Height int `json:"height"` // Graffiti height
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (doc MessagesGraffiti) ToAttachment() string {
|
||||
return fmt.Sprintf("doc%d_%d", doc.OwnerID, doc.ID)
|
||||
}
|
||||
|
||||
// MessagesMessage struct.
|
||||
type MessagesMessage struct {
|
||||
// Only for messages from community. Contains user ID of community admin,
|
||||
// who sent this message.
|
||||
AdminAuthorID int `json:"admin_author_id"`
|
||||
Action MessagesMessageAction `json:"action"`
|
||||
Attachments []MessagesMessageAttachment `json:"attachments"`
|
||||
|
||||
// Unique auto-incremented number for all messages with this peer.
|
||||
ConversationMessageID int `json:"conversation_message_id"`
|
||||
|
||||
// Date when the message has been sent in Unixtime.
|
||||
Date int `json:"date"`
|
||||
|
||||
// Message author's ID.
|
||||
FromID int `json:"from_id"`
|
||||
|
||||
// Forwarded messages.
|
||||
FwdMessages []MessagesMessage `json:"fwd_Messages"`
|
||||
ReplyMessage *MessagesMessage `json:"reply_message"`
|
||||
Geo BaseMessageGeo `json:"geo"`
|
||||
PinnedAt int `json:"pinned_at,omitempty"`
|
||||
ID int `json:"id"` // Message ID
|
||||
Deleted BaseBoolInt `json:"deleted"` // Is it an deleted message
|
||||
Important BaseBoolInt `json:"important"` // Is it an important message
|
||||
IsHidden BaseBoolInt `json:"is_hidden"`
|
||||
IsCropped BaseBoolInt `json:"is_cropped"`
|
||||
Out BaseBoolInt `json:"out"` // Information whether the message is outcoming
|
||||
WasListened BaseBoolInt `json:"was_listened,omitempty"`
|
||||
Keyboard MessagesKeyboard `json:"keyboard"`
|
||||
Template MessagesTemplate `json:"template"`
|
||||
Payload string `json:"payload"`
|
||||
PeerID int `json:"peer_id"` // Peer ID
|
||||
|
||||
// ID used for sending messages. It returned only for outgoing messages.
|
||||
RandomID int `json:"random_id"`
|
||||
Ref string `json:"ref"`
|
||||
RefSource string `json:"ref_source"`
|
||||
Text string `json:"text"` // Message text
|
||||
UpdateTime int `json:"update_time"` // Date when the message has been updated in Unixtime
|
||||
MembersCount int `json:"members_count"` // Members number
|
||||
ExpireTTL int `json:"expire_ttl"`
|
||||
}
|
||||
|
||||
// MessagesBasePayload struct.
|
||||
type MessagesBasePayload struct {
|
||||
ButtonType string `json:"button_type,omitempty"`
|
||||
Command string `json:"command,omitempty"`
|
||||
Payload string `json:"payload,omitempty"`
|
||||
}
|
||||
|
||||
// Command for MessagesBasePayload.
|
||||
const (
|
||||
CommandNotSupportedButton = "not_supported_button"
|
||||
)
|
||||
|
||||
// MessagesKeyboard struct.
|
||||
type MessagesKeyboard struct {
|
||||
AuthorID int `json:"author_id,omitempty"` // Community or bot, which set this keyboard
|
||||
Buttons [][]MessagesKeyboardButton `json:"buttons"`
|
||||
OneTime BaseBoolInt `json:"one_time,omitempty"` // Should this keyboard disappear on first use
|
||||
Inline BaseBoolInt `json:"inline,omitempty"`
|
||||
}
|
||||
|
||||
// NewMessagesKeyboard returns a new MessagesKeyboard.
|
||||
func NewMessagesKeyboard(oneTime BaseBoolInt) *MessagesKeyboard {
|
||||
return &MessagesKeyboard{
|
||||
Buttons: [][]MessagesKeyboardButton{},
|
||||
OneTime: oneTime,
|
||||
}
|
||||
}
|
||||
|
||||
// NewMessagesKeyboardInline returns a new inline MessagesKeyboard.
|
||||
func NewMessagesKeyboardInline() *MessagesKeyboard {
|
||||
return &MessagesKeyboard{
|
||||
Buttons: [][]MessagesKeyboardButton{},
|
||||
Inline: true,
|
||||
}
|
||||
}
|
||||
|
||||
// AddRow add row in MessagesKeyboard.
|
||||
func (keyboard *MessagesKeyboard) AddRow() *MessagesKeyboard {
|
||||
if len(keyboard.Buttons) == 0 {
|
||||
keyboard.Buttons = make([][]MessagesKeyboardButton, 1)
|
||||
} else {
|
||||
row := make([]MessagesKeyboardButton, 0)
|
||||
keyboard.Buttons = append(keyboard.Buttons, row)
|
||||
}
|
||||
|
||||
return keyboard
|
||||
}
|
||||
|
||||
// AddTextButton add Text button in last row.
|
||||
func (keyboard *MessagesKeyboard) AddTextButton(label string, payload interface{}, color string) *MessagesKeyboard {
|
||||
b, err := json.Marshal(payload)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
button := MessagesKeyboardButton{
|
||||
Action: MessagesKeyboardButtonAction{
|
||||
Type: ButtonText,
|
||||
Label: label,
|
||||
Payload: string(b),
|
||||
},
|
||||
Color: color,
|
||||
}
|
||||
|
||||
lastRow := len(keyboard.Buttons) - 1
|
||||
keyboard.Buttons[lastRow] = append(keyboard.Buttons[lastRow], button)
|
||||
|
||||
return keyboard
|
||||
}
|
||||
|
||||
// AddOpenLinkButton add Open Link button in last row.
|
||||
func (keyboard *MessagesKeyboard) AddOpenLinkButton(link, label string, payload interface{}) *MessagesKeyboard {
|
||||
b, err := json.Marshal(payload)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
button := MessagesKeyboardButton{
|
||||
Action: MessagesKeyboardButtonAction{
|
||||
Type: ButtonOpenLink,
|
||||
Payload: string(b),
|
||||
Label: label,
|
||||
Link: link,
|
||||
},
|
||||
}
|
||||
|
||||
lastRow := len(keyboard.Buttons) - 1
|
||||
keyboard.Buttons[lastRow] = append(keyboard.Buttons[lastRow], button)
|
||||
|
||||
return keyboard
|
||||
}
|
||||
|
||||
// AddLocationButton add Location button in last row.
|
||||
func (keyboard *MessagesKeyboard) AddLocationButton(payload interface{}) *MessagesKeyboard {
|
||||
b, err := json.Marshal(payload)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
button := MessagesKeyboardButton{
|
||||
Action: MessagesKeyboardButtonAction{
|
||||
Type: ButtonLocation,
|
||||
Payload: string(b),
|
||||
},
|
||||
}
|
||||
|
||||
lastRow := len(keyboard.Buttons) - 1
|
||||
keyboard.Buttons[lastRow] = append(keyboard.Buttons[lastRow], button)
|
||||
|
||||
return keyboard
|
||||
}
|
||||
|
||||
// AddVKPayButton add VK Pay button in last row.
|
||||
func (keyboard *MessagesKeyboard) AddVKPayButton(payload interface{}, hash string) *MessagesKeyboard {
|
||||
b, err := json.Marshal(payload)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
button := MessagesKeyboardButton{
|
||||
Action: MessagesKeyboardButtonAction{
|
||||
Type: ButtonVKPay,
|
||||
Payload: string(b),
|
||||
Hash: hash,
|
||||
},
|
||||
}
|
||||
|
||||
lastRow := len(keyboard.Buttons) - 1
|
||||
keyboard.Buttons[lastRow] = append(keyboard.Buttons[lastRow], button)
|
||||
|
||||
return keyboard
|
||||
}
|
||||
|
||||
// AddVKAppsButton add VK Apps button in last row.
|
||||
func (keyboard *MessagesKeyboard) AddVKAppsButton(
|
||||
appID, ownerID int,
|
||||
payload interface{},
|
||||
label, hash string,
|
||||
) *MessagesKeyboard {
|
||||
b, err := json.Marshal(payload)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
button := MessagesKeyboardButton{
|
||||
Action: MessagesKeyboardButtonAction{
|
||||
Type: ButtonVKApp,
|
||||
AppID: appID,
|
||||
OwnerID: ownerID,
|
||||
Payload: string(b),
|
||||
Label: label,
|
||||
Hash: hash,
|
||||
},
|
||||
}
|
||||
|
||||
lastRow := len(keyboard.Buttons) - 1
|
||||
keyboard.Buttons[lastRow] = append(keyboard.Buttons[lastRow], button)
|
||||
|
||||
return keyboard
|
||||
}
|
||||
|
||||
// AddCallbackButton add Callback button in last row.
|
||||
func (keyboard *MessagesKeyboard) AddCallbackButton(label string, payload interface{}, color string) *MessagesKeyboard {
|
||||
b, err := json.Marshal(payload)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
button := MessagesKeyboardButton{
|
||||
Action: MessagesKeyboardButtonAction{
|
||||
Type: ButtonCallback,
|
||||
Label: label,
|
||||
Payload: string(b),
|
||||
},
|
||||
Color: color,
|
||||
}
|
||||
|
||||
lastRow := len(keyboard.Buttons) - 1
|
||||
keyboard.Buttons[lastRow] = append(keyboard.Buttons[lastRow], button)
|
||||
|
||||
return keyboard
|
||||
}
|
||||
|
||||
// ToJSON returns the JSON encoding of MessagesKeyboard.
|
||||
func (keyboard MessagesKeyboard) ToJSON() string {
|
||||
b, _ := json.Marshal(keyboard)
|
||||
return string(b)
|
||||
}
|
||||
|
||||
// MessagesKeyboardButton struct.
|
||||
type MessagesKeyboardButton struct {
|
||||
Action MessagesKeyboardButtonAction `json:"action"`
|
||||
Color string `json:"color,omitempty"` // Button color
|
||||
}
|
||||
|
||||
// MessagesKeyboardButtonAction struct.
|
||||
type MessagesKeyboardButtonAction struct {
|
||||
AppID int `json:"app_id,omitempty"` // Fragment value in app link like vk.com/app{app_id}_-654321#hash
|
||||
Hash string `json:"hash,omitempty"` // Fragment value in app link like vk.com/app123456_-654321#{hash}
|
||||
Label string `json:"label,omitempty"` // Label for button
|
||||
OwnerID int `json:"owner_id,omitempty"` // Fragment value in app link like vk.com/app123456_{owner_id}#hash
|
||||
Payload string `json:"payload,omitempty"` // Additional data sent along with message for developer convenience
|
||||
Type string `json:"type"` // Button type
|
||||
Link string `json:"link,omitempty"` // Link URL
|
||||
}
|
||||
|
||||
// MessagesEventDataShowSnackbar struct.
|
||||
type MessagesEventDataShowSnackbar struct {
|
||||
Text string `json:"text,omitempty"`
|
||||
}
|
||||
|
||||
// MessagesEventDataOpenLink struct.
|
||||
type MessagesEventDataOpenLink struct {
|
||||
Link string `json:"link,omitempty"`
|
||||
}
|
||||
|
||||
// MessagesEventDataOpenApp struct.
|
||||
type MessagesEventDataOpenApp struct {
|
||||
AppID int `json:"app_id,omitempty"`
|
||||
OwnerID int `json:"owner_id,omitempty"`
|
||||
Hash string `json:"hash,omitempty"`
|
||||
}
|
||||
|
||||
// MessagesEventData struct.
|
||||
type MessagesEventData struct {
|
||||
Type string `json:"type"`
|
||||
MessagesEventDataShowSnackbar
|
||||
MessagesEventDataOpenLink
|
||||
MessagesEventDataOpenApp
|
||||
}
|
||||
|
||||
// NewMessagesEventDataShowSnackbar show disappearing message.
|
||||
//
|
||||
// Contains the field text - the text you want to print
|
||||
// (maximum 90 characters). Snackbar is shown for 10 seconds and automatically
|
||||
// hides, while the user has the ability to flick it off the screen.
|
||||
func NewMessagesEventDataShowSnackbar(text string) *MessagesEventData {
|
||||
return &MessagesEventData{
|
||||
Type: "show_snackbar",
|
||||
MessagesEventDataShowSnackbar: MessagesEventDataShowSnackbar{
|
||||
Text: text,
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
// NewMessagesEventDataOpenLink open the link. Click on the specified address.
|
||||
func NewMessagesEventDataOpenLink(link string) *MessagesEventData {
|
||||
return &MessagesEventData{
|
||||
Type: "open_link",
|
||||
MessagesEventDataOpenLink: MessagesEventDataOpenLink{
|
||||
Link: link,
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
// NewMessagesEventDataOpenApp open the link. Click on the specified address.
|
||||
func NewMessagesEventDataOpenApp(appID, ownerID int, hash string) *MessagesEventData {
|
||||
return &MessagesEventData{
|
||||
Type: "open_app",
|
||||
MessagesEventDataOpenApp: MessagesEventDataOpenApp{
|
||||
AppID: appID,
|
||||
OwnerID: ownerID,
|
||||
Hash: hash,
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
// ToJSON returns the JSON encoding of MessagesEventData.
|
||||
func (eventData MessagesEventData) ToJSON() string {
|
||||
b, _ := json.Marshal(eventData)
|
||||
return string(b)
|
||||
}
|
||||
|
||||
// MessagesTemplate struct.
|
||||
//
|
||||
// https://vk.com/dev/bot_docs_templates
|
||||
type MessagesTemplate struct {
|
||||
Type string `json:"type"`
|
||||
Elements []MessagesTemplateElement `json:"elements"`
|
||||
}
|
||||
|
||||
// ToJSON returns the JSON encoding of MessagesKeyboard.
|
||||
func (template MessagesTemplate) ToJSON() string {
|
||||
b, _ := json.Marshal(template)
|
||||
return string(b)
|
||||
}
|
||||
|
||||
// MessagesTemplateElement struct.
|
||||
type MessagesTemplateElement struct {
|
||||
MessagesTemplateElementCarousel
|
||||
}
|
||||
|
||||
// MessagesTemplateElementCarousel struct.
|
||||
type MessagesTemplateElementCarousel struct {
|
||||
Title string `json:"title"`
|
||||
Action MessagesTemplateElementCarouselAction `json:"action"`
|
||||
Description string `json:"description"`
|
||||
Photo PhotosPhoto `json:"photo"`
|
||||
Buttons []MessagesKeyboardButton `json:"buttons"`
|
||||
}
|
||||
|
||||
// MessagesTemplateElementCarouselAction struct.
|
||||
type MessagesTemplateElementCarouselAction struct {
|
||||
Type string `json:"type"`
|
||||
Link string `json:"link"`
|
||||
}
|
||||
|
||||
// MessageContentSourceMessage ...
|
||||
type MessageContentSourceMessage struct {
|
||||
OwnerID int `json:"owner_id,omitempty"`
|
||||
PeerID int `json:"peer_id,omitempty"`
|
||||
ConversationMessageID int `json:"conversation_message_id,omitempty"`
|
||||
}
|
||||
|
||||
// MessageContentSourceURL ...
|
||||
type MessageContentSourceURL struct {
|
||||
URL string `json:"url,omitempty"`
|
||||
}
|
||||
|
||||
// MessageContentSource struct.
|
||||
//
|
||||
// https://vk.com/dev/bots_docs_2
|
||||
type MessageContentSource struct {
|
||||
Type string `json:"type"`
|
||||
MessageContentSourceMessage // type message
|
||||
MessageContentSourceURL // type url
|
||||
|
||||
}
|
||||
|
||||
// NewMessageContentSourceMessage ...
|
||||
func NewMessageContentSourceMessage(ownerID, peerID, conversationMessageID int) *MessageContentSource {
|
||||
return &MessageContentSource{
|
||||
Type: "message",
|
||||
MessageContentSourceMessage: MessageContentSourceMessage{
|
||||
OwnerID: ownerID,
|
||||
PeerID: peerID,
|
||||
ConversationMessageID: conversationMessageID,
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
// NewMessageContentSourceURL ...
|
||||
func NewMessageContentSourceURL(u string) *MessageContentSource {
|
||||
return &MessageContentSource{
|
||||
Type: "url",
|
||||
MessageContentSourceURL: MessageContentSourceURL{
|
||||
URL: u,
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
// ToJSON returns the JSON encoding of MessageContentSource.
|
||||
func (contentSource MessageContentSource) ToJSON() string {
|
||||
b, _ := json.Marshal(contentSource)
|
||||
return string(b)
|
||||
}
|
||||
|
||||
// MessagesChat struct.
|
||||
type MessagesChat struct {
|
||||
AdminID int `json:"admin_id"` // Chat creator ID
|
||||
ID int `json:"id"` // Chat ID
|
||||
IsDefaultPhoto BaseBoolInt `json:"is_default_photo"`
|
||||
Photo100 string `json:"photo_100"` // URL of the preview image with 100 px in width
|
||||
Photo200 string `json:"photo_200"` // URL of the preview image with 200 px in width
|
||||
Photo50 string `json:"photo_50"` // URL of the preview image with 50 px in width
|
||||
Title string `json:"title"` // Chat title
|
||||
Type string `json:"type"` // Chat type
|
||||
Users []int `json:"users"`
|
||||
MembersCount int `json:"members_count"`
|
||||
}
|
||||
|
||||
// MessagesChatPreview struct.
|
||||
type MessagesChatPreview struct {
|
||||
AdminID int `json:"admin_id"`
|
||||
MembersCount int `json:"members_count"`
|
||||
Members []int `json:"members"`
|
||||
Title string `json:"title"`
|
||||
Photo MessagesChatSettingsPhoto `json:"photo"`
|
||||
LocalID int `json:"local_id"`
|
||||
Joined bool `json:"joined"`
|
||||
ChatSettings MessagesConversationChatSettings `json:"chat_settings"`
|
||||
}
|
||||
|
||||
// MessagesChatPushSettings struct.
|
||||
type MessagesChatPushSettings struct {
|
||||
DisabledUntil int `json:"disabled_until"` // Time until that notifications are disabled
|
||||
Sound BaseBoolInt `json:"sound"` // Information whether the sound is on
|
||||
}
|
||||
|
||||
// MessagesChatSettingsPhoto struct.
|
||||
type MessagesChatSettingsPhoto struct {
|
||||
Photo100 string `json:"photo_100"`
|
||||
Photo200 string `json:"photo_200"`
|
||||
Photo50 string `json:"photo_50"`
|
||||
IsDefaultPhoto BaseBoolInt `json:"is_default_photo"`
|
||||
}
|
||||
|
||||
// MessagesConversation struct.
|
||||
type MessagesConversation struct {
|
||||
CanWrite MessagesConversationCanWrite `json:"can_write"`
|
||||
ChatSettings MessagesConversationChatSettings `json:"chat_settings"`
|
||||
InRead int `json:"in_read"` // Last message user have read
|
||||
LastMessageID int `json:"last_message_id"` // ID of the last message in conversation
|
||||
Mentions []int `json:"mentions"` // IDs of messages with mentions
|
||||
MessageRequest string `json:"message_request"`
|
||||
|
||||
// Last outcoming message have been read by the opponent.
|
||||
OutRead int `json:"out_read"`
|
||||
Peer MessagesConversationPeer `json:"peer"`
|
||||
PushSettings MessagesConversationPushSettings `json:"push_settings"`
|
||||
Important BaseBoolInt `json:"important"`
|
||||
Unanswered BaseBoolInt `json:"unanswered"`
|
||||
IsMarkedUnread BaseBoolInt `json:"is_marked_unread"`
|
||||
UnreadCount int `json:"unread_count"` // Unread messages number
|
||||
CurrentKeyboard MessagesKeyboard `json:"current_keyboard"`
|
||||
SortID struct {
|
||||
MajorID int `json:"major_id"`
|
||||
MinorID int `json:"minor_id"`
|
||||
} `json:"sort_id"`
|
||||
}
|
||||
|
||||
// MessagesConversationCanWrite struct.
|
||||
type MessagesConversationCanWrite struct {
|
||||
Allowed BaseBoolInt `json:"allowed"`
|
||||
Reason int `json:"reason"`
|
||||
}
|
||||
|
||||
// MessagesConversationChatSettings struct.
|
||||
type MessagesConversationChatSettings struct {
|
||||
MembersCount int `json:"members_count"`
|
||||
Photo MessagesChatSettingsPhoto `json:"photo"`
|
||||
PinnedMessage MessagesPinnedMessage `json:"pinned_message"`
|
||||
State string `json:"state"`
|
||||
Title string `json:"title"`
|
||||
ActiveIDs []int `json:"active_ids"`
|
||||
ACL struct {
|
||||
CanInvite BaseBoolInt `json:"can_invite"`
|
||||
CanChangeInfo BaseBoolInt `json:"can_change_info"`
|
||||
CanChangePin BaseBoolInt `json:"can_change_pin"`
|
||||
CanPromoteUsers BaseBoolInt `json:"can_promote_users"`
|
||||
CanSeeInviteLink BaseBoolInt `json:"can_see_invite_link"`
|
||||
CanChangeInviteLink BaseBoolInt `json:"can_change_invite_link"`
|
||||
CanCopyChat BaseBoolInt `json:"can_copy_chat"`
|
||||
CanModerate BaseBoolInt `json:"can_moderate"`
|
||||
CanCall BaseBoolInt `json:"can_call"`
|
||||
CanUseMassMentions BaseBoolInt `json:"can_use_mass_mentions"`
|
||||
CanChangeServiceType BaseBoolInt `json:"can_change_service_type"`
|
||||
} `json:"acl"`
|
||||
IsGroupChannel BaseBoolInt `json:"is_group_channel"`
|
||||
IsDisappearing BaseBoolInt `json:"is_disappearing"`
|
||||
IsService BaseBoolInt `json:"is_service"`
|
||||
IsCreatedForCall BaseBoolInt `json:"is_created_for_call"`
|
||||
OwnerID int `json:"owner_id"`
|
||||
AdminIDs []int `json:"admin_ids"`
|
||||
Permissions MessagesChatPermissions `json:"permissions"`
|
||||
}
|
||||
|
||||
// MessagesChatPermission struct.
|
||||
type MessagesChatPermission string
|
||||
|
||||
// Possible values.
|
||||
const (
|
||||
OwnerChatPermission MessagesChatPermission = "owner"
|
||||
OwnerAndAdminsChatPermission MessagesChatPermission = "owner_and_admins"
|
||||
AllChatPermission MessagesChatPermission = "all"
|
||||
)
|
||||
|
||||
// MessagesChatPermissions struct.
|
||||
type MessagesChatPermissions struct {
|
||||
Invite MessagesChatPermission `json:"invite"`
|
||||
ChangeInfo MessagesChatPermission `json:"change_info"`
|
||||
ChangePin MessagesChatPermission `json:"change_pin"`
|
||||
UseMassMentions MessagesChatPermission `json:"use_mass_mentions"`
|
||||
SeeInviteLink MessagesChatPermission `json:"see_invite_link"`
|
||||
Call MessagesChatPermission `json:"call"`
|
||||
ChangeAdmins MessagesChatPermission `json:"change_admins"`
|
||||
}
|
||||
|
||||
// MessagesConversationPeer struct.
|
||||
type MessagesConversationPeer struct {
|
||||
ID int `json:"id"`
|
||||
LocalID int `json:"local_id"`
|
||||
Type string `json:"type"`
|
||||
}
|
||||
|
||||
// MessagesConversationPushSettings struct.
|
||||
type MessagesConversationPushSettings struct {
|
||||
DisabledUntil int `json:"disabled_until"`
|
||||
DisabledForever BaseBoolInt `json:"disabled_forever"`
|
||||
NoSound BaseBoolInt `json:"no_sound"`
|
||||
}
|
||||
|
||||
// MessagesConversationWithMessage struct.
|
||||
type MessagesConversationWithMessage struct {
|
||||
Conversation MessagesConversation `json:"conversation"`
|
||||
// BUG(VK): https://vk.com/bug229134
|
||||
LastMessage MessagesMessage `json:"last_message"`
|
||||
}
|
||||
|
||||
// MessagesDialog struct.
|
||||
type MessagesDialog struct {
|
||||
Important int `json:"important"`
|
||||
InRead int `json:"in_read"`
|
||||
Message MessagesMessage `json:"message"`
|
||||
OutRead int `json:"out_read"`
|
||||
Unanswered int `json:"unanswered"`
|
||||
Unread int `json:"unread"`
|
||||
}
|
||||
|
||||
// MessagesHistoryAttachment struct.
|
||||
type MessagesHistoryAttachment struct {
|
||||
Attachment MessagesHistoryMessageAttachment `json:"attachment"`
|
||||
MessageID int `json:"message_id"` // Message ID
|
||||
FromID int `json:"from_id"`
|
||||
}
|
||||
|
||||
// MessagesHistoryMessageAttachment struct.
|
||||
type MessagesHistoryMessageAttachment struct {
|
||||
Audio AudioAudio `json:"audio"`
|
||||
Doc DocsDoc `json:"doc"`
|
||||
Link BaseLink `json:"link"`
|
||||
Market BaseLink `json:"market"`
|
||||
Photo PhotosPhoto `json:"photo"`
|
||||
Share BaseLink `json:"share"`
|
||||
Type string `json:"type"`
|
||||
Video VideoVideo `json:"video"`
|
||||
Wall BaseLink `json:"wall"`
|
||||
}
|
||||
|
||||
// MessagesLastActivity struct.
|
||||
type MessagesLastActivity struct {
|
||||
Online BaseBoolInt `json:"online"` // Information whether user is online
|
||||
Time int `json:"time"` // Time when user was online in Unixtime
|
||||
}
|
||||
|
||||
// MessagesLongPollParams struct.
|
||||
type MessagesLongPollParams struct {
|
||||
Key string `json:"key"` // Key
|
||||
Pts int `json:"pts"` // Persistent timestamp
|
||||
Server string `json:"server"` // Server URL
|
||||
Ts int `json:"ts"` // Timestamp
|
||||
}
|
||||
|
||||
// MessagesMessageAction status.
|
||||
const (
|
||||
ChatPhotoUpdate = "chat_photo_update"
|
||||
ChatPhotoRemove = "chat_photo_remove"
|
||||
ChatCreate = "chat_create"
|
||||
ChatTitleUpdate = "chat_title_update"
|
||||
ChatInviteUser = "chat_invite_user"
|
||||
ChatKickUser = "chat_kick_user"
|
||||
ChatPinMessage = "chat_pin_message"
|
||||
ChatUnpinMessage = "chat_unpin_message"
|
||||
ChatInviteUserByLink = "chat_invite_user_by_link"
|
||||
AcceptedMessageRequest = "accepted_message_request"
|
||||
)
|
||||
|
||||
// MessagesMessageAction struct.
|
||||
type MessagesMessageAction struct {
|
||||
ConversationMessageID int `json:"conversation_message_id"` // Message ID
|
||||
|
||||
// Email address for chat_invite_user or chat_kick_user actions.
|
||||
Email string `json:"email"`
|
||||
MemberID int `json:"member_id"` // User or email peer ID
|
||||
Message string `json:"message"` // Message body of related message
|
||||
Photo MessagesMessageActionPhoto `json:"photo"`
|
||||
|
||||
// New chat title for chat_create and chat_title_update actions.
|
||||
Text string `json:"text"`
|
||||
Type string `json:"type"`
|
||||
}
|
||||
|
||||
// MessagesMessageActionPhoto struct.
|
||||
type MessagesMessageActionPhoto struct {
|
||||
Photo100 string `json:"photo_100"` // URL of the preview image with 100px in width
|
||||
Photo200 string `json:"photo_200"` // URL of the preview image with 200px in width
|
||||
Photo50 string `json:"photo_50"` // URL of the preview image with 50px in width
|
||||
}
|
||||
|
||||
// MessagesMessageAttachment struct.
|
||||
type MessagesMessageAttachment struct {
|
||||
Audio AudioAudio `json:"audio"`
|
||||
Doc DocsDoc `json:"doc"`
|
||||
Gift GiftsLayout `json:"gift"`
|
||||
Link BaseLink `json:"link"`
|
||||
Market MarketMarketItem `json:"market"`
|
||||
MarketMarketAlbum MarketMarketAlbum `json:"market_market_album"`
|
||||
Photo PhotosPhoto `json:"photo"`
|
||||
Sticker BaseSticker `json:"sticker"`
|
||||
Type string `json:"type"`
|
||||
Video VideoVideo `json:"video"`
|
||||
Wall WallWallpost `json:"wall"`
|
||||
WallReply WallWallComment `json:"wall_reply"`
|
||||
AudioMessage DocsDoc `json:"audio_message"`
|
||||
Graffiti DocsDoc `json:"graffiti"`
|
||||
Poll PollsPoll `json:"poll"`
|
||||
Call MessageCall `json:"call"`
|
||||
Story StoriesStory `json:"story"`
|
||||
Podcast PodcastsEpisode `json:"podcast"`
|
||||
}
|
||||
|
||||
// State in which call ended up.
|
||||
//
|
||||
// TODO: v3 type CallEndState.
|
||||
const (
|
||||
CallEndStateCanceledByInitiator = "canceled_by_initiator"
|
||||
CallEndStateCanceledByReceiver = "canceled_by_receiver"
|
||||
CallEndStateReached = "reached"
|
||||
)
|
||||
|
||||
// MessageCall struct.
|
||||
type MessageCall struct {
|
||||
InitiatorID int `json:"initiator_id"`
|
||||
ReceiverID int `json:"receiver_id"`
|
||||
State string `json:"state"`
|
||||
Time int `json:"time"`
|
||||
Duration int `json:"duration"`
|
||||
Video BaseBoolInt `json:"video"`
|
||||
}
|
||||
|
||||
// MessagesPinnedMessage struct.
|
||||
type MessagesPinnedMessage struct {
|
||||
Attachments []MessagesMessageAttachment `json:"attachments"`
|
||||
|
||||
// Unique auto-incremented number for all Messages with this peer.
|
||||
ConversationMessageID int `json:"conversation_message_id"`
|
||||
|
||||
// Date when the message has been sent in Unixtime.
|
||||
Date int `json:"date"`
|
||||
|
||||
// Message author's ID.
|
||||
FromID int `json:"from_id"`
|
||||
FwdMessages []*MessagesMessage `json:"fwd_Messages"`
|
||||
Geo BaseMessageGeo `json:"geo"`
|
||||
ID int `json:"id"` // Message ID
|
||||
PeerID int `json:"peer_id"` // Peer ID
|
||||
ReplyMessage *MessagesMessage `json:"reply_message"`
|
||||
Text string `json:"text"` // Message text
|
||||
}
|
||||
|
||||
// MessagesUserXtrInvitedBy struct.
|
||||
type MessagesUserXtrInvitedBy struct {
|
||||
}
|
||||
|
||||
// MessagesForward struct.
|
||||
type MessagesForward struct {
|
||||
// Message owner. It is worth passing it on if you want to forward messages
|
||||
// from the community to a dialog.
|
||||
OwnerID int `json:"owner_id,omitempty"`
|
||||
|
||||
// Identifier of the place from which the messages are to be sent.
|
||||
PeerID int `json:"peer_id,omitempty"`
|
||||
|
||||
// Messages can be passed to conversation_message_ids array:
|
||||
//
|
||||
// - that are in a personal dialog with the bot;
|
||||
//
|
||||
// - which are outbound messages from the bot;
|
||||
//
|
||||
// - written after the bot has entered the conversation.
|
||||
ConversationMessageIDs []int `json:"conversation_message_ids,omitempty"`
|
||||
MessageIDs []int `json:"message_ids,omitempty"`
|
||||
|
||||
// Reply to messages. It is worth passing if you want to reply to messages
|
||||
// in the chat room where the messages are. In this case there should be
|
||||
// only one element in the conversation_message_ids/message_ids.
|
||||
IsReply bool `json:"is_reply,omitempty"`
|
||||
}
|
||||
|
||||
// ToJSON returns the JSON encoding of MessagesForward.
|
||||
func (forward MessagesForward) ToJSON() string {
|
||||
b, _ := json.Marshal(forward)
|
||||
return string(b)
|
||||
}
|
@ -0,0 +1,187 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// NewsfeedEventActivity struct.
|
||||
type NewsfeedEventActivity struct {
|
||||
Address string `json:"address"` // address of event
|
||||
ButtonText string `json:"button_text"` // text of attach
|
||||
Friends []int `json:"friends"` // array of friends ids
|
||||
MemberStatus int `json:"member_status"` // Current user's member status
|
||||
Text string `json:"text"` // text of attach
|
||||
Time int `json:"time"` // event start time
|
||||
}
|
||||
|
||||
// NewsfeedItemAudio struct.
|
||||
type NewsfeedItemAudio struct {
|
||||
Audio NewsfeedItemAudioAudio `json:"audio"`
|
||||
}
|
||||
|
||||
// NewsfeedItemAudioAudio struct.
|
||||
type NewsfeedItemAudioAudio struct {
|
||||
Count int `json:"count"` // Audios number
|
||||
Items []AudioAudio `json:"items"`
|
||||
}
|
||||
|
||||
// NewsfeedItemDigest struct.
|
||||
type NewsfeedItemDigest struct {
|
||||
ButtonText string `json:"button_text"`
|
||||
FeedID string `json:"feed_id"` // id of feed in digest
|
||||
Items []WallWallpost `json:"items"`
|
||||
MainPostIDs []string `json:"main_post_ids"`
|
||||
Template string `json:"template"` // type of digest
|
||||
Title string `json:"title"`
|
||||
TrackCode string `json:"track_code"`
|
||||
// Type string `json:"type"`
|
||||
}
|
||||
|
||||
// NewsfeedItemFriend struct.
|
||||
type NewsfeedItemFriend struct {
|
||||
Friends NewsfeedItemFriendFriends `json:"friends"`
|
||||
}
|
||||
|
||||
// NewsfeedItemFriendFriends struct.
|
||||
type NewsfeedItemFriendFriends struct {
|
||||
Count int `json:"count"` // Number of friends has been added
|
||||
Items []BaseUserID `json:"items"`
|
||||
}
|
||||
|
||||
// NewsfeedItemNote struct.
|
||||
type NewsfeedItemNote struct {
|
||||
Notes NewsfeedItemNoteNotes `json:"notes"`
|
||||
}
|
||||
|
||||
// NewsfeedItemNoteNotes struct.
|
||||
type NewsfeedItemNoteNotes struct {
|
||||
Count int `json:"count"` // Notes number
|
||||
Items []NewsfeedNewsfeedNote `json:"items"`
|
||||
}
|
||||
|
||||
// NewsfeedItemPhoto struct.
|
||||
type NewsfeedItemPhoto struct {
|
||||
Photos NewsfeedItemPhotoPhotos `json:"photos"`
|
||||
}
|
||||
|
||||
// NewsfeedItemPhotoPhotos struct.
|
||||
type NewsfeedItemPhotoPhotos struct {
|
||||
Count int `json:"count"` // Photos number
|
||||
Items []PhotosPhotoFull `json:"items"`
|
||||
}
|
||||
|
||||
// NewsfeedItemPhotoTag struct.
|
||||
type NewsfeedItemPhotoTag struct {
|
||||
PhotoTags NewsfeedItemPhotoTagPhotoTags `json:"photo_tags"`
|
||||
}
|
||||
|
||||
// NewsfeedItemPhotoTagPhotoTags struct.
|
||||
type NewsfeedItemPhotoTagPhotoTags struct {
|
||||
Count int `json:"count"` // Tags number
|
||||
Items []PhotosPhotoFull `json:"items"`
|
||||
}
|
||||
|
||||
// NewsfeedItemStoriesBlock struct.
|
||||
type NewsfeedItemStoriesBlock struct {
|
||||
BlockType string `json:"block_type"`
|
||||
Stories []StoriesStory `json:"stories"`
|
||||
// Title string `json:"title"`
|
||||
// TrackCode string `json:"track_code"`
|
||||
// Type string `json:"type"`
|
||||
}
|
||||
|
||||
// NewsfeedItemTopic struct.
|
||||
type NewsfeedItemTopic struct {
|
||||
// Comments BaseCommentsInfo `json:"comments"`
|
||||
// Likes BaseLikesInfo `json:"likes"`
|
||||
// Text string `json:"text"` // Post text
|
||||
}
|
||||
|
||||
// NewsfeedItemVideo struct.
|
||||
type NewsfeedItemVideo struct {
|
||||
Video NewsfeedItemVideoVideo `json:"video"`
|
||||
}
|
||||
|
||||
// NewsfeedItemVideoVideo struct.
|
||||
type NewsfeedItemVideoVideo struct {
|
||||
Count int `json:"count"` // Tags number
|
||||
Items []VideoVideo `json:"items"`
|
||||
}
|
||||
|
||||
// NewsfeedItemWallpost struct.
|
||||
type NewsfeedItemWallpost struct {
|
||||
Activity NewsfeedEventActivity `json:"activity"`
|
||||
Attachments []WallWallpostAttachment `json:"attachments"`
|
||||
Comments BaseCommentsInfo `json:"comments"`
|
||||
FromID int `json:"from_id"`
|
||||
CopyHistory []WallWallpost `json:"copy_history"`
|
||||
Geo BaseGeo `json:"geo"`
|
||||
Likes BaseLikesInfo `json:"likes"`
|
||||
PostSource WallPostSource `json:"post_source"`
|
||||
PostType string `json:"post_type"`
|
||||
Reposts BaseRepostsInfo `json:"reposts"`
|
||||
MarkedAsAds int `json:"marked_as_ads,omitempty"`
|
||||
Views interface{} `json:"views,omitempty"` // BUG: Views int or wallViews
|
||||
IsFavorite BaseBoolInt `json:"is_favorite,omitempty"`
|
||||
CanDelete BaseBoolInt `json:"can_delete"`
|
||||
CanArchive BaseBoolInt `json:"can_archive"`
|
||||
IsArchived BaseBoolInt `json:"is_archived"`
|
||||
SignerID int `json:"signer_id,omitempty"`
|
||||
Text string `json:"text"` // Post text
|
||||
Copyright WallPostCopyright `json:"copyright"`
|
||||
CategoryAction NewsfeedCategoryAction `json:"category_action"`
|
||||
}
|
||||
|
||||
// NewsfeedCategoryAction struct.
|
||||
type NewsfeedCategoryAction struct {
|
||||
Action struct {
|
||||
Target string `json:"target"`
|
||||
Type string `json:"type"`
|
||||
URL string `json:"url"`
|
||||
} `json:"action"`
|
||||
Name string `json:"name"`
|
||||
}
|
||||
|
||||
// NewsfeedList struct.
|
||||
type NewsfeedList struct {
|
||||
ID int `json:"id"` // List ID
|
||||
Title string `json:"title"` // List title
|
||||
}
|
||||
|
||||
// NewsfeedItemMarket struct.
|
||||
type NewsfeedItemMarket struct {
|
||||
MarketMarketItem
|
||||
}
|
||||
|
||||
// NewsfeedNewsfeedItem struct.
|
||||
type NewsfeedNewsfeedItem struct {
|
||||
Type string `json:"type"`
|
||||
SourceID int `json:"source_id"`
|
||||
Date int `json:"date"`
|
||||
TopicID int `json:"topic_id"`
|
||||
|
||||
PostID int `json:"post_id,omitempty"`
|
||||
|
||||
NewsfeedItemWallpost
|
||||
NewsfeedItemPhoto
|
||||
NewsfeedItemPhotoTag
|
||||
NewsfeedItemFriend
|
||||
NewsfeedItemNote
|
||||
NewsfeedItemAudio
|
||||
NewsfeedItemTopic
|
||||
NewsfeedItemVideo
|
||||
NewsfeedItemDigest
|
||||
NewsfeedItemStoriesBlock
|
||||
NewsfeedItemMarket
|
||||
|
||||
CreatedBy int `json:"created_by,omitempty"`
|
||||
CanEdit BaseBoolInt `json:"can_edit,omitempty"`
|
||||
CanDelete BaseBoolInt `json:"can_delete,omitempty"`
|
||||
CanDoubtCategory BaseBoolInt `json:"can_doubt_category"`
|
||||
CanSetCategory BaseBoolInt `json:"can_set_category"`
|
||||
// TODO: Need more fields
|
||||
}
|
||||
|
||||
// NewsfeedNewsfeedNote struct.
|
||||
type NewsfeedNewsfeedNote struct {
|
||||
Comments int `json:"comments"` // Comments Number
|
||||
ID int `json:"id"` // Note ID
|
||||
OwnerID int `json:"owner_id"` // integer
|
||||
Title string `json:"title"` // Note title
|
||||
}
|
@ -0,0 +1,37 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// NotesNote struct.
|
||||
type NotesNote struct {
|
||||
CanComment BaseBoolInt `json:"can_comment"` // Information whether current user can comment the note
|
||||
Comments int `json:"comments"` // Comments number
|
||||
Date int `json:"date"` // Date when the note has been created in Unixtime
|
||||
ID int `json:"id"` // Note ID
|
||||
OwnerID int `json:"owner_id"` // Note owner's ID
|
||||
Text string `json:"text"` // Note text
|
||||
TextWiki string `json:"text_wiki"` // Note text in wiki format
|
||||
Title string `json:"title"` // Note title
|
||||
ViewURL string `json:"view_url"` // URL of the page with note preview
|
||||
ReadComments int `json:"read_comments"`
|
||||
PrivacyView []interface{} `json:"privacy_view"` // NOTE: old type privacy
|
||||
PrivacyComment []interface{} `json:"privacy_comment"` // NOTE: old type privacy
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (note NotesNote) ToAttachment() string {
|
||||
return fmt.Sprintf("note%d_%d", note.OwnerID, note.ID)
|
||||
}
|
||||
|
||||
// NotesNoteComment struct.
|
||||
type NotesNoteComment struct {
|
||||
Date int `json:"date"` // Date when the comment has been added in Unixtime
|
||||
ID int `json:"id"` // Comment ID
|
||||
Message string `json:"message"` // Comment text
|
||||
NID int `json:"nid"` // Note ID
|
||||
OID int `json:"oid"` // Note ID
|
||||
ReplyTo int `json:"reply_to"` // ID of replied comment
|
||||
UID int `json:"uid"` // Comment author's ID
|
||||
}
|
@ -0,0 +1,42 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
import "encoding/json"
|
||||
|
||||
// NotificationsFeedback struct.
|
||||
type NotificationsFeedback struct {
|
||||
Attachments []WallWallpostAttachment `json:"attachments"`
|
||||
FromID int `json:"from_id"` // Reply author's ID
|
||||
Geo BaseGeo `json:"geo"`
|
||||
ID int `json:"id"` // Item ID
|
||||
Likes BaseLikesInfo `json:"likes"`
|
||||
Text string `json:"text"` // Reply text
|
||||
ToID int `json:"to_id"` // Wall owner's ID
|
||||
}
|
||||
|
||||
// NotificationsNotification struct.
|
||||
type NotificationsNotification struct {
|
||||
Date int `json:"date"` // Date when the event has been occurred
|
||||
Feedback json.RawMessage `json:"feedback"`
|
||||
Parent json.RawMessage `json:"parent"`
|
||||
Reply NotificationsReply `json:"reply"`
|
||||
Type string `json:"type"` // Notification type
|
||||
}
|
||||
|
||||
// NotificationsNotificationsComment struct.
|
||||
type NotificationsNotificationsComment struct {
|
||||
Date int `json:"date"` // Date when the comment has been added in Unixtime
|
||||
ID int `json:"id"` // Comment ID
|
||||
OwnerID int `json:"owner_id"` // Author ID
|
||||
Photo PhotosPhoto `json:"photo"`
|
||||
Post WallWallpost `json:"post"`
|
||||
Text string `json:"text"` // Comment text
|
||||
Topic BoardTopic `json:"topic"`
|
||||
Video VideoVideo `json:"video"`
|
||||
}
|
||||
|
||||
// NotificationsReply struct.
|
||||
type NotificationsReply struct {
|
||||
Date string `json:"date"` // Date when the reply has been created in Unixtime
|
||||
ID int `json:"id"` // Reply ID
|
||||
Text string `json:"text"` // Reply text
|
||||
}
|
@ -0,0 +1,45 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// OrdersAmount struct.
|
||||
type OrdersAmount struct {
|
||||
Amounts []OrdersAmountItem `json:"amounts"`
|
||||
Currency string `json:"currency"` // Currency name
|
||||
}
|
||||
|
||||
// OrdersAmountItem struct.
|
||||
type OrdersAmountItem struct {
|
||||
Amount int `json:"amount"` // Votes amount in user's currency
|
||||
Description string `json:"description"` // Amount description
|
||||
Votes string `json:"votes"` // Votes number
|
||||
}
|
||||
|
||||
// OrdersOrder struct.
|
||||
type OrdersOrder struct {
|
||||
Amount int `json:"amount"` // Amount
|
||||
AppOrderID int `json:"app_order_id"` // App order ID
|
||||
CancelTransactionID int `json:"cancel_transaction_id"` // Cancel transaction ID
|
||||
Date int `json:"date"` // Date of creation in Unixtime
|
||||
ID int `json:"id"` // Order ID
|
||||
Item string `json:"item"` // Order item
|
||||
ReceiverID int `json:"receiver_id"` // Receiver ID
|
||||
Status string `json:"status"` // Order status
|
||||
TransactionID int `json:"transaction_id"` // Transaction ID
|
||||
UserID int `json:"user_id"` // User ID
|
||||
}
|
||||
|
||||
// OrdersSubscription struct.
|
||||
type OrdersSubscription struct {
|
||||
CancelReason string `json:"cancel_reason"` // Cancel reason
|
||||
CreateTime int `json:"create_time"` // Date of creation in Unixtime
|
||||
ID int `json:"id"` // Subscription ID
|
||||
ItemID string `json:"item_id"` // Subscription order item
|
||||
NextBillTime int `json:"next_bill_time"` // Date of next bill in Unixtime
|
||||
Period int `json:"period"` // Subscription period
|
||||
PeriodStartTime int `json:"period_start_time"` // Date of last period start in Unixtime
|
||||
Price int `json:"price"` // Subscription price
|
||||
Status string `json:"status"` // Subscription status
|
||||
PendingCancel BaseBoolInt `json:"pending_cancel"` // Pending cancel state
|
||||
TestMode BaseBoolInt `json:"test_mode"` // Is test subscription
|
||||
TrialExpireTime int `json:"trial_expire_time"` // Date of trial expire in Unixtime
|
||||
UpdateTime int `json:"update_time"` // Date of last change in Unixtime
|
||||
}
|
@ -0,0 +1,85 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// Pages privacy settings.
|
||||
const (
|
||||
PagesPrivacyCommunityManagers = iota // community managers only
|
||||
PagesPrivacyCommunityMembers // community members only
|
||||
PagesPrivacyEveryone // everyone
|
||||
)
|
||||
|
||||
// PagesWikipage struct.
|
||||
type PagesWikipage struct {
|
||||
CreatorID int `json:"creator_id"` // Page creator ID
|
||||
CreatorName int `json:"creator_name"` // Page creator name
|
||||
EditorID int `json:"editor_id"` // Last editor ID
|
||||
EditorName string `json:"editor_name"` // Last editor name
|
||||
GroupID int `json:"group_id"` // Community ID
|
||||
ID int `json:"id"` // Page ID
|
||||
Title string `json:"title"` // Page title
|
||||
Views int `json:"views"` // Views number
|
||||
WhoCanEdit int `json:"who_can_edit"` // Edit settings of the page
|
||||
WhoCanView int `json:"who_can_view"` // View settings of the page
|
||||
}
|
||||
|
||||
// PagesWikipageFull struct.
|
||||
type PagesWikipageFull struct {
|
||||
// Date when the page has been created in Unixtime.
|
||||
Created int `json:"created"`
|
||||
|
||||
// Page creator ID.
|
||||
CreatorID int `json:"creator_id"`
|
||||
|
||||
// Information whether current user can edit the page.
|
||||
CurrentUserCanEdit BaseBoolInt `json:"current_user_can_edit"`
|
||||
|
||||
// Information whether current user can edit the page access settings.
|
||||
CurrentUserCanEditAccess BaseBoolInt `json:"current_user_can_edit_access"`
|
||||
|
||||
// Date when the page has been edited in Unixtime.
|
||||
Edited int `json:"edited"`
|
||||
|
||||
// Last editor ID.
|
||||
EditorID int `json:"editor_id"`
|
||||
|
||||
// Page ID.
|
||||
PageID int `json:"page_id"`
|
||||
|
||||
// Community ID.
|
||||
GroupID int `json:"group_id"`
|
||||
|
||||
// Page content, HTML.
|
||||
HTML string `json:"html"`
|
||||
|
||||
// Page ID.
|
||||
ID int `json:"id"`
|
||||
|
||||
// Page content, wiki.
|
||||
Source string `json:"source"`
|
||||
|
||||
// Page title.
|
||||
Title string `json:"title"`
|
||||
|
||||
// URL of the page preview.
|
||||
ViewURL string `json:"view_url"`
|
||||
|
||||
// Views number.
|
||||
Views int `json:"views"`
|
||||
|
||||
// Edit settings of the page.
|
||||
WhoCanEdit int `json:"who_can_edit"`
|
||||
|
||||
// View settings of the page.
|
||||
WhoCanView int `json:"who_can_view"`
|
||||
VersionCreated int `json:"version_created"`
|
||||
}
|
||||
|
||||
// PagesWikipageHistory struct.
|
||||
//
|
||||
// BUG(VK): https://vk.com/dev/pages.getHistory edited and date.
|
||||
type PagesWikipageHistory struct {
|
||||
Date int `json:"date"` // Date when the page has been edited in Unixtime
|
||||
EditorID int `json:"editor_id"` // Last editor ID
|
||||
EditorName string `json:"editor_name"` // Last editor name
|
||||
ID int `json:"id"` // Version ID
|
||||
Length int `json:"length"` // Page size in bytes
|
||||
}
|
@ -0,0 +1,339 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// PhotosPhoto struct.
|
||||
type PhotosPhoto struct {
|
||||
AccessKey string `json:"access_key"` // Access key for the photo
|
||||
AlbumID int `json:"album_id"` // Album ID
|
||||
Date int `json:"date"` // Date when uploaded
|
||||
Height int `json:"height"` // Original photo height
|
||||
ID int `json:"id"` // Photo ID
|
||||
Images []PhotosImage `json:"images"`
|
||||
Lat float64 `json:"lat"` // Latitude
|
||||
Long float64 `json:"long"` // Longitude
|
||||
OwnerID int `json:"owner_id"` // Photo owner's ID
|
||||
PostID int `json:"post_id"` // Post ID
|
||||
Text string `json:"text"` // Photo caption
|
||||
UserID int `json:"user_id"` // ID of the user who have uploaded the photo
|
||||
Width int `json:"width"` // Original photo width
|
||||
CanUpload BaseBoolInt `json:"can_upload"`
|
||||
CommentsDisabled BaseBoolInt `json:"comments_disabled"`
|
||||
ThumbIsLast BaseBoolInt `json:"thumb_is_last"`
|
||||
UploadByAdminsOnly BaseBoolInt `json:"upload_by_admins_only"`
|
||||
HasTags BaseBoolInt `json:"has_tags"`
|
||||
Created int `json:"created"`
|
||||
Description string `json:"description"`
|
||||
PrivacyComment []string `json:"privacy_comment"`
|
||||
PrivacyView []string `json:"privacy_view"`
|
||||
Size int `json:"size"`
|
||||
Sizes []PhotosPhotoSizes `json:"sizes"`
|
||||
ThumbID int `json:"thumb_id"`
|
||||
ThumbSrc string `json:"thumb_src"`
|
||||
Title string `json:"title"`
|
||||
Updated int `json:"updated"`
|
||||
Color string `json:"color"`
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (photo PhotosPhoto) ToAttachment() string {
|
||||
return fmt.Sprintf("photo%d_%d", photo.OwnerID, photo.ID)
|
||||
}
|
||||
|
||||
// MaxSize return the largest PhotosPhotoSizes.
|
||||
func (photo PhotosPhoto) MaxSize() (maxPhotoSize PhotosPhotoSizes) {
|
||||
var max float64
|
||||
|
||||
for _, photoSize := range photo.Sizes {
|
||||
size := photoSize.Height * photoSize.Width
|
||||
if size > max {
|
||||
max = size
|
||||
maxPhotoSize = photoSize
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MinSize return the smallest PhotosPhotoSizes.
|
||||
func (photo PhotosPhoto) MinSize() (minPhotoSize PhotosPhotoSizes) {
|
||||
var min float64
|
||||
|
||||
for _, photoSize := range photo.Sizes {
|
||||
size := photoSize.Height * photoSize.Width
|
||||
if size < min || min == 0 {
|
||||
min = size
|
||||
minPhotoSize = photoSize
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosCommentXtrPid struct.
|
||||
type PhotosCommentXtrPid struct {
|
||||
Attachments []WallCommentAttachment `json:"attachments"`
|
||||
Date int `json:"date"` // Date when the comment has been added in Unixtime
|
||||
FromID int `json:"from_id"` // Author ID
|
||||
ID int `json:"id"` // Comment ID
|
||||
Likes BaseLikesInfo `json:"likes"`
|
||||
ParentsStack []int `json:"parents_stack"`
|
||||
Pid int `json:"pid"` // Photo ID
|
||||
ReplyToComment int `json:"reply_to_comment"` // Replied comment ID
|
||||
ReplyToUser int `json:"reply_to_user"` // Replied user ID
|
||||
Text string `json:"text"` // Comment text
|
||||
Thread WallWallCommentThread `json:"thread"`
|
||||
}
|
||||
|
||||
// PhotosImage struct.
|
||||
type PhotosImage struct {
|
||||
BaseImage
|
||||
Type string `json:"type"`
|
||||
}
|
||||
|
||||
// PhotosChatUploadResponse struct.
|
||||
type PhotosChatUploadResponse struct {
|
||||
Response string `json:"response"` // Uploaded photo data
|
||||
}
|
||||
|
||||
// PhotosMarketAlbumUploadResponse struct.
|
||||
type PhotosMarketAlbumUploadResponse struct {
|
||||
GID int `json:"gid"` // Community ID
|
||||
Hash string `json:"hash"` // Uploading hash
|
||||
Photo string `json:"photo"` // Uploaded photo data
|
||||
Server int `json:"server"` // Upload server number
|
||||
}
|
||||
|
||||
// PhotosMarketUploadResponse struct.
|
||||
type PhotosMarketUploadResponse struct {
|
||||
CropData string `json:"crop_data"` // Crop data
|
||||
CropHash string `json:"crop_hash"` // Crop hash
|
||||
GroupID int `json:"group_id"` // Community ID
|
||||
Hash string `json:"hash"` // Uploading hash
|
||||
Photo string `json:"photo"` // Uploaded photo data
|
||||
Server int `json:"server"` // Upload server number
|
||||
}
|
||||
|
||||
// PhotosMessageUploadResponse struct.
|
||||
type PhotosMessageUploadResponse struct {
|
||||
Hash string `json:"hash"` // Uploading hash
|
||||
Photo string `json:"photo"` // Uploaded photo data
|
||||
Server int `json:"server"` // Upload server number
|
||||
}
|
||||
|
||||
// PhotosOwnerUploadResponse struct.
|
||||
type PhotosOwnerUploadResponse struct {
|
||||
Hash string `json:"hash"` // Uploading hash
|
||||
Photo string `json:"photo"` // Uploaded photo data
|
||||
Server int `json:"server"` // Upload server number
|
||||
}
|
||||
|
||||
// PhotosPhotoAlbum struct.
|
||||
type PhotosPhotoAlbum struct {
|
||||
Created int `json:"created"` // Date when the album has been created in Unixtime
|
||||
Description string `json:"description"` // Photo album description
|
||||
ID string `json:"id"` // BUG(VK): Photo album ID
|
||||
OwnerID int `json:"owner_id"` // Album owner's ID
|
||||
Size int `json:"size"` // Photos number
|
||||
Thumb PhotosPhoto `json:"thumb"`
|
||||
Title string `json:"title"` // Photo album title
|
||||
Updated int `json:"updated"` // Date when the album has been updated last time in Unixtime
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (album PhotosPhotoAlbum) ToAttachment() string {
|
||||
return fmt.Sprintf("album%d_%s", album.OwnerID, album.ID)
|
||||
}
|
||||
|
||||
// PhotosPhotoAlbumFull struct.
|
||||
type PhotosPhotoAlbumFull struct {
|
||||
// Information whether current user can upload photo to the album.
|
||||
CanUpload BaseBoolInt `json:"can_upload"`
|
||||
CommentsDisabled BaseBoolInt `json:"comments_disabled"` // Information whether album comments are disabled
|
||||
Created int `json:"created"` // Date when the album has been created in Unixtime
|
||||
Description string `json:"description"` // Photo album description
|
||||
ID int `json:"id"` // Photo album ID
|
||||
OwnerID int `json:"owner_id"` // Album owner's ID
|
||||
Size int `json:"size"` // Photos number
|
||||
PrivacyComment Privacy `json:"privacy_comment"`
|
||||
PrivacyView Privacy `json:"privacy_view"`
|
||||
Sizes []PhotosPhotoSizes `json:"sizes"`
|
||||
ThumbID int `json:"thumb_id"` // Thumb photo ID
|
||||
|
||||
// Information whether the album thumb is last photo.
|
||||
ThumbIsLast int `json:"thumb_is_last"`
|
||||
ThumbSrc string `json:"thumb_src"` // URL of the thumb image
|
||||
Title string `json:"title"` // Photo album title
|
||||
|
||||
// Date when the album has been updated last time in Unixtime.
|
||||
Updated int `json:"updated"`
|
||||
|
||||
// Information whether only community administrators can upload photos.
|
||||
UploadByAdminsOnly int `json:"upload_by_admins_only"`
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (album PhotosPhotoAlbumFull) ToAttachment() string {
|
||||
return fmt.Sprintf("album%d_%d", album.OwnerID, album.ID)
|
||||
}
|
||||
|
||||
// MaxSize return the largest PhotosPhotoSizes.
|
||||
func (album PhotosPhotoAlbumFull) MaxSize() (maxPhotoSize PhotosPhotoSizes) {
|
||||
var max float64
|
||||
|
||||
for _, photoSize := range album.Sizes {
|
||||
size := photoSize.Height * photoSize.Width
|
||||
if size > max {
|
||||
max = size
|
||||
maxPhotoSize = photoSize
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MinSize return the smallest PhotosPhotoSizes.
|
||||
func (album PhotosPhotoAlbumFull) MinSize() (minPhotoSize PhotosPhotoSizes) {
|
||||
var min float64
|
||||
|
||||
for _, photoSize := range album.Sizes {
|
||||
size := photoSize.Height * photoSize.Width
|
||||
if size < min || min == 0 {
|
||||
min = size
|
||||
minPhotoSize = photoSize
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosPhotoFull struct.
|
||||
type PhotosPhotoFull struct {
|
||||
AccessKey string `json:"access_key"` // Access key for the photo
|
||||
AlbumID int `json:"album_id"` // Album ID
|
||||
CanComment BaseBoolInt `json:"can_comment"` // Information whether current user can comment the photo
|
||||
CanRepost BaseBoolInt `json:"can_repost"` // Information whether current user can repost the photo
|
||||
HasTags BaseBoolInt `json:"has_tags"`
|
||||
Comments BaseObjectCount `json:"comments"`
|
||||
Date int `json:"date"` // Date when uploaded
|
||||
Height int `json:"height"` // Original photo height
|
||||
ID int `json:"id"` // Photo ID
|
||||
Images []PhotosImage `json:"images"`
|
||||
Lat float64 `json:"lat"` // Latitude
|
||||
Likes BaseLikes `json:"likes"`
|
||||
Long float64 `json:"long"` // Longitude
|
||||
OwnerID int `json:"owner_id"` // Photo owner's ID
|
||||
PostID int `json:"post_id"` // Post ID
|
||||
Reposts BaseRepostsInfo `json:"reposts"`
|
||||
Tags BaseObjectCount `json:"tags"`
|
||||
Text string `json:"text"` // Photo caption
|
||||
UserID int `json:"user_id"` // ID of the user who have uploaded the photo
|
||||
Width int `json:"width"` // Original photo width
|
||||
Hidden int `json:"hidden"` // Returns if the photo is hidden above the wall
|
||||
Photo75 string `json:"photo_75"` // URL of image with 75 px width
|
||||
Photo130 string `json:"photo_130"` // URL of image with 130 px width
|
||||
Photo604 string `json:"photo_604"` // URL of image with 604 px width
|
||||
Photo807 string `json:"photo_807"` // URL of image with 807 px width
|
||||
Photo1280 string `json:"photo_1280"` // URL of image with 1280 px width
|
||||
Photo2560 string `json:"photo_2560"` // URL of image with 2560 px width
|
||||
Sizes []PhotosPhotoSizes `json:"sizes"`
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (photo PhotosPhotoFull) ToAttachment() string {
|
||||
return fmt.Sprintf("photo%d_%d", photo.OwnerID, photo.ID)
|
||||
}
|
||||
|
||||
// MaxSize return the largest PhotosPhotoSizes.
|
||||
func (photo PhotosPhotoFull) MaxSize() (maxPhotoSize PhotosPhotoSizes) {
|
||||
var max float64
|
||||
|
||||
for _, photoSize := range photo.Sizes {
|
||||
size := photoSize.Height * photoSize.Width
|
||||
if size > max {
|
||||
max = size
|
||||
maxPhotoSize = photoSize
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// MinSize return the smallest PhotosPhotoSizes.
|
||||
func (photo PhotosPhotoFull) MinSize() (minPhotoSize PhotosPhotoSizes) {
|
||||
var min float64
|
||||
|
||||
for _, photoSize := range photo.Sizes {
|
||||
size := photoSize.Height * photoSize.Width
|
||||
if size < min || min == 0 {
|
||||
min = size
|
||||
minPhotoSize = photoSize
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// PhotosPhotoFullXtrRealOffset struct.
|
||||
type PhotosPhotoFullXtrRealOffset struct {
|
||||
PhotosPhotoFull
|
||||
RealOffset int `json:"real_offset"` // Real position of the photo
|
||||
}
|
||||
|
||||
// PhotosPhotoSizes struct.
|
||||
type PhotosPhotoSizes struct {
|
||||
// BUG(VK): json: cannot unmarshal number 180.000000 into Go struct field PhotosPhotoSizes.height of type int
|
||||
BaseImage
|
||||
}
|
||||
|
||||
// PhotosPhotoTag struct.
|
||||
type PhotosPhotoTag struct {
|
||||
Date int `json:"date"` // Date when tag has been added in Unixtime
|
||||
ID int `json:"id"` // Tag ID
|
||||
PlacerID int `json:"placer_id"` // ID of the tag creator
|
||||
TaggedName string `json:"tagged_name"` // Tag description
|
||||
Description string `json:"description"` // Tagged description.
|
||||
UserID int `json:"user_id"` // Tagged user ID
|
||||
Viewed BaseBoolInt `json:"viewed"` // Information whether the tag is reviewed
|
||||
X float64 `json:"x"` // Coordinate X of the left upper corner
|
||||
X2 float64 `json:"x2"` // Coordinate X of the right lower corner
|
||||
Y float64 `json:"y"` // Coordinate Y of the left upper corner
|
||||
Y2 float64 `json:"y2"` // Coordinate Y of the right lower corner
|
||||
}
|
||||
|
||||
// PhotosPhotoUpload struct.
|
||||
type PhotosPhotoUpload struct {
|
||||
AlbumID int `json:"album_id"` // Album ID
|
||||
UploadURL string `json:"upload_url"` // URL to upload photo
|
||||
UserID int `json:"user_id"` // User ID
|
||||
}
|
||||
|
||||
// PhotosPhotoUploadResponse struct.
|
||||
type PhotosPhotoUploadResponse struct {
|
||||
AID int `json:"aid"` // Album ID
|
||||
Hash string `json:"hash"` // Uploading hash
|
||||
PhotosList string `json:"photos_list"` // Uploaded photos data
|
||||
Server int `json:"server"` // Upload server number
|
||||
}
|
||||
|
||||
// PhotosPhotoXtrRealOffset struct.
|
||||
type PhotosPhotoXtrRealOffset struct {
|
||||
PhotosPhoto
|
||||
RealOffset int `json:"real_offset"` // Real position of the photo
|
||||
}
|
||||
|
||||
// PhotosPhotoXtrTagInfo struct.
|
||||
type PhotosPhotoXtrTagInfo struct {
|
||||
PhotosPhoto
|
||||
TagCreated int `json:"tag_created"` // Date when tag has been added in Unixtime
|
||||
TagID int `json:"tag_id"` // Tag ID
|
||||
}
|
||||
|
||||
// PhotosWallUploadResponse struct.
|
||||
type PhotosWallUploadResponse struct {
|
||||
Hash string `json:"hash"` // Uploading hash
|
||||
Photo string `json:"photo"` // Uploaded photo data
|
||||
Server int `json:"server"` // Upload server number
|
||||
}
|
@ -0,0 +1,45 @@
|
||||
package object
|
||||
|
||||
// PodcastsItem struct.
|
||||
type PodcastsItem struct {
|
||||
OwnerID int `json:"owner_id"`
|
||||
}
|
||||
|
||||
// PodcastsCategory struct.
|
||||
type PodcastsCategory struct {
|
||||
ID int `json:"id"`
|
||||
Title string `json:"title"`
|
||||
Cover []BaseImage `json:"cover"`
|
||||
}
|
||||
|
||||
// PodcastsEpisode struct.
|
||||
type PodcastsEpisode struct {
|
||||
ID int `json:"id"`
|
||||
OwnerID int `json:"owner_id"`
|
||||
Artist string `json:"artist"`
|
||||
Title string `json:"title"`
|
||||
Duration int `json:"duration"`
|
||||
Date int `json:"date"`
|
||||
URL string `json:"url"`
|
||||
LyricsID int `json:"lyrics_id"`
|
||||
NoSearch int `json:"no_search"`
|
||||
TrackCode string `json:"track_code"`
|
||||
IsHq BaseBoolInt `json:"is_hq"`
|
||||
IsFocusTrack BaseBoolInt `json:"is_focus_track"`
|
||||
IsExplicit BaseBoolInt `json:"is_explicit"`
|
||||
ShortVideosAllowed BaseBoolInt `json:"short_videos_allowed"`
|
||||
StoriesAllowed BaseBoolInt `json:"stories_allowed"`
|
||||
StoriesCoverAllowed BaseBoolInt `json:"stories_cover_allowed"`
|
||||
PodcastInfo PodcastsPodcastInfo `json:"podcast_info"`
|
||||
}
|
||||
|
||||
// PodcastsPodcastInfo struct.
|
||||
type PodcastsPodcastInfo struct {
|
||||
Cover struct {
|
||||
Sizes []BaseImage `json:"cover"`
|
||||
}
|
||||
Plays int `json:"plays"`
|
||||
IsFavorite BaseBoolInt `json:"is_favorite"`
|
||||
Description string `json:"description"`
|
||||
Position int `json:"position"`
|
||||
}
|
@ -0,0 +1,101 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// PollsAnswer struct.
|
||||
type PollsAnswer struct {
|
||||
ID int `json:"id"`
|
||||
Rate float64 `json:"rate"`
|
||||
Text string `json:"text"`
|
||||
Votes int `json:"votes"`
|
||||
}
|
||||
|
||||
// PollsPoll struct.
|
||||
type PollsPoll struct {
|
||||
AnswerID int `json:"answer_id"` // Current user's answer ID
|
||||
Answers []PollsAnswer `json:"answers"`
|
||||
Created int `json:"created"` // Date when poll has been created in Unixtime
|
||||
ID int `json:"id"` // Poll ID
|
||||
OwnerID int `json:"owner_id"` // Poll owner's ID
|
||||
Question string `json:"question"` // Poll question
|
||||
Votes int `json:"votes"` // Votes number
|
||||
AnswerIDs []int `json:"answer_ids"`
|
||||
EndDate int `json:"end_date"`
|
||||
Anonymous BaseBoolInt `json:"anonymous"` // Information whether the pole is anonymous
|
||||
Closed BaseBoolInt `json:"closed"`
|
||||
IsBoard BaseBoolInt `json:"is_board"`
|
||||
CanEdit BaseBoolInt `json:"can_edit"`
|
||||
CanVote BaseBoolInt `json:"can_vote"`
|
||||
CanReport BaseBoolInt `json:"can_report"`
|
||||
CanShare BaseBoolInt `json:"can_share"`
|
||||
Multiple BaseBoolInt `json:"multiple"`
|
||||
DisableUnvote BaseBoolInt `json:"disable_unvote"`
|
||||
Photo PhotosPhoto `json:"photo"`
|
||||
AuthorID int `json:"author_id"`
|
||||
Background PollsBackground `json:"background"`
|
||||
Friends []PollsFriend `json:"friends"`
|
||||
Profiles []UsersUser `json:"profiles"`
|
||||
Groups []GroupsGroup `json:"groups"`
|
||||
}
|
||||
|
||||
// ToAttachment return attachment format.
|
||||
func (poll PollsPoll) ToAttachment() string {
|
||||
return fmt.Sprintf("poll%d_%d", poll.OwnerID, poll.ID)
|
||||
}
|
||||
|
||||
// PollsFriend struct.
|
||||
type PollsFriend struct {
|
||||
ID int `json:"id"`
|
||||
}
|
||||
|
||||
// PollsVoters struct.
|
||||
type PollsVoters struct {
|
||||
AnswerID int `json:"answer_id"` // Answer ID
|
||||
Users PollsVotersUsers `json:"users"`
|
||||
}
|
||||
|
||||
// PollsVotersUsers struct.
|
||||
type PollsVotersUsers struct {
|
||||
Count int `json:"count"` // Votes number
|
||||
Items []int `json:"items"`
|
||||
}
|
||||
|
||||
// PollsVotersFields struct.
|
||||
type PollsVotersFields struct {
|
||||
AnswerID int `json:"answer_id"` // Answer ID
|
||||
Users PollsVotersUsersFields `json:"users"`
|
||||
}
|
||||
|
||||
// PollsVotersUsersFields struct.
|
||||
type PollsVotersUsersFields struct {
|
||||
Count int `json:"count"` // Votes number
|
||||
Items []UsersUser `json:"items"`
|
||||
}
|
||||
|
||||
// PollsBackground struct.
|
||||
type PollsBackground struct {
|
||||
Type string `json:"type"`
|
||||
Angle int `json:"angle"`
|
||||
Color string `json:"color"`
|
||||
Points []struct {
|
||||
Position float64 `json:"position"`
|
||||
Color string `json:"color"`
|
||||
} `json:"points"`
|
||||
ID int `json:"id"`
|
||||
Name string `json:"name"`
|
||||
}
|
||||
|
||||
// PollsPhoto struct.
|
||||
type PollsPhoto struct {
|
||||
ID int `json:"id"`
|
||||
Color string `json:"color"`
|
||||
Images []PhotosImage `json:"images"`
|
||||
}
|
||||
|
||||
// PollsPhotoUploadResponse struct.
|
||||
type PollsPhotoUploadResponse struct {
|
||||
Photo string `json:"photo"` // Uploaded photo data
|
||||
Hash string `json:"hash"` // Uploaded hash
|
||||
}
|
@ -0,0 +1,14 @@
|
||||
package object
|
||||
|
||||
// PrettyCardsPrettyCard struct.
|
||||
type PrettyCardsPrettyCard struct {
|
||||
Button string `json:"button"` // Button key
|
||||
ButtonText string `json:"button_text"` // Button text in current language
|
||||
CardID string `json:"card_id"` // Card ID (long int returned as string)
|
||||
Images []BaseImage `json:"images"`
|
||||
LinkURL string `json:"link_url"` // Link URL
|
||||
Photo string `json:"photo"` // Photo ID (format "<owner_id>_<media_id>")
|
||||
Price string `json:"price"` // Price if set (decimal number returned as string)
|
||||
PriceOld string `json:"price_old"` // Old price if set (decimal number returned as string)
|
||||
Title string `json:"title"` // Title
|
||||
}
|
@ -0,0 +1,11 @@
|
||||
package object
|
||||
|
||||
// SearchHint struct.
|
||||
type SearchHint struct {
|
||||
Description string `json:"description"` // Object description
|
||||
Global int `json:"global,omitempty"` // Information whether the object has been found globally
|
||||
Group GroupsGroup `json:"group,omitempty"`
|
||||
Profile UsersUser `json:"profile,omitempty"`
|
||||
Section string `json:"section"`
|
||||
Type string `json:"type"`
|
||||
}
|
@ -0,0 +1,33 @@
|
||||
package object // import "github.com/SevereCloud/vksdk/v2/object"
|
||||
|
||||
// SecureLevel struct.
|
||||
type SecureLevel struct {
|
||||
Level int `json:"level"` // Level
|
||||
UID int `json:"uid"` // User ID
|
||||
}
|
||||
|
||||
// SecureSmsNotification struct.
|
||||
type SecureSmsNotification struct {
|
||||
AppID int `json:"app_id"` // Application ID
|
||||
Date int `json:"date"` // Date when message has been sent in Unixtime
|
||||
ID int `json:"id"` // Notification ID
|
||||
Message string `json:"message"` // Message text
|
||||
UserID int `json:"user_id"` // User ID
|
||||
}
|
||||
|
||||
// SecureTokenChecked struct.
|
||||
type SecureTokenChecked struct {
|
||||
Date int `json:"date"` // Date when access_token has been generated in Unixtime
|
||||
Expire int `json:"expire"` // Date when access_token will expire in Unixtime
|
||||
Success int `json:"success"` // Returns if successfully processed
|
||||
UserID int `json:"user_id"` // User ID
|
||||
}
|
||||
|
||||
// SecureTransaction struct.
|
||||
type SecureTransaction struct {
|
||||
Date int `json:"date"` // Transaction date in Unixtime
|
||||
ID int `json:"id"` // Transaction ID
|
||||
UIDFrom int `json:"uid_from"` // From ID
|
||||
UIDTo int `json:"uid_to"` // To ID
|
||||
Votes int `json:"votes"` // Votes number
|
||||
}
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue