@things-factory/operato-board 9.0.0-beta.9 → 9.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -7,61 +7,8 @@ import { connect } from 'pwa-helpers';
7
7
  import { store } from '@operato/shell';
8
8
  import { privileged } from '@things-factory/auth-base/dist-client';
9
9
  let MenuTools = class MenuTools extends connect(store)(LitElement) {
10
- render() {
11
- return this.context && this.context['board_topmenu']
12
- ? html `
13
- <ul>
14
- <li>
15
- <a href="board-list" ?active=${this.page == 'board-list'}>
16
- <md-icon>dvr</md-icon>
17
- <div><ox-i18n msgid="label.board"></ox-i18n></div>
18
- </a>
19
- </li>
20
- <li>
21
- <a href="play-list" ?active=${this.page == 'play-list'}>
22
- <md-icon>airplay</md-icon>
23
- <div><ox-i18n msgid="label.player"></ox-i18n></div>
24
- </a>
25
- </li>
26
- ${privileged({ privilege: 'mutation', category: 'board' }, html `
27
- <li>
28
- <a href="board-template-list" ?active=${this.page == 'board-template-list'}>
29
- <md-icon>developer_board</md-icon>
30
- <div><ox-i18n msgid="label.template"></ox-i18n></div>
31
- </a>
32
- </li>
33
- <li>
34
- <a href="attachment-list" ?active=${this.page == 'attachment-list'}>
35
- <md-icon>attachment</md-icon>
36
- <div><ox-i18n msgid="label.attachment"></ox-i18n></div>
37
- </a>
38
- </li>
39
- <li>
40
- <a href="connection-list" ?active=${this.page == 'connection-list'}>
41
- <md-icon>device_hub</md-icon>
42
- <div><ox-i18n msgid="label.connection"></ox-i18n></div>
43
- </a>
44
- </li>
45
- <li>
46
- <a href="scenario-list" ?active=${this.page == 'scenario-list'}>
47
- <md-icon>format_list_numbered</md-icon>
48
- <div><ox-i18n msgid="label.scenario"></ox-i18n></div>
49
- </a>
50
- </li>
51
- </ul>
52
- `)}
53
- </ul>
54
- `
55
- : html ``;
56
- }
57
- stateChanged(state) {
58
- this.page = state.route.page;
59
- this.width = state.layout.width;
60
- this.context = state.route.context;
61
- }
62
- };
63
- MenuTools.styles = [
64
- css `
10
+ static { this.styles = [
11
+ css `
65
12
  :host {
66
13
  display: flex;
67
14
  background-color: var(--menu-tools-background-color);
@@ -122,7 +69,60 @@ MenuTools.styles = [
122
69
  font-size: 0.6em;
123
70
  }
124
71
  `
125
- ];
72
+ ]; }
73
+ render() {
74
+ return this.context && this.context['board_topmenu']
75
+ ? html `
76
+ <ul>
77
+ <li>
78
+ <a href="board-list" ?active=${this.page == 'board-list'}>
79
+ <md-icon>dvr</md-icon>
80
+ <div><ox-i18n msgid="label.board"></ox-i18n></div>
81
+ </a>
82
+ </li>
83
+ <li>
84
+ <a href="play-list" ?active=${this.page == 'play-list'}>
85
+ <md-icon>airplay</md-icon>
86
+ <div><ox-i18n msgid="label.player"></ox-i18n></div>
87
+ </a>
88
+ </li>
89
+ ${privileged({ privilege: 'mutation', category: 'board' }, html `
90
+ <li>
91
+ <a href="board-template-list" ?active=${this.page == 'board-template-list'}>
92
+ <md-icon>developer_board</md-icon>
93
+ <div><ox-i18n msgid="label.template"></ox-i18n></div>
94
+ </a>
95
+ </li>
96
+ <li>
97
+ <a href="attachment-list" ?active=${this.page == 'attachment-list'}>
98
+ <md-icon>attachment</md-icon>
99
+ <div><ox-i18n msgid="label.attachment"></ox-i18n></div>
100
+ </a>
101
+ </li>
102
+ <li>
103
+ <a href="connection-list" ?active=${this.page == 'connection-list'}>
104
+ <md-icon>device_hub</md-icon>
105
+ <div><ox-i18n msgid="label.connection"></ox-i18n></div>
106
+ </a>
107
+ </li>
108
+ <li>
109
+ <a href="scenario-list" ?active=${this.page == 'scenario-list'}>
110
+ <md-icon>format_list_numbered</md-icon>
111
+ <div><ox-i18n msgid="label.scenario"></ox-i18n></div>
112
+ </a>
113
+ </li>
114
+ </ul>
115
+ `)}
116
+ </ul>
117
+ `
118
+ : html ``;
119
+ }
120
+ stateChanged(state) {
121
+ this.page = state.route.page;
122
+ this.width = state.layout.width;
123
+ this.context = state.route.context;
124
+ }
125
+ };
126
126
  __decorate([
127
127
  property({ type: String }),
128
128
  __metadata("design:type", String)
@@ -1 +1 @@
1
- {"version":3,"file":"menu-tools.js","sourceRoot":"","sources":["../../client/viewparts/menu-tools.ts"],"names":[],"mappings":";AAAA,OAAO,4BAA4B,CAAA;AACnC,OAAO,0BAA0B,CAAA;AAEjC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AACtC,OAAO,EAAE,UAAU,EAAE,MAAM,uCAAuC,CAAA;AAG3D,IAAM,SAAS,GAAf,MAAM,SAAU,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC;IAqEvD,MAAM;QACJ,OAAO,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC;YAClD,CAAC,CAAC,IAAI,CAAA;;;6CAGiC,IAAI,CAAC,IAAI,IAAI,YAAY;;;;;;4CAM1B,IAAI,CAAC,IAAI,IAAI,WAAW;;;;;cAKtD,UAAU,CACV,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,EAC5C,IAAI,CAAA;;sDAEoC,IAAI,CAAC,IAAI,IAAI,qBAAqB;;;;;;kDAMtC,IAAI,CAAC,IAAI,IAAI,iBAAiB;;;;;;kDAM9B,IAAI,CAAC,IAAI,IAAI,iBAAiB;;;;;;gDAMhC,IAAI,CAAC,IAAI,IAAI,eAAe;;;;;;aAM/D,CACA;;SAEJ;YACH,CAAC,CAAC,IAAI,CAAA,EAAE,CAAA;IACZ,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAA;QAC5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAA;QAC/B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAA;IACpC,CAAC;;AA3HM,gBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA4DF;CACF,AA9DY,CA8DZ;AAE2B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;uCAAc;AACE;IAA1C,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;;wCAAe;AAC7B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;0CAAa;AAnE7B,SAAS;IADrB,aAAa,CAAC,YAAY,CAAC;GACf,SAAS,CA6HrB","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@operato/i18n/ox-i18n.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers'\n\nimport { store } from '@operato/shell'\nimport { privileged } from '@things-factory/auth-base/dist-client'\n\n@customElement('menu-tools')\nexport class MenuTools extends connect(store)(LitElement) {\n static styles = [\n css`\n :host {\n display: flex;\n background-color: var(--menu-tools-background-color);\n\n /* for narrow mode */\n flex-direction: column;\n width: 100%;\n }\n\n :host([width='WIDE']) {\n /* for wide mode */\n flex-direction: row;\n width: initial;\n height: 100%;\n }\n\n ul {\n display: flex;\n flex-direction: row;\n\n margin: auto;\n padding: 0;\n list-style: none;\n height: 100%;\n overflow: none;\n }\n\n :host([width='WIDE']) ul {\n flex-direction: column;\n }\n\n :host([width='WIDE']) li {\n border-top: 1px solid rgba(255, 255, 255, 0.1);\n border-bottom: 1px solid rgba(0, 0, 0, 0.1);\n }\n\n a {\n display: block;\n padding: 5px 0px;\n text-align: center;\n text-decoration: none;\n color: var(--menu-tools-color);\n }\n\n a[active] {\n color: var(--menu-tools-active-color);\n background-color: rgba(0, 0, 0, 0.2);\n }\n\n md-icon {\n font-variation-settings: 'FILL' 0;\n\n padding: 5px 15px 0px 15px;\n vertical-align: bottom;\n }\n\n div {\n font-size: 0.6em;\n }\n `\n ]\n\n @property({ type: String }) page?: string\n @property({ type: String, reflect: true }) width?: string\n @property({ type: Object }) context: any\n\n render() {\n return this.context && this.context['board_topmenu']\n ? html`\n <ul>\n <li>\n <a href=\"board-list\" ?active=${this.page == 'board-list'}>\n <md-icon>dvr</md-icon>\n <div><ox-i18n msgid=\"label.board\"></ox-i18n></div>\n </a>\n </li>\n <li>\n <a href=\"play-list\" ?active=${this.page == 'play-list'}>\n <md-icon>airplay</md-icon>\n <div><ox-i18n msgid=\"label.player\"></ox-i18n></div>\n </a>\n </li>\n ${privileged(\n { privilege: 'mutation', category: 'board' },\n html`\n <li>\n <a href=\"board-template-list\" ?active=${this.page == 'board-template-list'}>\n <md-icon>developer_board</md-icon>\n <div><ox-i18n msgid=\"label.template\"></ox-i18n></div>\n </a>\n </li>\n <li>\n <a href=\"attachment-list\" ?active=${this.page == 'attachment-list'}>\n <md-icon>attachment</md-icon>\n <div><ox-i18n msgid=\"label.attachment\"></ox-i18n></div>\n </a>\n </li>\n <li>\n <a href=\"connection-list\" ?active=${this.page == 'connection-list'}>\n <md-icon>device_hub</md-icon>\n <div><ox-i18n msgid=\"label.connection\"></ox-i18n></div>\n </a>\n </li>\n <li>\n <a href=\"scenario-list\" ?active=${this.page == 'scenario-list'}>\n <md-icon>format_list_numbered</md-icon>\n <div><ox-i18n msgid=\"label.scenario\"></ox-i18n></div>\n </a>\n </li>\n </ul>\n `\n )}\n </ul>\n `\n : html``\n }\n\n stateChanged(state) {\n this.page = state.route.page\n this.width = state.layout.width\n this.context = state.route.context\n }\n}\n"]}
1
+ {"version":3,"file":"menu-tools.js","sourceRoot":"","sources":["../../client/viewparts/menu-tools.ts"],"names":[],"mappings":";AAAA,OAAO,4BAA4B,CAAA;AACnC,OAAO,0BAA0B,CAAA;AAEjC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AACtC,OAAO,EAAE,UAAU,EAAE,MAAM,uCAAuC,CAAA;AAG3D,IAAM,SAAS,GAAf,MAAM,SAAU,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC;aAChD,WAAM,GAAG;QACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA4DF;KACF,AA9DY,CA8DZ;IAMD,MAAM;QACJ,OAAO,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC;YAClD,CAAC,CAAC,IAAI,CAAA;;;6CAGiC,IAAI,CAAC,IAAI,IAAI,YAAY;;;;;;4CAM1B,IAAI,CAAC,IAAI,IAAI,WAAW;;;;;cAKtD,UAAU,CACV,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,EAC5C,IAAI,CAAA;;sDAEoC,IAAI,CAAC,IAAI,IAAI,qBAAqB;;;;;;kDAMtC,IAAI,CAAC,IAAI,IAAI,iBAAiB;;;;;;kDAM9B,IAAI,CAAC,IAAI,IAAI,iBAAiB;;;;;;gDAMhC,IAAI,CAAC,IAAI,IAAI,eAAe;;;;;;aAM/D,CACA;;SAEJ;YACH,CAAC,CAAC,IAAI,CAAA,EAAE,CAAA;IACZ,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAA;QAC5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAA;QAC/B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAA;IACpC,CAAC;;AA3D2B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;uCAAc;AACE;IAA1C,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;;wCAAe;AAC7B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;0CAAa;AAnE7B,SAAS;IADrB,aAAa,CAAC,YAAY,CAAC;GACf,SAAS,CA6HrB","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@operato/i18n/ox-i18n.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers'\n\nimport { store } from '@operato/shell'\nimport { privileged } from '@things-factory/auth-base/dist-client'\n\n@customElement('menu-tools')\nexport class MenuTools extends connect(store)(LitElement) {\n static styles = [\n css`\n :host {\n display: flex;\n background-color: var(--menu-tools-background-color);\n\n /* for narrow mode */\n flex-direction: column;\n width: 100%;\n }\n\n :host([width='WIDE']) {\n /* for wide mode */\n flex-direction: row;\n width: initial;\n height: 100%;\n }\n\n ul {\n display: flex;\n flex-direction: row;\n\n margin: auto;\n padding: 0;\n list-style: none;\n height: 100%;\n overflow: none;\n }\n\n :host([width='WIDE']) ul {\n flex-direction: column;\n }\n\n :host([width='WIDE']) li {\n border-top: 1px solid rgba(255, 255, 255, 0.1);\n border-bottom: 1px solid rgba(0, 0, 0, 0.1);\n }\n\n a {\n display: block;\n padding: 5px 0px;\n text-align: center;\n text-decoration: none;\n color: var(--menu-tools-color);\n }\n\n a[active] {\n color: var(--menu-tools-active-color);\n background-color: rgba(0, 0, 0, 0.2);\n }\n\n md-icon {\n font-variation-settings: 'FILL' 0;\n\n padding: 5px 15px 0px 15px;\n vertical-align: bottom;\n }\n\n div {\n font-size: 0.6em;\n }\n `\n ]\n\n @property({ type: String }) page?: string\n @property({ type: String, reflect: true }) width?: string\n @property({ type: Object }) context: any\n\n render() {\n return this.context && this.context['board_topmenu']\n ? html`\n <ul>\n <li>\n <a href=\"board-list\" ?active=${this.page == 'board-list'}>\n <md-icon>dvr</md-icon>\n <div><ox-i18n msgid=\"label.board\"></ox-i18n></div>\n </a>\n </li>\n <li>\n <a href=\"play-list\" ?active=${this.page == 'play-list'}>\n <md-icon>airplay</md-icon>\n <div><ox-i18n msgid=\"label.player\"></ox-i18n></div>\n </a>\n </li>\n ${privileged(\n { privilege: 'mutation', category: 'board' },\n html`\n <li>\n <a href=\"board-template-list\" ?active=${this.page == 'board-template-list'}>\n <md-icon>developer_board</md-icon>\n <div><ox-i18n msgid=\"label.template\"></ox-i18n></div>\n </a>\n </li>\n <li>\n <a href=\"attachment-list\" ?active=${this.page == 'attachment-list'}>\n <md-icon>attachment</md-icon>\n <div><ox-i18n msgid=\"label.attachment\"></ox-i18n></div>\n </a>\n </li>\n <li>\n <a href=\"connection-list\" ?active=${this.page == 'connection-list'}>\n <md-icon>device_hub</md-icon>\n <div><ox-i18n msgid=\"label.connection\"></ox-i18n></div>\n </a>\n </li>\n <li>\n <a href=\"scenario-list\" ?active=${this.page == 'scenario-list'}>\n <md-icon>format_list_numbered</md-icon>\n <div><ox-i18n msgid=\"label.scenario\"></ox-i18n></div>\n </a>\n </li>\n </ul>\n `\n )}\n </ul>\n `\n : html``\n }\n\n stateChanged(state) {\n this.page = state.route.page\n this.width = state.layout.width\n this.context = state.route.context\n }\n}\n"]}
@@ -145,15 +145,19 @@ class SeedRole1610516350460 {
145
145
  async up(queryRunner) {
146
146
  const repository = (0, shell_1.getRepository)(auth_base_1.Role);
147
147
  const userRepository = (0, shell_1.getRepository)(auth_base_1.User);
148
- let users = await userRepository.find({ where: { userType: 'admin' }, relations: ['domains'] });
148
+ let users = await userRepository.find({ where: { username: 'admin' }, relations: ['domains'] });
149
149
  let domain = await (0, shell_1.getRepository)(shell_1.Domain).findOneBy({
150
150
  name: 'SYSTEM'
151
151
  });
152
152
  var privilegeSeeds = [];
153
153
  Promise.all(SEED.map(async (role) => {
154
154
  var privileges = await this.getPrivileges(privilegeSeeds, role.name);
155
- await repository.save(Object.assign(Object.assign({}, role), { privileges: privileges, users,
156
- domain }));
155
+ await repository.save({
156
+ ...role,
157
+ privileges: privileges,
158
+ users,
159
+ domain
160
+ });
157
161
  }));
158
162
  await this.saveSystemRole(repository, users, domain);
159
163
  }
@@ -164,8 +168,12 @@ class SeedRole1610516350460 {
164
168
  description: 'System Admin'
165
169
  };
166
170
  var privileges = await privilegeRepository.find();
167
- await repository.save(Object.assign(Object.assign({}, role), { privileges: privileges, users,
168
- domain }));
171
+ await repository.save({
172
+ ...role,
173
+ privileges: privileges,
174
+ users,
175
+ domain
176
+ });
169
177
  }
