nwo able to upload the sources to the DB
This commit is contained in:
parent
409788d0b0
commit
11dac75882
110
main.go
110
main.go
@ -23,7 +23,12 @@ func main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
defer driver.Close(ctx)
|
defer func(driver neo4j.DriverWithContext, ctx context.Context) {
|
||||||
|
err := driver.Close(ctx)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
}(driver, ctx)
|
||||||
|
|
||||||
e621Client := api.NewClient(config.E621APIKey, config.E621Username)
|
e621Client := api.NewClient(config.E621APIKey, config.E621Username)
|
||||||
user, err := e621Client.GetUserInfo("selloo")
|
user, err := e621Client.GetUserInfo("selloo")
|
||||||
@ -36,29 +41,30 @@ func main() {
|
|||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
favs, err := e621Client.GetFavorites(user.Name)
|
favorites, err := e621Client.GetFavorites(user.Name)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
start := time.Now()
|
start := time.Now()
|
||||||
uploadTags(favs, ctx, driver)
|
uploadTags(favorites, ctx, driver)
|
||||||
elapsed := time.Since(start)
|
elapsed := time.Since(start)
|
||||||
log.Printf("upload of Tags took %d", elapsed)
|
log.Printf("upload of Tags took %d", elapsed)
|
||||||
|
|
||||||
start = time.Now()
|
start = time.Now()
|
||||||
uploadPosts(favs, ctx, driver)
|
uploadPosts(favorites, ctx, driver)
|
||||||
elapsed = time.Since(start)
|
elapsed = time.Since(start)
|
||||||
log.Printf("upload of Posts took %d", elapsed)
|
log.Printf("upload of Posts took %d", elapsed)
|
||||||
|
|
||||||
start = time.Now()
|
start = time.Now()
|
||||||
//uploadSources(favs, ctx, driver)
|
uploadSources(favorites, ctx, driver)
|
||||||
elapsed = time.Since(start)
|
elapsed = time.Since(start)
|
||||||
log.Printf("upload of Sources took %d", elapsed)
|
log.Printf("upload of Sources took %d", elapsed)
|
||||||
|
|
||||||
}
|
}
|
||||||
func uploadPosts(favs []models.Post, ctx context.Context, driver neo4j.DriverWithContext) error {
|
func uploadPosts(posts []models.Post, ctx context.Context, driver neo4j.DriverWithContext) error {
|
||||||
for _, fav := range favs {
|
for _, fav := range posts {
|
||||||
|
log.Printf("e621 PostID: %d", fav.ID)
|
||||||
err := neo4jAPI.CreatePostNode(ctx, driver, fav.ID)
|
err := neo4jAPI.CreatePostNode(ctx, driver, fav.ID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -69,7 +75,7 @@ func uploadPosts(favs []models.Post, ctx context.Context, driver neo4j.DriverWit
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func uploadTags(favs []models.Post, ctx context.Context, driver neo4j.DriverWithContext) {
|
func uploadTags(posts []models.Post, ctx context.Context, driver neo4j.DriverWithContext) error {
|
||||||
uniqueGeneralTags := make([]string, 0)
|
uniqueGeneralTags := make([]string, 0)
|
||||||
uniqueCharacterTags := make([]string, 0)
|
uniqueCharacterTags := make([]string, 0)
|
||||||
uniqueCopyrightTags := make([]string, 0)
|
uniqueCopyrightTags := make([]string, 0)
|
||||||
@ -81,7 +87,7 @@ func uploadTags(favs []models.Post, ctx context.Context, driver neo4j.DriverWith
|
|||||||
allArtistTags := make([]string, 0)
|
allArtistTags := make([]string, 0)
|
||||||
|
|
||||||
// add all tags together
|
// add all tags together
|
||||||
for _, fav := range favs {
|
for _, fav := range posts {
|
||||||
allGeneralTags = append(allGeneralTags, fav.Tags.General...)
|
allGeneralTags = append(allGeneralTags, fav.Tags.General...)
|
||||||
allCharacterTags = append(allCharacterTags, fav.Tags.Character...)
|
allCharacterTags = append(allCharacterTags, fav.Tags.Character...)
|
||||||
allCopyrightTags = append(allCopyrightTags, fav.Tags.Character...)
|
allCopyrightTags = append(allCopyrightTags, fav.Tags.Character...)
|
||||||
@ -102,8 +108,6 @@ func uploadTags(favs []models.Post, ctx context.Context, driver neo4j.DriverWith
|
|||||||
|
|
||||||
log.Printf("uniqueGeneralTags length: %d", len(uniqueGeneralTags))
|
log.Printf("uniqueGeneralTags length: %d", len(uniqueGeneralTags))
|
||||||
|
|
||||||
log.Printf("uniqueCharacterTags length: %d", len(uniqueCharacterTags))
|
|
||||||
|
|
||||||
log.Printf("uniqueCopyrightTags length: %d", len(uniqueCopyrightTags))
|
log.Printf("uniqueCopyrightTags length: %d", len(uniqueCopyrightTags))
|
||||||
|
|
||||||
log.Printf("uniqueArtistTags length: %d", len(uniqueArtistTags))
|
log.Printf("uniqueArtistTags length: %d", len(uniqueArtistTags))
|
||||||
@ -113,14 +117,14 @@ func uploadTags(favs []models.Post, ctx context.Context, driver neo4j.DriverWith
|
|||||||
log.Printf("TagType: General - Tag: %s", uniqueGeneralTag)
|
log.Printf("TagType: General - Tag: %s", uniqueGeneralTag)
|
||||||
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueGeneralTag, "general")
|
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueGeneralTag, "general")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for _, uniqueCharacterTag := range uniqueCharacterTags {
|
for _, uniqueCharacterTag := range uniqueCharacterTags {
|
||||||
log.Printf("TagType: Character - Tag: %s", uniqueCharacterTag)
|
log.Printf("TagType: Character - Tag: %s", uniqueCharacterTag)
|
||||||
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueCharacterTag, "character")
|
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueCharacterTag, "character")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,7 +132,7 @@ func uploadTags(favs []models.Post, ctx context.Context, driver neo4j.DriverWith
|
|||||||
log.Printf("TagType: Copyright - Tag: %s", uniqueCopyrightTag)
|
log.Printf("TagType: Copyright - Tag: %s", uniqueCopyrightTag)
|
||||||
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueCopyrightTag, "copyright")
|
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueCopyrightTag, "copyright")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -136,81 +140,21 @@ func uploadTags(favs []models.Post, ctx context.Context, driver neo4j.DriverWith
|
|||||||
log.Printf("TagType: Artist - Tag: %s", uniqueArtistTag)
|
log.Printf("TagType: Artist - Tag: %s", uniqueArtistTag)
|
||||||
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueArtistTag, "artist")
|
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueArtistTag, "artist")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func uploadSources(favs []models.Post, ctx context.Context, driver neo4j.DriverWithContext) {
|
func uploadSources(posts []models.Post, ctx context.Context, driver neo4j.DriverWithContext) error {
|
||||||
uniqueGeneralTags := make([]string, 0)
|
for _, fav := range posts {
|
||||||
uniqueCharacterTags := make([]string, 0)
|
for _, source := range fav.Sources {
|
||||||
uniqueCopyrightTags := make([]string, 0)
|
log.Printf("e621 Source: %s", source)
|
||||||
uniqueArtistTags := make([]string, 0)
|
err := neo4jAPI.CreateSourceNode(ctx, driver, source)
|
||||||
|
|
||||||
allGeneralTags := make([]string, 0)
|
|
||||||
allCharacterTags := make([]string, 0)
|
|
||||||
allCopyrightTags := make([]string, 0)
|
|
||||||
allArtistTags := make([]string, 0)
|
|
||||||
|
|
||||||
// add all tags together
|
|
||||||
for _, fav := range favs {
|
|
||||||
allGeneralTags = append(allGeneralTags, fav.Tags.General...)
|
|
||||||
allCharacterTags = append(allCharacterTags, fav.Tags.Character...)
|
|
||||||
allCopyrightTags = append(allCopyrightTags, fav.Tags.Character...)
|
|
||||||
allArtistTags = append(allArtistTags, fav.Tags.Artist...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Process General PostTags
|
|
||||||
uniqueGeneralTags = utils.UniqueNonEmptyElementsOf(allGeneralTags)
|
|
||||||
|
|
||||||
// Process Character PostTags
|
|
||||||
uniqueCharacterTags = utils.UniqueNonEmptyElementsOf(allCharacterTags)
|
|
||||||
|
|
||||||
// Process Copyright PostTags
|
|
||||||
uniqueCopyrightTags = utils.UniqueNonEmptyElementsOf(allCopyrightTags)
|
|
||||||
|
|
||||||
// Process Artist PostTags
|
|
||||||
uniqueArtistTags = utils.UniqueNonEmptyElementsOf(allArtistTags)
|
|
||||||
|
|
||||||
log.Printf("uniqueGeneralTags length: %d", len(uniqueGeneralTags))
|
|
||||||
|
|
||||||
log.Printf("uniqueCharacterTags length: %d", len(uniqueCharacterTags))
|
|
||||||
|
|
||||||
log.Printf("uniqueCopyrightTags length: %d", len(uniqueCopyrightTags))
|
|
||||||
|
|
||||||
log.Printf("uniqueArtistTags length: %d", len(uniqueArtistTags))
|
|
||||||
|
|
||||||
for _, uniqueGeneralTag := range uniqueGeneralTags {
|
|
||||||
|
|
||||||
log.Printf("TagType: General - Tag: %s", uniqueGeneralTag)
|
|
||||||
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueGeneralTag, "general")
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for _, uniqueCharacterTag := range uniqueCharacterTags {
|
|
||||||
log.Printf("TagType: Character - Tag: %s", uniqueCharacterTag)
|
|
||||||
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueCharacterTag, "character")
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
}
|
||||||
}
|
return nil
|
||||||
|
|
||||||
for _, uniqueCopyrightTag := range uniqueCopyrightTags {
|
|
||||||
log.Printf("TagType: Copyright - Tag: %s", uniqueCopyrightTag)
|
|
||||||
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueCopyrightTag, "copyright")
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, uniqueArtistTag := range uniqueArtistTags {
|
|
||||||
log.Printf("TagType: Artist - Tag: %s", uniqueArtistTag)
|
|
||||||
err := neo4jAPI.CreateTagNode(ctx, driver, uniqueArtistTag, "artist")
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,7 @@ func CreateSourceNode(ctx context.Context, driver neo4j.DriverWithContext, URL s
|
|||||||
RETURN u
|
RETURN u
|
||||||
`
|
`
|
||||||
params := map[string]any{
|
params := map[string]any{
|
||||||
"URL": URL,
|
"url": URL,
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err := neo4j.ExecuteQuery(ctx, driver, query, params, neo4j.EagerResultTransformer)
|
_, err := neo4j.ExecuteQuery(ctx, driver, query, params, neo4j.EagerResultTransformer)
|
||||||
|
Reference in New Issue
Block a user