Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[WIP] Develop merge #308

Open
wants to merge 127 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
127 commits
Select commit Hold shift + click to select a range
394e9da
Working on Pebble BulkLoad stutter
kellrott Feb 2, 2024
b2a5c07
Starting to abstract structures in GDBI to better support different d…
kellrott Feb 7, 2024
88aa084
Adding missing files
kellrott Feb 7, 2024
ddf6dee
Fixing reference issues and move old test code
kellrott Feb 7, 2024
37b04e3
Adding verbose output option to server and fixing pebble bulk insert …
kellrott Feb 7, 2024
0f69c26
Simplifying `select` command and removing alternate use, which is bet…
kellrott Feb 7, 2024
531cdb9
Fixing issue with serialization of base traveler. Added a bunch of ru…
kellrott Feb 8, 2024
ee443ff
Debugging output check optimizer and cleaning up debug logging
kellrott Feb 9, 2024
c3798d0
Adjusting unit tests to remove outdated elements
kellrott Feb 9, 2024
d526ab6
Starting to refactor mongo data storage, to eliminate using the `data…
kellrott Feb 9, 2024
e4ba0b1
Fixing hasLabel bug
kellrott Feb 9, 2024
d75e125
Fixing schema sampling
kellrott Feb 9, 2024
e5bb94c
Adding missing file
kellrott Feb 9, 2024
0ab3ae1
Fixing various issues in the engines
kellrott Feb 9, 2024
5cabbd1
Working on issues conformance test issues
kellrott Feb 16, 2024
610803b
Fixing more conformance testing issues
kellrott Feb 16, 2024
eaef88e
Fixing various issues to get the key/value graph store to work
kellrott Feb 17, 2024
f52dce8
Fixing small issues around gripper driver testing
kellrott Feb 17, 2024
c60a321
Merge pull request #302 from bmeg/mongo-remap
kellrott Feb 17, 2024
5357f73
Fixing issues around mongo engine
kellrott Feb 17, 2024
69c4867
Fixing additional issues to clear errors in mongo engine
kellrott Feb 18, 2024
942105b
Adding path conversion unit tests
kellrott Feb 18, 2024
0f84a35
Improving command line job submission utilities and fixing mongo core…
kellrott Feb 19, 2024
166f1f7
Fixing compiler options so job system can override data loading optim…
kellrott Feb 19, 2024
e1b19ad
Merge pull request #303 from bmeg/mongo-remap
kellrott Feb 19, 2024
7121f8d
Merge pull request #301 from bmeg/grids-update
kellrott Mar 15, 2024
370ca21
Upgrading Goja and adding some callback methods into javascript client
kellrott Mar 15, 2024
39ea894
Functions for js query engine
kellrott Mar 18, 2024
f725c92
Adding verbose option to query command
kellrott Mar 19, 2024
4df877b
Adding configuration for endpoints
kellrott Mar 20, 2024
ac185a0
Fixing go mod links
kellrott Mar 21, 2024
87975df
Merge pull request #307 from bmeg/feature/endpoint-config
kellrott Apr 4, 2024
804b1a5
Adding context variable to go client traversal
kellrott Apr 11, 2024
e350317
Merge branch 'develop' into feature/grip-client-context
kellrott Apr 11, 2024
09f1a55
Merge pull request #309 from bmeg/feature/grip-client-context
kellrott Apr 15, 2024
3b618e0
Adds jobC to gripql client
matthewpeterkort May 14, 2024
405906b
Adding pivot method to query engine
kellrott Jun 15, 2024
0cd94d3
Adding test files
kellrott Jun 15, 2024
ca228fc
Working on support for mongo engine compiler
kellrott Jun 15, 2024
eddeade
Switching pivot to key/value storage based system
kellrott Jun 20, 2024
27afef6
update to golangv1.21.12
matthewpeterkort Jul 12, 2024
93139c0
adds broken grip deps for reproducing error
matthewpeterkort Jul 15, 2024
a236329
update to 1.22.5
matthewpeterkort Jul 15, 2024
5a6ef93
protoc, lint updates
matthewpeterkort Jul 15, 2024
dc77113
Fix code, tests to work with updated cast package
matthewpeterkort Jul 16, 2024
f0f1023
fixes
matthewpeterkort Jul 16, 2024
2148c7b
fix Mongo test
matthewpeterkort Jul 17, 2024
c245cf6
fix
matthewpeterkort Jul 17, 2024
d391505
bugfix
matthewpeterkort Jul 17, 2024
0d2e05c
Address feedback
matthewpeterkort Jul 18, 2024
aeb30de
Merge pull request #313 from bmeg/update/golang
kellrott Jul 18, 2024
eea63a6
Merge remote-tracking branch 'origin/develop' into feature/pivot
kellrott Jul 19, 2024
b008c92
Working on the docs
kellrott Jul 19, 2024
cf1d997
Adding `_id` field to pivot outputs
kellrott Jul 30, 2024
40967a7
Fixing _id output
kellrott Jul 30, 2024
8a922de
Adding bulk delete
matthewpeterkort Aug 2, 2024
6e1d980
Adding server functions
matthewpeterkort Aug 2, 2024
afaf151
package up
matthewpeterkort Aug 5, 2024
1d18818
debug statements
matthewpeterkort Aug 5, 2024
b172cf7
Merge pull request #312 from bmeg/feature/pivot
kellrott Aug 5, 2024
d0b3a78
Make bulk del a unary operation
matthewpeterkort Aug 6, 2024
ee9be35
fix bulk delete
matthewpeterkort Aug 6, 2024
b0392dd
adds test
matthewpeterkort Aug 6, 2024
29752ea
Merge branch 'develop' into feature/BulkDelete
matthewpeterkort Aug 7, 2024
f93ecbb
update test
matthewpeterkort Aug 7, 2024
9bf7ca1
fix proto
matthewpeterkort Aug 7, 2024
ab51dee
Optimize Mongo bulk delete
matthewpeterkort Aug 8, 2024
2d5367d
fix protoc body
matthewpeterkort Aug 12, 2024
2d17195
fix mongo test
matthewpeterkort Aug 12, 2024
359a032
add suggested args
matthewpeterkort Aug 12, 2024
99c314b
Merge pull request #315 from bmeg/feature/BulkDelete
kellrott Aug 12, 2024
73a7584
Adds support for sqlite
matthewpeterkort Sep 17, 2024
6ce3de0
update test workflow
matthewpeterkort Sep 17, 2024
529684b
fix action test names
matthewpeterkort Sep 17, 2024
b163abb
Merge pull request #317 from bmeg/feature/sqlite
kellrott Oct 3, 2024
42de601
Start JSON schema loader into grip graph
matthewpeterkort Oct 22, 2024
f9cf8f4
Add support for extensions
matthewpeterkort Oct 22, 2024
9a800dc
cleanup vertex generation
matthewpeterkort Oct 23, 2024
b9da7be
Add edge generation
matthewpeterkort Oct 23, 2024
5f507f8
Adds schema load command
matthewpeterkort Nov 1, 2024
c1ee086
start implement json load
matthewpeterkort Nov 1, 2024
7051f51
working json loader
matthewpeterkort Nov 13, 2024
be854ce
cleanup, add support for graph and project-id customization
matthewpeterkort Nov 14, 2024
1fcac9f
Adds tests, new schema load method
matthewpeterkort Nov 15, 2024
f4ae5df
trim down test data size
matthewpeterkort Nov 15, 2024
c9f36fe
bug fix
matthewpeterkort Nov 15, 2024
694ef9d
bug fix
matthewpeterkort Nov 15, 2024
f11f79e
cleanup
matthewpeterkort Nov 15, 2024
0e7ce90
fix schema dataset
matthewpeterkort Nov 15, 2024
7351ace
fix logs
matthewpeterkort Nov 15, 2024
14f0a58
Bug fix auth test
matthewpeterkort Nov 18, 2024
bb2b9dd
Adds more tests
matthewpeterkort Nov 18, 2024
821431f
Add server err message response
matthewpeterkort Nov 19, 2024
a7f6fdd
fix tests
matthewpeterkort Nov 19, 2024
b8d9a0a
Remove elasticSearch from grip
matthewpeterkort Nov 20, 2024
a3ff902
Bugfix protobuf definition
matthewpeterkort Nov 20, 2024
515a682
bugfix, rename cmd
matthewpeterkort Nov 22, 2024
67d787e
factor out project_id into an optional extra arg
matthewpeterkort Nov 30, 2024
007f2fc
fix docs hostname and schema import name
matthewpeterkort Dec 3, 2024
9537849
fix double slash in paths
matthewpeterkort Dec 4, 2024
3bb0fde
remove extra file
matthewpeterkort Dec 4, 2024
a1646b0
Flesh out jsonschema to graphql schema command
matthewpeterkort Dec 10, 2024
146c50e
fixup graphql schema generation
matthewpeterkort Dec 11, 2024
b772ede
fix up cmd args to work with jsonschemagraph changes
matthewpeterkort Dec 11, 2024
1eed29a
Make go.mod versions compatible with grip plugin versions and move gr…
matthewpeterkort Dec 12, 2024
e938d18
Add support for yaml schemas, change AddSchema to an upsert operation
matthewpeterkort Jan 2, 2025
f365481
clean up / improve tests
matthewpeterkort Jan 2, 2025
683df7a
cleanup
matthewpeterkort Jan 2, 2025
c2dbbc7
cleanup
matthewpeterkort Jan 2, 2025
9654ae9
Add gripql query function calls
matthewpeterkort Jan 2, 2025
a231289
Merge pull request #318 from bmeg/feature/fhir-json-schema
kellrott Jan 3, 2025
bbc42ac
Working on core engine implementation of group function
kellrott Jan 8, 2025
a9b890d
Fixing query optimization for the new operation
kellrott Jan 8, 2025
9c733bf
Adding the group method to the mongo engine
kellrott Jan 9, 2025
0eed461
Fixing some of the graph inspection related to new method
kellrott Jan 9, 2025
90275c0
Updating javascript client and docs
kellrott Jan 9, 2025
25c183b
Simplifying the protobuff for the group method
kellrott Jan 9, 2025
e36be9a
Adding test for multiple collections during group method
kellrott Jan 9, 2025
338a4f1
add failing test
matthewpeterkort Jan 9, 2025
0f2fcda
Add engine support for totype operation
matthewpeterkort Jan 11, 2025
a928d0a
add mongo totype logic
matthewpeterkort Jan 11, 2025
c856023
add gripql print statements
matthewpeterkort Jan 12, 2025
396e42f
Merge pull request #320 from bmeg/feature/to-type
kellrott Jan 14, 2025
20e7f63
update to proto 5.29.3, make nil renders return nil
matthewpeterkort Jan 14, 2025
337df00
Merge pull request #319 from bmeg/feature/group
kellrott Jan 15, 2025
0fc1119
fixes an issue where unwind doesn't work on null map of outNull
matthewpeterkort Jan 17, 2025
b04bd8d
Merge pull request #321 from bmeg/fix/outNull-unwind
kellrott Jan 17, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
99 changes: 47 additions & 52 deletions .github/workflows/tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,18 +13,18 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Set up Go 1.x
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version: ^1.18
go-version: ^1.22.6

- name: Check out code into the Go module directory
uses: actions/checkout@v2
uses: actions/checkout@v4

- name: Build
run: go build -v ./

- name: Store grip
uses: actions/upload-artifact@v2
uses: actions/upload-artifact@v4
with:
name: gripBin
path: grip
Expand All @@ -35,28 +35,27 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Set up Go 1.x
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version: ^1.18
go-version: ^1.22.6
- name: Check out code
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: run unit tests
run: |
go test ./test/... -config badger.yml




badgerTest:
needs: build
name: Badger Conformance
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Python Dependencies for Conformance
run: pip install requests numpy
- name: Download grip
uses: actions/download-artifact@v2
uses: actions/download-artifact@v4
with:
name: gripBin
- name: Badger Test
Expand All @@ -65,19 +64,19 @@ jobs:
./grip server --rpc-port 18202 --http-port 18201 --config ./test/badger.yml &
sleep 5
make test-conformance


pebbleTest:
needs: build
name: Pebble Conformance
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Python Dependencies for Conformance
run: pip install requests numpy
- name: Download grip
uses: actions/download-artifact@v2
uses: actions/download-artifact@v4
with:
name: gripBin
- name: Pebble Test
Expand All @@ -86,19 +85,19 @@ jobs:
./grip server --rpc-port 18202 --http-port 18201 --config ./test/pebble.yml &
sleep 5
make test-conformance


mongoTest:
needs: build
name: Mongo Test
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Python Dependencies for Conformance
run: pip install requests numpy
- name: Download grip
uses: actions/download-artifact@v2
uses: actions/download-artifact@v4
with:
name: gripBin
- name: Mongo Conformance
Expand All @@ -108,89 +107,86 @@ jobs:
./grip server --rpc-port 18202 --http-port 18201 --config ./test/mongo.yml &
sleep 5
make test-conformance


mongoCoreTest:
needs: build
name: Mongo Core Test
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Python Dependencies for Conformance
run: pip install requests numpy
- name: Download grip
uses: actions/download-artifact@v2
uses: actions/download-artifact@v4
with:
name: gripBin
- name: Mongo Conformance
- name: Mongo Core Conformance
run: |
chmod +x grip
make start-mongo
./grip server --rpc-port 18202 --http-port 18201 --config ./test/mongo-core-processor.yml &
sleep 5
make test-conformance


elasticTest:
postgresTest:
needs: build
name: Elastic Test
name: Postgres Test
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Python Dependencies for Conformance
run: pip install requests numpy
- name: Download grip
uses: actions/download-artifact@v2
uses: actions/download-artifact@v4
with:
name: gripBin
- name: Elastic Conformance
- name: Postgres Conformance
run: |
chmod +x grip
make start-elastic
make start-postgres
sleep 15
./grip server --rpc-port 18202 --http-port 18201 --config ./test/elastic.yml &
./grip server --rpc-port 18202 --http-port 18201 --config ./test/psql.yml &
sleep 5
make test-conformance
python conformance/run_conformance.py http://localhost:18201 --exclude index aggregations


portgresTest:
sqliteTest:
needs: build
name: Portgres Test
name: Sqlite Test
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Python Dependencies for Conformance
run: pip install requests numpy
- name: Download grip
uses: actions/download-artifact@v2
uses: actions/download-artifact@v4
with:
name: gripBin
- name: Postgres Conformance
- name: Sqlite Conformance
run: |
chmod +x grip
make start-postgres
sleep 15
./grip server --rpc-port 18202 --http-port 18201 --config ./test/psql.yml &
./grip server --rpc-port 18202 --http-port 18201 --config ./test/sqlite.yml &
sleep 5
python conformance/run_conformance.py http://localhost:18201 --exclude index aggregations


gripperTest:
needs: build
name: Gripper Test
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Update pip
run: pip install --upgrade pip
- name: Python Dependencies for Conformance
run: pip install -U requests numpy grpcio-tools protobuf
- name: Download grip
uses: actions/download-artifact@v2
uses: actions/download-artifact@v4
with:
name: gripBin
- name: Gripper Conformance
Expand All @@ -210,11 +206,11 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Python Dependencies for Conformance
run: pip install requests numpy PyYAML
- name: Download grip
uses: actions/download-artifact@v2
uses: actions/download-artifact@v4
with:
name: gripBin
- name: Auth Test
Expand All @@ -224,30 +220,29 @@ jobs:
./grip server --rpc-port 18202 --http-port 18201 --config ./test/badger-auth.yml &
sleep 5
# simple auth
# run tests without credentials, should fail
# run tests without credentials, should fail
if make test-conformance
then
echo "ERROR: Conformance tests ran without credentials." ; exit 1
else
echo "Got expected auth error"
fi
echo "Got expected auth error"
fi
# run specialized role based tests
make test-authorization ARGS="--grip_config_file_path test/badger-auth.yml"






#gridsTest:
# needs: build
# name: GRIDs Conformance
# runs-on: ubuntu-latest
# steps:
# - name: Check out code
# uses: actions/checkout@v2
# uses: actions/checkout@v4
# - name: Python Dependencies for Conformance
# run: pip install requests numpy
# - name: Download grip
# uses: actions/download-artifact@v2
# uses: actions/download-artifact@v4
# with:
# name: gripBin
# - name: GRIDs unit tests
Expand Down
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -35,3 +35,4 @@ gripql/R/*.tar.gz
# dev tools
.idea/
.vscode/
.DS_Store
19 changes: 8 additions & 11 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ proto:
--go_opt paths=source_relative \
--go-grpc_out ./ \
--go-grpc_opt paths=source_relative \
--grpc-gateway_out ./ \
--grpc-gateway_out allow_delete_body=true:./ \
--grpc-gateway_opt logtostderr=true \
--grpc-gateway_opt paths=source_relative \
--grpc-rest-direct_out . \
Expand All @@ -66,11 +66,12 @@ proto:

proto-depends:
@git submodule update --init --recursive
@go install github.com/grpc-ecosystem/grpc-gateway/v2/[email protected]
@go install github.com/grpc-ecosystem/grpc-gateway/v2/[email protected]
@go install google.golang.org/protobuf/cmd/[email protected]
@go install github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-grpc-gateway@latest
@go install github.com/akuity/grpc-gateway-client/protoc-gen-grpc-gateway-client
@go install github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-openapiv2@latest
@go install google.golang.org/protobuf/cmd/[email protected]
@go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@latest
@go install github.com/ckaznocha/protoc-gen-lint@v0.2.4
@go install github.com/ckaznocha/protoc-gen-lint@latest
@go install github.com/bmeg/protoc-gen-grpc-rest-direct@latest
@go install github.com/ckaznocha/protoc-gen-lint@latest

Expand All @@ -91,7 +92,7 @@ lint:
flake8 gripql/python/ conformance/

lint-depends:
go get github.com/golangci/golangci-lint/cmd/golangci-lint@v1.35.2
go get github.com/golangci/golangci-lint/cmd/golangci-lint@v1.59.1
go install golang.org/x/tools/cmd/goimports

# ---------------------
Expand Down Expand Up @@ -129,11 +130,7 @@ test-authorization:
# ---------------------
start-mongo:
@docker rm -f grip-mongodb-test > /dev/null 2>&1 || echo
docker run -d --name grip-mongodb-test -p 27017:27017 docker.io/mongo:3.6.4 > /dev/null

start-elastic:
@docker rm -f grip-es-test > /dev/null 2>&1 || echo
docker run -d --name grip-es-test -p 19200:9200 -p 9300:9300 -e "discovery.type=single-node" -e "xpack.security.enabled=false" docker.elastic.co/elasticsearch/elasticsearch:5.6.3 > /dev/null
docker run -d --name grip-mongodb-test -p 27017:27017 mongo:7.0.13-rc0-jammy > /dev/null

start-postgres:
@docker rm -f grip-postgres-test > /dev/null 2>&1 || echo
Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@

https://bmeg.github.io/grip/

GRIP stands for GRaph Integration Platform. It provides a graph interface on top of a variety of existing database technologies including: MongoDB, Elasticsearch, PostgreSQL, MySQL, MariaDB, Badger, and LevelDB.
GRIP stands for GRaph Integration Platform. It provides a graph interface on top of a variety of existing database technologies including: MongoDB, PostgreSQL, MySQL, MariaDB, Badger, and LevelDB.

Properties of an GRIP graph:

Expand Down
44 changes: 44 additions & 0 deletions accounts/bulk_write_filter.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,3 +52,47 @@ func (bw *BulkWriteFilter) RecvMsg(m interface{}) error {
}
}
}

type BulkWriteRawFilter struct {
SS grpc.ServerStream
User string
Access Access
}

func (bw *BulkWriteRawFilter) SetHeader(m metadata.MD) error {
return bw.SS.SendHeader(m)
}

func (bw *BulkWriteRawFilter) SendHeader(m metadata.MD) error {
return bw.SS.SendHeader(m)
}

func (bw *BulkWriteRawFilter) SetTrailer(m metadata.MD) {
bw.SS.SetTrailer(m)
}

func (bw *BulkWriteRawFilter) Context() context.Context {
return bw.SS.Context()
}

func (bw *BulkWriteRawFilter) SendMsg(m interface{}) error {
return bw.SS.SendMsg(m)
}

func (bw *BulkWriteRawFilter) RecvMsg(m interface{}) error {
for {
var ge gripql.RawJson
err := bw.SS.RecvMsg(&ge)
if err != nil {
return err
}
err = bw.Access.Enforce(bw.User, ge.Graph, Write)
if err == nil {
mPtr := m.(*gripql.RawJson)
*mPtr = ge
return nil
} else {
log.Infof("Graph write error: %s", ge.Graph)
}
}
}
Loading
Loading