-
Notifications
You must be signed in to change notification settings - Fork 0
/
list.go
31 lines (25 loc) · 784 Bytes
/
list.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
package sql_node_repository
import (
"context"
"github.com/awlsring/texit/internal/pkg/domain/node"
"github.com/awlsring/texit/internal/pkg/logger"
)
func (r *SqlNodeRepository) List(ctx context.Context) ([]*node.Node, error) {
log := logger.FromContext(ctx)
log.Debug().Msg("Listing nodes from sqlite database")
var dbn []*NodeSqlRecord
query := "SELECT * FROM nodes"
log.Debug().Msgf("Query: %s", query)
err := r.db.SelectContext(ctx, &dbn, query)
if err != nil {
log.Error().Err(err).Msg("Failed to list nodes from sqlite database")
return nil, err
}
log.Debug().Msg("Converting nodes from sqlite")
nodes := make([]*node.Node, len(dbn))
for i, n := range dbn {
nodes[i] = n.ToNode()
}
log.Debug().Msgf("Returning nodes: %s", query)
return nodes, nil
}