upd
This commit is contained in:
parent
1c507cf7d6
commit
7bd38e0a24
5 changed files with 261 additions and 87 deletions
104
src/api/users.cr
104
src/api/users.cr
|
@ -1,51 +1,99 @@
|
|||
require "json"
|
||||
require "../twitchapi/*"
|
||||
|
||||
# def fetchGQL(id : String) : JSON::Any
|
||||
# GqlAPI.query(id)
|
||||
# end
|
||||
|
||||
# def fetchGQLchannel(id : String) : JSON::Any
|
||||
# GqlAPI.channel(id)
|
||||
# end
|
||||
|
||||
# def fetchGQLbanned(id : String) : JSON::Any
|
||||
# GqlAPI.isBanned(id)
|
||||
# end
|
||||
|
||||
module Users
|
||||
def self.checkBanned(gql)
|
||||
puts "tst2"
|
||||
pp gql["userResultByLogin"]
|
||||
pp gql["userResultByID"]
|
||||
if gql["userResultByLogin"].nil?
|
||||
return nil
|
||||
elsif gql["userResultByID"].nil?
|
||||
return nil
|
||||
else
|
||||
return true
|
||||
end
|
||||
end
|
||||
|
||||
def self.parseData(params)
|
||||
helixUsers = JSON.parse(HelixAPI.users(params))
|
||||
login = helixUsers["data"][0]["login"]
|
||||
id = helixUsers["data"][0]["id"]
|
||||
# helixUsers = JSON.parse(HelixAPI.users(params))
|
||||
# begin
|
||||
# login = helixUsers["data"][0]["login"]
|
||||
# id = helixUsers["data"][0]["id"]
|
||||
# rescue
|
||||
# login = nil
|
||||
# id = nil
|
||||
# end
|
||||
|
||||
gqlUser = GqlAPI.user(id.to_s)
|
||||
gqlChannel = GqlAPI.channel(id.to_s)
|
||||
# helixChatColor = JSON.parse(HelixAPI.chatColor(id))
|
||||
# if login.nil? && params.has_key?("login")
|
||||
# login = params["login"]
|
||||
# elsif id.nil? && params.has_key?("id")
|
||||
# id = params["id"]
|
||||
# end
|
||||
|
||||
panels = gqlUser["panels"]
|
||||
# gqlUser = GqlAPI.user(id.to_s)
|
||||
# gqlChannel = GqlAPI.channel(id.to_s)
|
||||
|
||||
# a = Channel(JSON::Any).new
|
||||
# spawn do
|
||||
# a.send fetchGQL(id.to_s)
|
||||
# end
|
||||
|
||||
gql = GqlAPI.query(params)
|
||||
panels = gql["user"]["panels"]
|
||||
banned = checkBanned(gql)
|
||||
pp gql
|
||||
|
||||
json_data = [
|
||||
{
|
||||
"banned" => false,
|
||||
"displayName" => helixUsers["data"][0]["display_name"],
|
||||
"login" => helixUsers["data"][0]["login"],
|
||||
"id" => helixUsers["data"][0]["id"],
|
||||
"bio" => helixUsers["data"][0]["description"],
|
||||
# "banned" => banned, # TODO: FIX BANNED
|
||||
"displayName" => gql["user"]["displayName"],
|
||||
"login" => gql["user"]["login"],
|
||||
"id" => gql["user"]["id"],
|
||||
"bio" => gql["user"]["description"],
|
||||
"follows" => nil,
|
||||
"followers" => gqlUser["followers"]["totalCount"],
|
||||
"followers" => gql["user"]["followers"]["totalCount"],
|
||||
"profileViewCount" => nil, # Always null
|
||||
"panelCount" => panels.size,
|
||||
# "chatColor" => helixChatColor["data"][0]["color"],
|
||||
"logo" => gqlUser["profileImageURL"],
|
||||
"banner" => gqlUser["bannerImageURL"],
|
||||
"chatColor" => gql["user"]["chatColor"],
|
||||
"logo" => gql["user"]["profileImageURL"],
|
||||
"banner" => gql["user"]["bannerImageURL"],
|
||||
"verifiedBot" => nil, # Deprecated by twitch
|
||||
"createdAt" => gqlUser["createdAt"],
|
||||
"updatedAt" => gqlUser["updatedAt"],
|
||||
"deletedAt" => gqlUser["deletedAt"],
|
||||
"emotePrefix" => "lol",
|
||||
"createdAt" => gql["user"]["createdAt"],
|
||||
"updatedAt" => gql["user"]["updatedAt"],
|
||||
"deletedAt" => gql["user"]["deletedAt"],
|
||||
"emotePrefix" => gql["user"]["emoticonPrefix"]["name"],
|
||||
"roles" => {
|
||||
"isAffiliate" => gqlUser["roles"]["isAffiliate"],
|
||||
"isPartner" => gqlUser["roles"]["isPartner"],
|
||||
"isStaff" => gqlUser["roles"]["isStaff"],
|
||||
"isAffiliate" => gql["user"]["roles"]["isAffiliate"],
|
||||
"isPartner" => gql["user"]["roles"]["isPartner"],
|
||||
"isStaff" => gql["user"]["roles"]["isStaff"],
|
||||
},
|
||||
"badges" => gqlUser["displayBadges"],
|
||||
"chatterCount" => gqlChannel["chatters"]["count"],
|
||||
"chatSettings" => gqlUser["chatSettings"],
|
||||
"stream" => gqlUser["stream"],
|
||||
"lastBroadcast" => gqlUser["lastBroadcast"],
|
||||
"badges" => gql["user"]["displayBadges"],
|
||||
"chatterCount" => gql["user"]["channel"]["chatters"]["count"],
|
||||
"chatSettings" => gql["user"]["chatSettings"],
|
||||
"stream" => gql["user"]["stream"],
|
||||
"lastBroadcast" => gql["user"]["lastBroadcast"],
|
||||
"panels" => panels,
|
||||
},
|
||||
]
|
||||
|
||||
# if json_data[0]["banned"].nil?
|
||||
# puts "test"
|
||||
# json_data[0]["reason"] = gql["userResultByID"]["reason"]
|
||||
# end
|
||||
|
||||
return json_data.to_json
|
||||
end
|
||||
end
|
||||
|
|
|
@ -3,8 +3,10 @@ require "yaml"
|
|||
class Config
|
||||
include YAML::Serializable
|
||||
|
||||
property oauthToken : String?
|
||||
property clientID : String?
|
||||
property helixOAuth : String?
|
||||
property helixClientID : String?
|
||||
property gqlOAuth : String?
|
||||
property gqlClientID : String?
|
||||
property apiEndpoint : String?
|
||||
property gqlEndpoint : String?
|
||||
|
||||
|
@ -13,13 +15,13 @@ class Config
|
|||
config_yaml = File.read(config_file)
|
||||
config = Config.from_yaml(config_yaml)
|
||||
|
||||
if config.oauthToken.to_s.empty?
|
||||
puts "Config: 'oauthToken' is required/can't be empty"
|
||||
if config.helixOAuth.to_s.empty?
|
||||
puts "Config: 'helixOAuth' is required/can't be empty"
|
||||
exit(1)
|
||||
end
|
||||
|
||||
if config.clientID.to_s.empty?
|
||||
puts "Config: 'oauthToken' is required/can't be empty"
|
||||
if config.helixClientID.to_s.empty?
|
||||
puts "Config: 'helixOAuth' is required/can't be empty"
|
||||
exit(1)
|
||||
end
|
||||
|
||||
|
|
|
@ -7,8 +7,8 @@ require "./api/*"
|
|||
require "./twitchapi/*"
|
||||
|
||||
CONFIG = Config.load
|
||||
# puts("oauthToken: #{CONFIG.oauthToken}")
|
||||
# puts("clientID: #{CONFIG.clientID}")
|
||||
# puts("helixOAuth: #{CONFIG.helixOAuth}")
|
||||
# puts("helixClientID: #{CONFIG.helixClientID}")
|
||||
|
||||
before_all "/twitch/*" do |env|
|
||||
env.response.content_type = "application/json"
|
||||
|
|
|
@ -2,48 +2,172 @@ require "json"
|
|||
require "uri"
|
||||
|
||||
module GqlAPI
|
||||
|
||||
@@headers = HTTP::Headers{
|
||||
"Content-Type" => "application/json",
|
||||
# "Client-Id" => "kimne78kx3ncx6brgo4mv6wki5h1ko", # Can cause problems due to Client-Integrity
|
||||
"Client-Id" => "ue6666qo983tsx6so1t0vnawi233wa",
|
||||
"Authorization" => "OAuth #{CONFIG.gqlOAuth}",
|
||||
"Client-Id" => "#{CONFIG.gqlClientID}",
|
||||
}
|
||||
|
||||
def self.user(id : String)
|
||||
data = { "query" => "{user(id:#{id}){
|
||||
bannerImageURL,
|
||||
profileImageURL(width: 600),
|
||||
createdAt,
|
||||
updatedAt,
|
||||
deletedAt,
|
||||
panels(hideExtensions: false){id,type},
|
||||
follows(first: 1, after: buh, filter: ALL order: ASC){totalCount},
|
||||
followers(first: 1, after: buh, order: ASC){totalCount},
|
||||
roles{isStaff,isAffiliate,isPartner,isExtensionsDeveloper},
|
||||
displayBadges(){setID, title, description,version},
|
||||
chatSettings{blockLinks,chatDelayMs,slowModeDurationSeconds,followersOnlyDurationMinutes,isBroadcasterLanguageModeEnabled,isEmoteOnlyModeEnabled,isFastSubsModeEnabled,isSubscribersOnlyModeEnabled,isUniqueChatModeEnabled,requireVerifiedAccount,rules},
|
||||
stream{averageFPS,bitrate,codec,createdAt,width,height,id,viewersCount,type,game{displayName}},
|
||||
lastBroadcast{game{displayName},id,startedAt,title}
|
||||
}}" }
|
||||
return JSON.parse(gqlReq(id, data.to_json))["data"]["user"]
|
||||
def self.userResultBy (params)
|
||||
if params.has_key?("id")
|
||||
return %(userResultByID(id: "#{params["id"]}"))
|
||||
else
|
||||
return %(userResultByLogin(login: "#{params["login"]}"))
|
||||
end
|
||||
end
|
||||
|
||||
def self.channel(id : String)
|
||||
data = { "query" => "{channel(id:#{id}){
|
||||
chatters{count,moderators{login},vips{login}}
|
||||
}}" }
|
||||
return JSON.parse(gqlReq(id, data.to_json))["data"]["channel"]
|
||||
# def self.channel (params)
|
||||
# if params.has_key?("id")
|
||||
# return %(channel(id: "#{params["id"]}"))
|
||||
# else
|
||||
# return %(channel(name: "#{params["login"]}"))
|
||||
# end
|
||||
# end
|
||||
|
||||
def self.user (params)
|
||||
if params.has_key?("id")
|
||||
return %(user(id: "#{params["id"]}" lookupType: ALL))
|
||||
else
|
||||
return %(user(login: "#{params["login"]}" lookupType: ALL))
|
||||
end
|
||||
end
|
||||
|
||||
def self.query(id : String)
|
||||
data = { "query" => "{query(id:#{id}){
|
||||
chatters{count,moderators{login},vips{login}}
|
||||
}}" }
|
||||
return JSON.parse(gqlReq(id, data.to_json))["data"]["channel"]
|
||||
def self.query(params)
|
||||
puts params
|
||||
# id = params["id"]
|
||||
|
||||
# data = { "query" => "{user(id:#{id}){
|
||||
# bannerImageURL,
|
||||
# profileImageURL(width: 600),
|
||||
# createdAt,
|
||||
# updatedAt,
|
||||
# deletedAt,
|
||||
# chatColor,
|
||||
# emoticonPrefix{name},
|
||||
# panels(hideExtensions: false){id,type},
|
||||
# follows(first: 1, after: buh, filter: ALL order: ASC){totalCount},
|
||||
# followers(first: 1, after: buh, order: ASC){totalCount},
|
||||
# roles{isStaff,isAffiliate,isPartner,isExtensionsDeveloper},
|
||||
# displayBadges(){setID, title, description,version},
|
||||
# chatSettings{blockLinks,chatDelayMs,slowModeDurationSeconds,followersOnlyDurationMinutes,isBroadcasterLanguageModeEnabled,isEmoteOnlyModeEnabled,isFastSubsModeEnabled,isSubscribersOnlyModeEnabled,isUniqueChatModeEnabled,requireVerifiedAccount,rules},
|
||||
# stream{averageFPS,bitrate,codec,createdAt,width,height,id,viewersCount,type,game{displayName}},
|
||||
# lastBroadcast{game{displayName},id,startedAt,title}
|
||||
# }}" }
|
||||
query = %(
|
||||
query {
|
||||
#{userResultBy(params)} {
|
||||
... on UserDoesNotExist {
|
||||
key
|
||||
reason
|
||||
}
|
||||
}
|
||||
#{user(params)} {
|
||||
id
|
||||
language
|
||||
login
|
||||
displayName
|
||||
description
|
||||
bannerImageURL
|
||||
profileImageURL(width: 600)
|
||||
createdAt
|
||||
updatedAt
|
||||
deletedAt
|
||||
chatColor
|
||||
emoticonPrefix {
|
||||
name
|
||||
}
|
||||
panels(hideExtensions: false) {
|
||||
id
|
||||
type
|
||||
}
|
||||
followers {
|
||||
totalCount
|
||||
}
|
||||
roles {
|
||||
isStaff
|
||||
isAffiliate
|
||||
isPartner
|
||||
isExtensionsDeveloper
|
||||
}
|
||||
displayBadges {
|
||||
setID
|
||||
title
|
||||
description
|
||||
version
|
||||
}
|
||||
chatSettings {
|
||||
autoModLevel
|
||||
blockLinks
|
||||
chatDelayMs
|
||||
followersOnlyDurationMinutes
|
||||
isBroadcasterLanguageModeEnabled
|
||||
isEmoteOnlyModeEnabled
|
||||
isFastSubsModeEnabled
|
||||
isOptedOutOfGlobalBannedWordsList
|
||||
isSubscribersOnlyModeEnabled
|
||||
isUniqueChatModeEnabled
|
||||
requireVerifiedAccount
|
||||
rules
|
||||
slowModeDurationSeconds
|
||||
}
|
||||
stream {
|
||||
averageFPS
|
||||
bitrate
|
||||
codec
|
||||
createdAt
|
||||
width
|
||||
height
|
||||
id
|
||||
viewersCount
|
||||
type
|
||||
game{displayName}
|
||||
}
|
||||
lastBroadcast {
|
||||
game{displayName}
|
||||
id
|
||||
startedAt
|
||||
title
|
||||
}
|
||||
channel {
|
||||
chatters {
|
||||
count
|
||||
moderators {
|
||||
login
|
||||
}
|
||||
vips {
|
||||
login
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
)
|
||||
return JSON.parse(gqlReq(params, query))["data"]
|
||||
end
|
||||
|
||||
def self.gqlReq(id : String, data : String)
|
||||
response = HTTP::Client.post(CONFIG.gqlEndpoint.to_s, headers: @@headers, body: data)
|
||||
# def self.isBanned(id : String)
|
||||
# data = {"query" => "{userResultByID(id:#{id}){... on UserDoesNotExist{reason}}}"}
|
||||
# return JSON.parse(gqlReq(id, data.to_json))["data"]["userResultByID"]
|
||||
# end
|
||||
|
||||
# def self.channel(id : String)
|
||||
# data = {"query" => "{channel(id:#{id}){
|
||||
# chatters{count,moderators{login},vips{login}}
|
||||
# }}"}
|
||||
# return JSON.parse(gqlReq(id, data.to_json))["data"]["channel"]
|
||||
# end
|
||||
|
||||
# def self.query(id : String)
|
||||
# data = { "query" => "{query(id:#{id}){
|
||||
# chatters{count,moderators{login},vips{login}}
|
||||
# }}" }
|
||||
# return JSON.parse(gqlReq(id, data.to_json))["data"]["channel"]
|
||||
# end
|
||||
|
||||
def self.gqlReq(params, query)
|
||||
data = {"query" => query}
|
||||
response = HTTP::Client.post(CONFIG.gqlEndpoint.to_s, headers: @@headers, body: data.to_json)
|
||||
|
||||
if response.success?
|
||||
return (response.body)
|
||||
|
@ -65,4 +189,3 @@ module GqlAPI
|
|||
# end
|
||||
# end
|
||||
end
|
||||
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
module HelixAPI
|
||||
@@headers = HTTP::Headers{
|
||||
"Content-Type" => "application/json",
|
||||
"Authorization" => "Bearer #{CONFIG.oauthToken}",
|
||||
"Client-Id" => "#{CONFIG.clientID}",
|
||||
"Authorization" => "Bearer #{CONFIG.helixOAuth}",
|
||||
"Client-Id" => "#{CONFIG.helixClientID}",
|
||||
}
|
||||
|
||||
def self.users(params)
|
||||
|
@ -14,6 +14,7 @@ module HelixAPI
|
|||
|
||||
response = HTTP::Client.get(endpoint, headers: @@headers)
|
||||
|
||||
puts response.body
|
||||
if response.success?
|
||||
return (response.body)
|
||||
else
|
||||
|
@ -21,15 +22,15 @@ module HelixAPI
|
|||
end
|
||||
end
|
||||
|
||||
def self.chatColor(id)
|
||||
endpoint = "#{CONFIG.apiEndpoint}/chat/color?user_id=#{id}"
|
||||
# def self.chatColor(id)
|
||||
# endpoint = "#{CONFIG.apiEndpoint}/chat/color?user_id=#{id}"
|
||||
|
||||
response = HTTP::Client.get(endpoint, headers: @@headers)
|
||||
# response = HTTP::Client.get(endpoint, headers: @@headers)
|
||||
|
||||
if response.success?
|
||||
return (response.body)
|
||||
else
|
||||
raise "Helix Twitch API returned #{response.status_code}: #{response.body.to_s}"
|
||||
end
|
||||
end
|
||||
# if response.success?
|
||||
# return (response.body)
|
||||
# else
|
||||
# raise "Helix Twitch API returned #{response.status_code}: #{response.body.to_s}"
|
||||
# end
|
||||
# end
|
||||
end
|
||||
|
|
Loading…
Add table
Reference in a new issue