googleDatastore
Utility class to interact with Google Datastore
Last updated
Utility class to interact with Google Datastore
Last updated
Get a Google Datastore entity
googleDatastore.getEntity({entityName, entityKey})
entityName
datastore entity group name
entityKey
entity key
returns a Promise.
const entityName = "MASTER";
const entityKey = "PIPPO"
}
const ret = googleDatastore.getEntity({entityName, entityKey)
.then((res) => {
//..
Insert a Google Datastore Entity
googleDatastore.insertEntity({entityName,entity,entityAttributes})
entityName
datastore entity group name
entity
entity object
entityAttributes
map attribute - type
return a Promise
const insertPars = {
entityName: "MASTER",
entity: {
"name": "PIPPO",
"createDate": "2022-09-08 00:00:00"
},
entityAttributes: {
name: {
type: "string",
isPk: true
},
createDate: {
type: "date"
}
}
}
const ret = googleDatastore.insertEntity(insertPars)
.then((res) => {
//Logiche per success true o false
})
.catch((err) => {
//Logica per catch dell'errore
});
Update a Google Datastore Entity.
googleDatastore.updateEntity({entityName, entityKey, entityObj, entityAttributes, forceNullFields})
entityName
datastore entity group name
entityKey
entity key
entityObj
object to save
entityAttributes
map attribute - type
forceNullFields
force not pass field to null
return a Promise
const updatePars = {
entityName: "MASTER",
entityKey: "PIPPO",
entityObj:{
"name": "PIPPO",
"createDate": "2022-09-08 00:00:00",
"lastUpdate": "2022-09-15 00:00:00"
},
entityAttributes: {
name: {
type: "string",
isPk: true
},
createDate: {
type: "date"
},
lastUpdate: {
type: "date"
}
},
forceNullFields: false
};
const ret = googleDatastore.updateEntity(updatePars)
.then((res) => {
//Logiche per success true o false
})
.catch((err) => {
//Logica per catch dell'errore
});
Delete a Google Datastore entity
googleDatastore.deleteEntity({entityName, entityKey})
entityName
datastore entity group name
entityKey
entity to delete key
return a Promise
const deletePars = {
entityName: "MASTER",
entityKey: "PIPPO"
}
const ret = googleDatastore.deleteEntity(deletePars)
.then((res) => {
//Logiche per success true o false
})
.catch((err) => {
//Logica per catch dell'errore
});
Return a list of entities
googleDatastore.list
[select]
fields to extract
entityName
datastore entity group name
[filters]
array of filter objects:
property
property to filter
value
filter value
[operator]
filter operator, default =
[order]
order object
property
property to order
[descending]
true
: descending,
limit
[offset]
return a Promise
In case the query searches only some fields or in case some sortings are necessary, it will be necessary to create indexes: if you are curious to understand how they work, check here: Indexes. If, you have already started using them and want to understand how to optimize them: Index optimization
//return first 10 entity
const pars = {
"entityName": "MASTER",
"limit": 10
}
const res = googleDatastore.list(pars)
.then((res) => {
//Logiche per success true o false
})
.catch((err) => {
//Logica per catch dell'errore
});
//return first 10 entity order by createDate desc
const pars = {
"entityName": "MASTER",
"limit": 10,
"order": {
"property": "createDate",
"descending": true
}
}
const res = googleDatastore.list(pars)
.then((res) => {
//Logiche per success true o false
})
.catch((err) => {
//Logica per catch dell'errore
});
false
false