This plugin allow you to perform grpc call from your vuex orm models
npm install @vuex-orm/core vuex-orm-grpc --save
import Vue from "vue";
import Vuex from "vuex";
import VuexORM from "@vuex-orm/core";
import VuexOrmGrpc from "vuex-orm-grpc";
Vue.use(Vuex);
VuexORM.use(VuexOrmGrpc);
import {Model} from "@vuex-orm/core";
export default class Pamphlet extends Model {
static entity = "Pamphlet";
static controller = "PamphletController";
static grpcWebPb = require("@/grpc/generated/pamhplet_grpc_web_pb");
static grpcOptions = {
url: "http://localhost:8082",
credentials: null,
options: null
};
static primaryKey = "uuid";
static fields() {
return {
uuid: this.uid(),
code: this.string(),
createdAt: this.string(),
updatedAt: this.string(),
modifiedBy: this.string(),
isArchived: this.boolean()
};
}
}
You can access all of your grpc services with grpc() attribute
Pamphlet.grpc()
.list(Pamphlet.grpc().PamphletListRequest, {})
.then(r => {
console.log(r.toObject())
Pamphlet.insert({
data: r.toObject().resultsList
});
})
.catch(error => {
throw new Error(error);
});
Your instance contain .$toProto() function who convert your model instance to an proto requester object. The requester is set by Model.entity attribute.
let pamphlet = new Pamphlet();
pamphlet.isArchived = false;
pamphlet.code = "Foo";
Pamphlet.grpc()
.create(pamphlet.$toProto(), {})
.then(r => {
Pamphlet.insert({
data: r.toObject()
});
})
.catch(error => {
throw new Error(error);
});