Compare commits
5 Commits
lotr
...
d0dc725d64
Author | SHA1 | Date | |
---|---|---|---|
d0dc725d64 | |||
74b67313e7 | |||
574a07495f | |||
8efe9263b1 | |||
a8b370c7b9 |
1
.gitignore
vendored
1
.gitignore
vendored
@ -35,3 +35,4 @@
|
|||||||
|
|
||||||
# Go workspace file
|
# Go workspace file
|
||||||
go.work
|
go.work
|
||||||
|
|
||||||
|
6
.gitmodules
vendored
6
.gitmodules
vendored
@ -4,9 +4,3 @@
|
|||||||
[submodule "submodule/src/remote"]
|
[submodule "submodule/src/remote"]
|
||||||
path = submodule/src/remote
|
path = submodule/src/remote
|
||||||
url = git://github.com/laramiel/bazel-example-golang-remote
|
url = git://github.com/laramiel/bazel-example-golang-remote
|
||||||
[submodule "vendor/github.com/laramiel/bazel-example-golang-remote"]
|
|
||||||
path = vendor/github.com/laramiel/bazel-example-golang-remote
|
|
||||||
url = git://github.com/laramiel/bazel-example-golang-remote
|
|
||||||
[submodule "vendor/github.com/laramiel/bazel-example-golang-bare"]
|
|
||||||
path = vendor/github.com/laramiel/bazel-example-golang-bare
|
|
||||||
url = git://github.com/laramiel/bazel-example-golang-bare
|
|
||||||
|
23
BUILD
23
BUILD
@ -1,13 +1,20 @@
|
|||||||
load("@io_bazel_rules_go//go:def.bzl", "go_binary")
|
|
||||||
|
|
||||||
package(
|
package(
|
||||||
default_visibility = ["//visibility:public"],
|
default_visibility = ["//visibility:public"],
|
||||||
)
|
)
|
||||||
|
|
||||||
go_binary(
|
load("@bazel_gazelle//:def.bzl", "gazelle")
|
||||||
name = "hello",
|
|
||||||
srcs = ["hello.go"],
|
# gazelle:prefix github.com/squk/lotr
|
||||||
deps = [
|
# gazelle:build_file_name BUILD
|
||||||
"//cmd",
|
gazelle(name = "gazelle")
|
||||||
]
|
|
||||||
|
gazelle(
|
||||||
|
name = "gazelle-update-repos",
|
||||||
|
args = [
|
||||||
|
"-from_file=go.mod",
|
||||||
|
"-to_macro=deps.bzl%go_dependencies",
|
||||||
|
"-prune",
|
||||||
|
"-build_file_proto_mode=disable_global",
|
||||||
|
],
|
||||||
|
command = "update-repos",
|
||||||
)
|
)
|
||||||
|
46
WORKSPACE
46
WORKSPACE
@ -1,23 +1,47 @@
|
|||||||
load("@bazel_tools//tools/build_defs/repo:git.bzl", "git_repository")
|
|
||||||
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
|
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
|
||||||
|
|
||||||
# git_repository(
|
|
||||||
# name = "io_bazel_rules_go",
|
|
||||||
# remote = "https://github.com/bazelbuild/rules_go.git",
|
|
||||||
# branch = "master",
|
|
||||||
# )
|
|
||||||
|
|
||||||
http_archive(
|
http_archive(
|
||||||
name = "io_bazel_rules_go",
|
name = "io_bazel_rules_go",
|
||||||
sha256 = "6b65cb7917b4d1709f9410ffe00ecf3e160edf674b78c54a894471320862184f",
|
sha256 = "6dc2da7ab4cf5d7bfc7c949776b1b7c733f05e56edc4bcd9022bb249d2e2a996",
|
||||||
urls = [
|
urls = [
|
||||||
"https://mirror.bazel.build/github.com/bazelbuild/rules_go/releases/download/v0.39.0/rules_go-v0.39.0.zip",
|
"https://mirror.bazel.build/github.com/bazelbuild/rules_go/releases/download/v0.39.1/rules_go-v0.39.1.zip",
|
||||||
"https://github.com/bazelbuild/rules_go/releases/download/v0.39.0/rules_go-v0.39.0.zip",
|
"https://github.com/bazelbuild/rules_go/releases/download/v0.39.1/rules_go-v0.39.1.zip",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
http_archive(
|
||||||
|
name = "bazel_gazelle",
|
||||||
|
sha256 = "727f3e4edd96ea20c29e8c2ca9e8d2af724d8c7778e7923a854b2c80952bc405",
|
||||||
|
urls = [
|
||||||
|
"https://mirror.bazel.build/github.com/bazelbuild/bazel-gazelle/releases/download/v0.30.0/bazel-gazelle-v0.30.0.tar.gz",
|
||||||
|
"https://github.com/bazelbuild/bazel-gazelle/releases/download/v0.30.0/bazel-gazelle-v0.30.0.tar.gz",
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
load("@io_bazel_rules_go//go:deps.bzl", "go_register_toolchains", "go_rules_dependencies")
|
load("@io_bazel_rules_go//go:deps.bzl", "go_register_toolchains", "go_rules_dependencies")
|
||||||
|
load("@bazel_gazelle//:deps.bzl", "gazelle_dependencies", "go_repository")
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# Define your own dependencies here using go_repository.
|
||||||
|
# Else, dependencies declared by rules_go/gazelle will be used.
|
||||||
|
# The first declaration of an external repository "wins".
|
||||||
|
############################################################
|
||||||
|
|
||||||
|
go_repository(
|
||||||
|
name = "com_github_davecgh_go_spew",
|
||||||
|
build_file_proto_mode = "disable_global",
|
||||||
|
importpath = "github.com/davecgh/go-spew",
|
||||||
|
sum = "h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=",
|
||||||
|
version = "v1.1.1",
|
||||||
|
)
|
||||||
|
|
||||||
|
load("//:deps.bzl", "go_dependencies")
|
||||||
|
|
||||||
|
# gazelle:repository_macro deps.bzl%go_dependencies
|
||||||
|
go_dependencies()
|
||||||
|
|
||||||
go_rules_dependencies()
|
go_rules_dependencies()
|
||||||
|
|
||||||
go_register_toolchains(version = "1.19.3")
|
go_register_toolchains(version = "1.20.4")
|
||||||
|
|
||||||
|
gazelle_dependencies()
|
||||||
|
@ -1,9 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
)
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
fmt.Println("Hello World. Cmd")
|
|
||||||
}
|
|
2
data/BUILD
Normal file
2
data/BUILD
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
exports_files(glob(["*.json"]))
|
||||||
|
# exports_files(["Export.Cards.json"])
|
1
data/ringsdb.json
Normal file
1
data/ringsdb.json
Normal file
File diff suppressed because one or more lines are too long
50
docker-compose.yaml
Normal file
50
docker-compose.yaml
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
version: "3.6"
|
||||||
|
services:
|
||||||
|
postgres:
|
||||||
|
image: postgres:15
|
||||||
|
restart: always
|
||||||
|
volumes:
|
||||||
|
- db_data:/var/lib/postgresql/data
|
||||||
|
environment:
|
||||||
|
POSTGRES_PASSWORD: lotrlcgpassword
|
||||||
|
graphql-engine:
|
||||||
|
image: hasura/graphql-engine:v2.28.0
|
||||||
|
ports:
|
||||||
|
- "8080:8080"
|
||||||
|
restart: always
|
||||||
|
environment:
|
||||||
|
## postgres database to store Hasura metadata
|
||||||
|
HASURA_GRAPHQL_METADATA_DATABASE_URL: postgres://postgres:lotrlcgpassword@postgres:5432/postgres
|
||||||
|
## this env var can be used to add the above postgres database to Hasura as a data source. this can be removed/updated based on your needs
|
||||||
|
PG_DATABASE_URL: postgres://postgres:lotrlcgpassword@postgres:5432/postgres
|
||||||
|
## enable the console served by server
|
||||||
|
HASURA_GRAPHQL_ENABLE_CONSOLE: "true" # set to "false" to disable console
|
||||||
|
## enable debugging mode. It is recommended to disable this in production
|
||||||
|
HASURA_GRAPHQL_DEV_MODE: "true"
|
||||||
|
HASURA_GRAPHQL_ENABLED_LOG_TYPES: startup, http-log, webhook-log, websocket-log, query-log
|
||||||
|
## uncomment next line to run console offline (i.e load console assets from server instead of CDN)
|
||||||
|
# HASURA_GRAPHQL_CONSOLE_ASSETS_DIR: /srv/console-assets
|
||||||
|
## uncomment next line to set an admin secret
|
||||||
|
# HASURA_GRAPHQL_ADMIN_SECRET: myadminsecretkey
|
||||||
|
HASURA_GRAPHQL_METADATA_DEFAULTS: '{"backend_configs":{"dataconnector":{"athena":{"uri":"http://data-connector-agent:8081/api/v1/athena"},"mariadb":{"uri":"http://data-connector-agent:8081/api/v1/mariadb"},"mysql8":{"uri":"http://data-connector-agent:8081/api/v1/mysql"},"oracle":{"uri":"http://data-connector-agent:8081/api/v1/oracle"},"snowflake":{"uri":"http://data-connector-agent:8081/api/v1/snowflake"}}}}'
|
||||||
|
depends_on:
|
||||||
|
data-connector-agent:
|
||||||
|
condition: service_healthy
|
||||||
|
data-connector-agent:
|
||||||
|
image: hasura/graphql-data-connector:v2.28.0
|
||||||
|
restart: always
|
||||||
|
ports:
|
||||||
|
- 8081:8081
|
||||||
|
environment:
|
||||||
|
QUARKUS_LOG_LEVEL: ERROR # FATAL, ERROR, WARN, INFO, DEBUG, TRACE
|
||||||
|
## https://quarkus.io/guides/opentelemetry#configuration-reference
|
||||||
|
QUARKUS_OPENTELEMETRY_ENABLED: "false"
|
||||||
|
## QUARKUS_OPENTELEMETRY_TRACER_EXPORTER_OTLP_ENDPOINT: http://jaeger:4317
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "curl", "-f", "http://localhost:8081/api/v1/athena/health"]
|
||||||
|
interval: 5s
|
||||||
|
timeout: 10s
|
||||||
|
retries: 5
|
||||||
|
start_period: 5s
|
||||||
|
volumes:
|
||||||
|
db_data:
|
3
extract/BUILD
Normal file
3
extract/BUILD
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
package(
|
||||||
|
default_visibility = ["//visibility:public"],
|
||||||
|
)
|
22
extract/cmd/BUILD
Normal file
22
extract/cmd/BUILD
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
load("@io_bazel_rules_go//go:def.bzl", "go_binary", "go_library")
|
||||||
|
|
||||||
|
go_library(
|
||||||
|
name = "cmd_lib",
|
||||||
|
srcs = ["main.go"],
|
||||||
|
data = [
|
||||||
|
"//data:Bot.Cards.json",
|
||||||
|
"//data:Export.Cards.json"
|
||||||
|
],
|
||||||
|
importpath = "github.com/squk/lotr/extract/cmd",
|
||||||
|
visibility = ["//visibility:private"],
|
||||||
|
deps = [
|
||||||
|
"//extract/types",
|
||||||
|
"@com_github_davecgh_go_spew//spew",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
go_binary(
|
||||||
|
name = "cmd",
|
||||||
|
embed = [":cmd_lib"],
|
||||||
|
visibility = ["//visibility:public"],
|
||||||
|
)
|
31
extract/cmd/main.go
Normal file
31
extract/cmd/main.go
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"github.com/squk/lotr/extract/types"
|
||||||
|
"github.com/davecgh/go-spew/spew"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println("LOTR CARD PARSE")
|
||||||
|
|
||||||
|
|
||||||
|
// Open our jsonFile
|
||||||
|
jsonFile, err := os.Open("./data/Bot.Cards.json")
|
||||||
|
// if we os.Open returns an error then handle it
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fmt.Println("Successfully Opened users.json")
|
||||||
|
// defer the closing of our jsonFile so that we can parse it later on
|
||||||
|
defer jsonFile.Close()
|
||||||
|
|
||||||
|
byteValue, _ := ioutil.ReadAll(jsonFile)
|
||||||
|
c := []types.HallOfBeornCard{}
|
||||||
|
json.Unmarshal(byteValue, &c)
|
||||||
|
spew.Dump(c)
|
||||||
|
}
|
@ -1,8 +1,8 @@
|
|||||||
load("@io_bazel_rules_go//go:def.bzl", "go_library")
|
load("@io_bazel_rules_go//go:def.bzl", "go_library")
|
||||||
|
|
||||||
go_library(
|
go_library(
|
||||||
name ="cmd",
|
name = "types",
|
||||||
srcs = [ "cmd.go" ],
|
srcs = ["card.go"],
|
||||||
|
importpath = "github.com/squk/lotr/extract/types",
|
||||||
visibility = ["//visibility:public"],
|
visibility = ["//visibility:public"],
|
||||||
importpath= "github.com/squk/lotr/cmd"
|
|
||||||
)
|
)
|
30
extract/types/card.go
Normal file
30
extract/types/card.go
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
package types
|
||||||
|
|
||||||
|
type HallOfBeornCard struct {
|
||||||
|
PackCode string `json:"pack_code"`
|
||||||
|
PackName string `json:"pack_name"`
|
||||||
|
IsOfficial bool `json:"is_official"`
|
||||||
|
TypeCode string `json:"type_code"`
|
||||||
|
TypeName string `json:"type_name"`
|
||||||
|
SphereCode string `json:"sphere_code"`
|
||||||
|
SphereName string `json:"sphere_name"`
|
||||||
|
Position int `json:"position"`
|
||||||
|
Code string `json:"code"`
|
||||||
|
Name string `json:"name"`
|
||||||
|
Traits string `json:"traits"`
|
||||||
|
Text string `json:"text"`
|
||||||
|
Flavor string `json:"flavor"`
|
||||||
|
IsUnique bool `json:"is_unique"`
|
||||||
|
Threat int `json:"threat"`
|
||||||
|
Willpower int `json:"willpower"`
|
||||||
|
Attack int `json:"attack"`
|
||||||
|
Defense int `json:"defense"`
|
||||||
|
Health int `json:"health"`
|
||||||
|
Quantity int `json:"quantity"`
|
||||||
|
DeckLimit int `json:"deck_limit"`
|
||||||
|
Illustrator string `json:"illustrator"`
|
||||||
|
Octgnid string `json:"octgnid"`
|
||||||
|
HasErrata bool `json:"has_errata"`
|
||||||
|
URL string `json:"url"`
|
||||||
|
Imagesrc string `json:"imagesrc"`
|
||||||
|
}
|
5
go.mod
Normal file
5
go.mod
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
module github.com/squk/lotr
|
||||||
|
|
||||||
|
go 1.19
|
||||||
|
|
||||||
|
require github.com/davecgh/go-spew v1.1.1
|
2
go.sum
Normal file
2
go.sum
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||||
|
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
9
hello.go
9
hello.go
@ -1,9 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
)
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
fmt.Println("Hello World")
|
|
||||||
}
|
|
7
vendor/github.com/laramiel/BUILD
generated
vendored
7
vendor/github.com/laramiel/BUILD
generated
vendored
@ -1,7 +0,0 @@
|
|||||||
load("@io_bazel_rules_go//go:def.bzl", "go_library")
|
|
||||||
|
|
||||||
go_library(
|
|
||||||
name = "bare",
|
|
||||||
srcs = ["bazel-example-golang-bare/bare.go"],
|
|
||||||
visibility = ["//visibility:public"],
|
|
||||||
)
|
|
1
vendor/github.com/laramiel/bazel-example-golang-bare
generated
vendored
1
vendor/github.com/laramiel/bazel-example-golang-bare
generated
vendored
Submodule vendor/github.com/laramiel/bazel-example-golang-bare deleted from 3bd848fc12
1
vendor/github.com/laramiel/bazel-example-golang-remote
generated
vendored
1
vendor/github.com/laramiel/bazel-example-golang-remote
generated
vendored
Submodule vendor/github.com/laramiel/bazel-example-golang-remote deleted from 4a9199be6e
Reference in New Issue
Block a user