170
178
  async getPrivileges(privilegeSeeds, roleName) {
171
179
  const privilegeRepository = (0, shell_1.getRepository)(auth_base_1.Privilege);
@@ -1 +1 @@
1
- {"version":3,"file":"1610516350460-SeedRole.js","sourceRoot":"","sources":["../../server/migrations/1610516350460-SeedRole.ts"],"names":[],"mappings":"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","sourcesContent":["import { MigrationInterface, QueryRunner } from 'typeorm'\n\nimport { Privilege, Role, User } from '@things-factory/auth-base'\nimport { Domain, getRepository } from '@things-factory/shell'\n\nconst PRIVILEGES_SEED = {\n modeller: [\n {\n name: 'mutation',\n category: 'setting'\n },\n {\n name: 'mutation',\n category: 'menu'\n },\n {\n name: 'mutation',\n category: 'user'\n },\n {\n name: 'mutation',\n category: 'appliance'\n },\n {\n name: 'mutation',\n category: 'appliance'\n },\n {\n name: 'mutation',\n category: 'application'\n },\n {\n name: 'mutation',\n category: 'board'\n },\n {\n name: 'mutation',\n category: 'group'\n },\n {\n name: 'mutation',\n category: 'play-group'\n },\n {\n name: 'mutation',\n category: 'fonts'\n },\n {\n name: 'mutation',\n category: 'attachment'\n },\n {\n name: 'mutation',\n category: 'scenario'\n },\n {\n name: 'mutation',\n category: 'step'\n },\n {\n name: 'query',\n category: 'setting'\n },\n {\n name: 'query',\n category: 'menu'\n },\n {\n name: 'query',\n category: 'user'\n },\n {\n name: 'query',\n category: 'appliance'\n },\n {\n name: 'query',\n category: 'application'\n },\n {\n name: 'query',\n category: 'board'\n },\n {\n name: 'query',\n category: 'group'\n },\n {\n name: 'query',\n category: 'play-group'\n },\n {\n name: 'query',\n category: 'fonts'\n },\n {\n name: 'query',\n category: 'attachment'\n },\n {\n name: 'query',\n category: 'scenario'\n },\n {\n name: 'query',\n category: 'step'\n }\n ],\n system: [\n {\n name: 'mutation',\n category: 'system'\n },\n {\n name: 'query',\n category: 'system'\n }\n ],\n viewer: [\n {\n name: 'query',\n category: 'board'\n },\n {\n name: 'query',\n category: 'group'\n },\n {\n name: 'query',\n category: 'play-group'\n }\n ]\n}\n\nconst SEED = [\n {\n name: 'modeller',\n description: 'Board Modeller'\n },\n {\n name: 'viewer',\n description: 'Board Viewer'\n }\n]\n\nexport class SeedRole1610516350460 implements MigrationInterface {\n public async up(queryRunner: QueryRunner): Promise<any> {\n const repository = getRepository(Role)\n const userRepository = getRepository(User)\n\n let users: User[] = await userRepository.find({ where: { userType: 'admin' }, relations: ['domains'] })\n let domain: Domain = await getRepository(Domain).findOneBy({\n name: 'SYSTEM'\n })\n\n var privilegeSeeds = []\n Promise.all(\n SEED.map(async role => {\n var privileges = await this.getPrivileges(privilegeSeeds, role.name)\n await repository.save({\n ...role,\n privileges: privileges,\n users,\n domain\n })\n })\n )\n await this.saveSystemRole(repository, users, domain)\n }\n\n public async saveSystemRole(repository, users, domain) {\n const privilegeRepository = getRepository(Privilege)\n var role = {\n name: 'system',\n description: 'System Admin'\n }\n var privileges = await privilegeRepository.find()\n await repository.save({\n ...role,\n privileges: privileges,\n users,\n domain\n })\n }\n\n public async getPrivileges(privilegeSeeds, roleName) {\n const privilegeRepository = getRepository(Privilege)\n privilegeSeeds = PRIVILEGES_SEED[roleName]\n var privileges = []\n await Promise.all(\n privilegeSeeds.map(async privilege => {\n var value = await privilegeRepository.findOne({ where: { name: privilege.name, category: privilege.category } })\n if (value) {\n privileges.push(value)\n }\n })\n )\n return privileges\n }\n\n public async down(queryRunner: QueryRunner): Promise<any> {\n const repository = getRepository(Role)\n const privilegeRepository = getRepository(Privilege)\n const domain: Domain = await getRepository(Domain).findOneBy({\n name: 'SYSTEM'\n })\n\n await Promise.all(\n SEED.reverse().map(async role => {\n await repository.delete({ name: role.name, domain: { id: domain.id } })\n })\n )\n\n await repository.delete({ name: 'system', domain: { id: domain.id } })\n }\n}\n"]}
1
+ {"version":3,"file":"1610516350460-SeedRole.js","sourceRoot":"","sources":["../../server/migrations/1610516350460-SeedRole.ts"],"names":[],"mappings":"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","sourcesContent":["import { MigrationInterface, QueryRunner } from 'typeorm'\n\nimport { Privilege, Role, User } from '@things-factory/auth-base'\nimport { Domain, getRepository } from '@things-factory/shell'\n\nconst PRIVILEGES_SEED = {\n modeller: [\n {\n name: 'mutation',\n category: 'setting'\n },\n {\n name: 'mutation',\n category: 'menu'\n },\n {\n name: 'mutation',\n category: 'user'\n },\n {\n name: 'mutation',\n category: 'appliance'\n },\n {\n name: 'mutation',\n category: 'appliance'\n },\n {\n name: 'mutation',\n category: 'application'\n },\n {\n name: 'mutation',\n category: 'board'\n },\n {\n name: 'mutation',\n category: 'group'\n },\n {\n name: 'mutation',\n category: 'play-group'\n },\n {\n name: 'mutation',\n category: 'fonts'\n },\n {\n name: 'mutation',\n category: 'attachment'\n },\n {\n name: 'mutation',\n category: 'scenario'\n },\n {\n name: 'mutation',\n category: 'step'\n },\n {\n name: 'query',\n category: 'setting'\n },\n {\n name: 'query',\n category: 'menu'\n },\n {\n name: 'query',\n category: 'user'\n },\n {\n name: 'query',\n category: 'appliance'\n },\n {\n name: 'query',\n category: 'application'\n },\n {\n name: 'query',\n category: 'board'\n },\n {\n name: 'query',\n category: 'group'\n },\n {\n name: 'query',\n category: 'play-group'\n },\n {\n name: 'query',\n category: 'fonts'\n },\n {\n name: 'query',\n category: 'attachment'\n },\n {\n name: 'query',\n category: 'scenario'\n },\n {\n name: 'query',\n category: 'step'\n }\n ],\n system: [\n {\n name: 'mutation',\n category: 'system'\n },\n {\n name: 'query',\n category: 'system'\n }\n ],\n viewer: [\n {\n name: 'query',\n category: 'board'\n },\n {\n name: 'query',\n category: 'group'\n },\n {\n name: 'query',\n category: 'play-group'\n }\n ]\n}\n\nconst SEED = [\n {\n name: 'modeller',\n description: 'Board Modeller'\n },\n {\n name: 'viewer',\n description: 'Board Viewer'\n }\n]\n\nexport class SeedRole1610516350460 implements MigrationInterface {\n public async up(queryRunner: QueryRunner): Promise<any> {\n const repository = getRepository(Role)\n const userRepository = getRepository(User)\n\n let users: User[] = await userRepository.find({ where: { username: 'admin' }, relations: ['domains'] })\n let domain: Domain = await getRepository(Domain).findOneBy({\n name: 'SYSTEM'\n })\n\n var privilegeSeeds = []\n Promise.all(\n SEED.map(async role => {\n var privileges = await this.getPrivileges(privilegeSeeds, role.name)\n await repository.save({\n ...role,\n privileges: privileges,\n users,\n domain\n })\n })\n )\n await this.saveSystemRole(repository, users, domain)\n }\n\n public async saveSystemRole(repository, users, domain) {\n const privilegeRepository = getRepository(Privilege)\n var role = {\n name: 'system',\n description: 'System Admin'\n }\n var privileges = await privilegeRepository.find()\n await repository.save({\n ...role,\n privileges: privileges,\n users,\n domain\n })\n }\n\n public async getPrivileges(privilegeSeeds, roleName) {\n const privilegeRepository = getRepository(Privilege)\n privilegeSeeds = PRIVILEGES_SEED[roleName]\n var privileges = []\n await Promise.all(\n privilegeSeeds.map(async privilege => {\n var value = await privilegeRepository.findOne({ where: { name: privilege.name, category: privilege.category } })\n if (value) {\n privileges.push(value)\n }\n })\n )\n return privileges\n }\n\n public async down(queryRunner: QueryRunner): Promise<any> {\n const repository = getRepository(Role)\n const privilegeRepository = getRepository(Privilege)\n const domain: Domain = await getRepository(Domain).findOneBy({\n name: 'SYSTEM'\n })\n\n await Promise.all(\n SEED.reverse().map(async role => {\n await repository.delete({ name: role.name, domain: { id: domain.id } })\n })\n )\n\n await repository.delete({ name: 'system', domain: { id: domain.id } })\n }\n}\n"]}