Socket
Socket
Sign inDemoInstall

github.com/stels-cs/vk-api-tools

Package Overview
Dependencies
0
Alerts
File Explorer

Install Socket

Detect and block malicious and high-risk dependencies

Install

    github.com/stels-cs/vk-api-tools

Пакет VkApi предоствляет инструменты для упрощенного взамодействия с API ВКонтакте. Получение списка пользователей Получение города пользователя Типа бот Запросы автоматически упаковываются в execute вызовы, в случае если поток запросов больше чем максимальный RPS очереди. В данном примере максимум 1 вызов в секунду. В примере делается 4 запроса, но к API будет сделано всего два execute запроса для работы с websocket используется github.com/gorilla/websocket


Version published

Readme

Source

License Build Status

Golang API ВКонтакте

go get git@github.com:stels-cs/vk-api-tools.git

github.com/gorilla/websocket потребуется для работы с WebSocket в StreamingAPI, но устанавливать его не обязательно

go get github.com/gorilla/websocket

Пример:

package main

import (
    "github.com/stels-cs/vk-api-tools"
    "strconv"
)

type User struct {
    Id        int    `json:"id"`
    FirstName string `json:"first_name"`
    LastName  string `json:"last_name"`
}

func main() {
    users := make([]User, 0)
    err := VkApi.Exec("users.get", VkApi.P{"user_ids": "2050,andrew"}, &users)
    if err != nil {
        panic(err)
    }

    for _, u := range users {
        println(u.FirstName + " " + u.LastName + " #" + strconv.Itoa(u.Id))
    }
}

Результат:

Катя Лебедева #2050
Андрей Рогозов #6492

Пример без структур:

package main

import (
    "github.com/stels-cs/vk-api-tools"
)

func main() {
    res, err := VkApi.Call("users.get", VkApi.P{"user_ids": "2050,avk", "fields": "city"})
    if err != nil {
        panic(err)
    }

    print(res.QStringDef("0.first_name", "") + " – ")
    println(res.QStringDef("0.city.title", ""))

    print(res.QStringDef("1.first_name", "") + " – ")
    println(res.QStringDef("1.city.title", ""))
}

Результат:

Катя – Санкт-Петербург
Александр – Москва

Подробнее про VkApi.Response и про QStringDef

Важно! По умолчанию VkApi.Exec и VkApi.Call будут повторят запрос до 30 раз в случае любых сетевых ошибок или если API вернет кодо ошибки: 1, 9, 6, 9, 10, 603 vk.com/dev/errors. Чтобы отключить это посмотрите пример ниже.

Пример создания объекта api

package main

import (
    "github.com/stels-cs/vk-api-tools"
    "strconv"
)

func main() {
    token := "3bac432bdcb1234b1...."  //API ключ доступа
    v := "5.71" //Версия API по умолчанию
    retryTimesIfFailed := 0 //Не повторять запросы в случае любых ошибок, можно поставить 5, тогда запрос будет повторен 5 раз в случае ошибок

    api := VkApi.CreateApi(token, v, VkApi.GetHttpTransport(), retryTimesIfFailed)

    users := make([]struct{
        Id int `json:"id"`
        FirstName string `json:"first_name"`
        LastName string `json:"last_name"`
    }, 0)
    err := api.Exec("users.get", VkApi.P{"user_ids": "2050,andrew"}, &users)
    if err != nil {
        panic(err)
    }

    for _, u := range users {
        println(u.FirstName + " " + u.LastName + " #" + strconv.Itoa(u.Id))
    }
}

Результат:

Катя Лебедева #2050
Андрей Рогозов #6492

Обработка ошибок

Метод VkApi.Call и VkApi.Exec могут вернуть три типа ошибок

  • VkApi.TransportError - Произошла ошибка сети, или сервер ВКонтакте временно недоступен
  • VkApi.ApiError - API ВКонтакте вернуло ошибку
  • все остальные типы - ошибки парсинга json, только для VkApi.Exec

Тесты

StreamingApi_test.go.txt - такой чтобы у вас не регалось на отсутсвие модуля

FAQs

Last updated on 29 Aug 2022

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc