@0xobelisk/sui-common 1.1.14 → 1.2.0-pre.1

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.
package/dist/index.js CHANGED
@@ -1,148 +1,92 @@
1
- import x from"prettier";import N from"prettier-plugin-move-js";async function C(e,t){let r;t&&(r=await x.resolveConfig(t));try{return x.format(e,{plugins:[N],parser:"move-parse",printWidth:120,semi:!0,tabWidth:2,useTabs:!1,bracketSpacing:!0,...r})}catch(a){let s;return a instanceof Error?s=a.message:s=a,console.log(`Error during output formatting: ${s}`),e}}async function V(e){return x.format(e,{parser:"typescript"})}import $ from"node:fs/promises";import E from"node:path";import R from"debug";var h=R("dubhe:common"),ee=R("dubhe:common");h.log=console.debug.bind(console);ee.log=console.error.bind(console);var b=h.extend("codegen"),te=h.extend("codegen");b.log=console.debug.bind(console);te.log=console.error.bind(console);async function i(e,t,r){let a=await C(e),s=` // Copyright (c) Obelisk Labs, Inc.
1
+ import v from"prettier";import Y from"prettier-plugin-move-js";async function C(e,t){let r;t&&(r=await v.resolveConfig(t));try{return v.format(e,{plugins:[Y],parser:"move-parse",printWidth:120,semi:!0,tabWidth:2,useTabs:!1,bracketSpacing:!0,...r})}catch(n){let a;return n instanceof Error?a=n.message:a=n,console.log(`Error during output formatting: ${a}`),e}}async function M(e){return v.format(e,{parser:"typescript"})}import y from"node:fs/promises";import R from"node:path";import E from"debug";var f=E("dubhe:common"),q=E("dubhe:common");f.log=console.debug.bind(console);q.log=console.error.bind(console);var b=f.extend("codegen"),N=f.extend("codegen");b.log=console.debug.bind(console);N.log=console.error.bind(console);async function c(e,t,r){let n=await C(e),a=` // Copyright (c) Obelisk Labs, Inc.
2
2
  // SPDX-License-Identifier: Apache-2.0
3
3
  #[allow(unused_use)]
4
4
 
5
5
  /* Autogenerated file. Do not edit manually. */
6
6
 
7
- `,n="#[test_only]",o=s+a,c="#[allow(lint(share_owned))]";t.includes(".toml")||t.includes("system")||t.includes("migrate")?o=a:t.includes("init")?o=n+a:t.includes("genesis")&&(o=c+a),await $.mkdir(E.dirname(t),{recursive:!0}),await $.writeFile(t,o),b(`${r}: ${t}`)}async function Re(e,t,r){let a=await V(e);await $.mkdir(E.dirname(t),{recursive:!0}),await $.writeFile(t,a),b(`${r}: ${t}`)}function je(e){return e.replace(/\\/g,"/")}import{existsSync as A}from"fs";import _ from"fs";function w(e){_.existsSync(e)&&(_.readdirSync(e).forEach(t=>{let r=`${e}/${t}`;_.lstatSync(r).isDirectory()?w(r):_.unlinkSync(r)}),_.rmdirSync(e))}function g(e){return Object.entries(e).map(([t,r])=>`${t}`).join(",")}function j(e){return`(${Object.entries(e).map(([t,r])=>`${r}`)})`}function u(e){return Object.entries(e).map(([t,r])=>`${t}: ${r}`)}function U(e){return Object.entries(e).map(([t,r])=>`self.${t}`)}function W(e,t){for(let r in e)if(e.hasOwnProperty(r)){let a=e[r];if(typeof a=="string"&&a===t||typeof a=="string"&&a.includes(t)&&a.includes(">"))return!0}return!1}async function O(e,t){console.log(`
7
+ `,o="#[test_only]",s=a+n,i="#[allow(lint(share_owned))]";t.includes(".toml")||t.includes("system")||t.includes("migrate")?s=n:t.includes("init")?s=o+n:t.includes("genesis")&&(s=i+n),await y.mkdir(R.dirname(t),{recursive:!0}),await y.writeFile(t,s),b(`${r}: ${t}`)}async function Ae(e,t,r){let n=await M(e);await y.mkdir(R.dirname(t),{recursive:!0}),await y.writeFile(t,n),b(`${r}: ${t}`)}function Te(e){return e.replace(/\\/g,"/")}import{existsSync as A}from"fs";import g from"fs";function x(e){g.existsSync(e)&&(g.readdirSync(e).forEach(t=>{let r=`${e}/${t}`;g.lstatSync(r).isDirectory()?x(r):g.unlinkSync(r)}),g.rmdirSync(e))}function $(e){return Object.entries(e).map(([t,r])=>`${t}`).join(",")}function U(e){return`(${Object.entries(e).map(([t,r])=>`${r}`)})`}function m(e){return Object.entries(e).map(([t,r])=>`${t}: ${r}`)}function O(e){return Object.entries(e).map(([t,r])=>`self.${t}`)}function W(e,t){for(let r in e)if(e.hasOwnProperty(r)){let n=e[r];if(typeof n=="string"&&n===t||typeof n=="string"&&n.includes(t)&&n.includes(">"))return!0}return!1}async function F(e,t){console.log(`
8
8
  \u{1F4C4} Starting Move.toml Generation...`),console.log(` \u2514\u2500 Output path: ${t}/contracts/${e.name}/Move.toml`);let r=`[package]
9
9
  name = "${e.name}"
10
10
  version = "1.0.0"
11
11
  edition = "2024"
12
12
 
13
13
  [dependencies]
14
- Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "mainnet-v1.38.3" }
15
- Dubhe = { git = "https://github.com/0xobelisk/dubhe-framework.git", rev = "dubhe-mainnet-v1.1.0" }
16
- ${e.plugins?.length?e.plugins.map(a=>`${a} = { git = "https://github.com/0xobelisk/merak.git", rev = "main", subdir = "contracts/${a}" }`).join(`
17
- `):""}
14
+ Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "mainnet-v1.46.3" }
15
+ Dubhe = { git = "https://github.com/0xobelisk/dubhe-framework.git", subdir = "contracts/dubhe", rev = "develop" }
18
16
 
19
17
  [addresses]
20
18
  sui = "0x2"
21
19
  ${e.name} = "0x0"
22
- `;await i(r,`${t}/contracts/${e.name}/Move.toml`,"formatAndWriteMove"),console.log(`\u2705 Move.toml Generation Complete
23
- `)}function re(e){return e.sort((t,r)=>{let a=t.charAt(0).toLowerCase(),s=r.charAt(0).toLowerCase();return a<s?-1:a>s?1:0})}function ae(e,t){return Object.entries(t).map(([r,a])=>`public(package) fun set_${r}(self: &mut ${e}, ${r}: ${a}) {
20
+ `;await c(r,`${t}/contracts/${e.name}/Move.toml`,"formatAndWriteMove"),console.log(`\u2705 Move.toml Generation Complete
21
+ `)}function ee(e){return e.sort((t,r)=>{let n=t.charAt(0).toLowerCase(),a=r.charAt(0).toLowerCase();return n<a?-1:n>a?1:0})}function te(e,t){return Object.entries(t).map(([r,n])=>`public(package) fun set_${r}(self: &mut ${e}, ${r}: ${n}) {
24
22
  self.${r} = ${r};
25
23
  }`).join(`
26
- `)}function se(e,t){return`public(package) fun set(self: &mut ${e}, ${u(t)}) {
24
+ `)}function re(e,t){return`public(package) fun set(self: &mut ${e}, ${m(t)}) {
27
25
  ${Object.entries(t).map(([r])=>`self.${r} = ${r};`).join(`
28
26
  `)}
29
- }`}function ne(e,t){return`public fun get(self: &${e}): ${j(t)} {
30
- (${U(t)})
31
- }`}function oe(e,t){return Object.entries(t).map(([r,a])=>`public fun get_${r}(self: &${e}): ${a} {
27
+ }`}function ne(e,t){return`public fun get(self: &${e}): ${U(t)} {
28
+ (${O(t)})
29
+ }`}function oe(e,t){return Object.entries(t).map(([r,n])=>`public fun get_${r}(self: &${e}): ${n} {
32
30
  self.${r}
33
31
  }`).join(`
34
- `)}function l(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}async function F(e,t,r){console.log(`
35
- \u{1F4E6} Starting Schema Data Generation...`);for(let a of Object.keys(t)){let s=a,n=t[a];console.log(` \u2514\u2500 ${s} ${Array.isArray(n)?"(enum)":"(struct)"}: ${JSON.stringify(n)}`);let o="",c=Object.keys(t).filter(p=>Array.isArray(t[p])).map(p=>p);if(Array.isArray(n)){let p=re(n);o=`module ${e}::${e}_${l(s)} {
36
- public enum ${s} has copy, drop , store {
37
- ${p}
32
+ `)}function d(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}async function L(e,t,r){console.log(`
33
+ \u{1F4E6} Starting Schema Data Generation...`);for(let n of Object.keys(t)){let a=n,o=t[n];console.log(` \u2514\u2500 ${a} ${Array.isArray(o)?"(enum)":"(struct)"}: ${JSON.stringify(o)}`);let s="",i=Object.keys(t).filter(u=>Array.isArray(t[u])).map(u=>u);if(Array.isArray(o)){let u=ee(o);s=`module ${e}::${e}_${d(a)} {
34
+ public enum ${a} has copy, drop , store {
35
+ ${u}
38
36
  }
39
37
 
40
- ${p.map(m=>`public fun new_${l(m)}(): ${s} {
41
- ${s}::${m}
42
- }`).join("")}`}else o=`module ${e}::${e}_${l(s)} {
38
+ ${u.map(p=>`public fun new_${d(p)}(): ${a} {
39
+ ${a}::${p}
40
+ }`).join("")}`}else s=`module ${e}::${e}_${d(a)} {
43
41
  use std::ascii::String;
44
42
 
45
- ${Object.keys(t).map(p=>{if(W(n,p))return`use ${e}::${e}_${l(p)}::${p};`}).filter(Boolean).join(`
43
+ ${Object.keys(t).map(u=>{if(W(o,u))return`use ${e}::${e}_${d(u)}::${u};`}).filter(Boolean).join(`
46
44
  `)}
47
45
 
48
- public struct ${s} has copy, drop , store {
49
- ${u(n)}
46
+ public struct ${a} has copy, drop , store {
47
+ ${m(o)}
50
48
  }
51
49
 
52
- public fun new(${u(n)}): ${s} {
53
- ${s} {
54
- ${g(n)}
50
+ public fun new(${m(o)}): ${a} {
51
+ ${a} {
52
+ ${$(o)}
55
53
  }
56
54
  }
57
55
 
58
- ${ne(s,n)}
59
- ${oe(s,n)}
60
- ${ae(s,n)}
61
- ${se(s,n)}
62
- }`;await i(o,`${r}/contracts/${e}/sources/codegen/data/${l(s)}.move`,"formatAndWriteMove")}}function ie(e,t){return t!=null?Object.keys(t).map(a=>`use ${e}::${e}_${l(a)}::${a};`).join(`
63
- `):""}async function D(e,t,r,a){console.log(`
64
- \u{1F4E6} Starting Schema Structure Generation...`),Object.entries(r).forEach(([n,o])=>{console.log(` \u2514\u2500 ${n}: ${o}`)});let s=`module ${e}::${e}_schema {
56
+ ${ne(a,o)}
57
+ ${oe(a,o)}
58
+ ${te(a,o)}
59
+ ${re(a,o)}
60
+ }`;await c(s,`${r}/contracts/${e}/sources/codegen/data/${d(a)}.move`,"formatAndWriteMove")}}function se(e,t){return t!=null?Object.keys(t).map(n=>`use ${e}::${e}_${d(n)}::${n};`).join(`
61
+ `):""}async function w(e,t,r,n){console.log(`
62
+ \u{1F4E6} Starting Schema Structure Generation...`),Object.entries(r).forEach(([o,s])=>{console.log(` \u2514\u2500 ${o}: ${s}`)});let a=`module ${e}::${e}_schema {
65
63
  use std::ascii::String;
66
64
  use std::ascii::string;
67
65
  use sui::package::UpgradeCap;
68
66
  use std::type_name;
69
67
  use dubhe::storage;
70
- use dubhe::storage_value::{Self, StorageValue};
71
- use dubhe::storage_map::{Self, StorageMap};
72
- use dubhe::storage_double_map::{Self, StorageDoubleMap};
68
+ use dubhe::${e=="dubhe"?"storage_value_internal":"storage_value"}::{Self, StorageValue};
69
+ use dubhe::${e=="dubhe"?"storage_map_internal":"storage_map"}::{Self, StorageMap};
70
+ use dubhe::${e=="dubhe"?"storage_double_map_internal":"storage_double_map"}::{Self, StorageDoubleMap};
73
71
  use sui::dynamic_field as df;
74
- use ${e}::${e}_dapp_metadata::DappMetadata;
75
72
 
76
- ${ie(e,t)}
73
+ ${se(e,t)}
77
74
 
78
75
  public struct Schema has key, store { id: UID }
79
-
80
- // Default storage
81
- public fun borrow_dapp__admin(self: &Schema): &StorageValue<address> {
82
- storage::borrow_field(&self.id, b"dapp__admin")
83
- }
84
-
85
- public fun borrow_dapp__package_id(self: &Schema): &StorageValue<address> {
86
- storage::borrow_field(&self.id, b"dapp__package_id")
87
- }
88
-
89
- public fun borrow_dapp__version(self: &Schema): &StorageValue<u32> {
90
- storage::borrow_field(&self.id, b"dapp__version")
91
- }
92
-
93
- public fun borrow_dapp__metadata(self: &Schema): &StorageValue<DappMetadata> {
94
- storage::borrow_field(&self.id, b"dapp__metadata")
95
- }
96
-
97
- public fun borrow_dapp__safe_mode(self: &Schema): &StorageValue<bool> {
98
- storage::borrow_field(&self.id, b"dapp__safe_mode")
99
- }
100
-
101
- public fun borrow_dapp__authorised_schemas(self: &Schema): &StorageValue<vector<address>> {
102
- storage::borrow_field(&self.id, b"dapp__authorised_schemas")
103
- }
104
-
105
- public fun borrow_dapp__schemas(self: &Schema): &StorageValue<vector<address>> {
106
- storage::borrow_field(&self.id, b"dapp__schemas")
107
- }
108
-
109
- public(package) fun dapp__admin(self: &mut Schema): &mut StorageValue<address> {
110
- storage::borrow_mut_field(&mut self.id, b"dapp__admin")
111
- }
112
-
113
- public(package) fun dapp__package_id(self: &mut Schema): &mut StorageValue<address> {
114
- storage::borrow_mut_field(&mut self.id, b"dapp__package_id")
115
- }
116
-
117
- public(package) fun dapp__version(self: &mut Schema): &mut StorageValue<u32> {
118
- storage::borrow_mut_field(&mut self.id, b"dapp__version")
119
- }
120
-
121
- public(package) fun dapp__metadata(self: &mut Schema): &mut StorageValue<DappMetadata> {
122
- storage::borrow_mut_field(&mut self.id, b"dapp__metadata")
123
- }
124
-
125
- public(package) fun dapp__safe_mode(self: &mut Schema): &mut StorageValue<bool> {
126
- storage::borrow_mut_field(&mut self.id, b"dapp__safe_mode")
127
- }
128
-
129
- public(package) fun dapp__authorised_schemas(self: &mut Schema): &mut StorageValue<vector<address>> {
130
- storage::borrow_mut_field(&mut self.id, b"dapp__authorised_schemas")
131
- }
132
76
 
133
- ${Object.entries(r).map(([n,o])=>`public fun borrow_${n}(self: &Schema) : &${o} {
134
- storage::borrow_field(&self.id, b"${n}")
77
+ ${Object.entries(r).map(([o,s])=>`public fun borrow_${o}(self: &Schema) : &${s} {
78
+ storage::borrow_field(&self.id, b"${o}")
135
79
  }
136
80
 
137
- public(package) fun ${n}(self: &mut Schema): &mut ${o} {
138
- storage::borrow_mut_field(&mut self.id, b"${n}")
81
+ public(package) fun ${o}(self: &mut Schema): &mut ${s} {
82
+ storage::borrow_mut_field(&mut self.id, b"${o}")
139
83
  }
140
84
  `).join("")}
141
85
 
142
86
 
143
87
  public(package) fun create(ctx: &mut TxContext): Schema {
144
88
  let mut id = object::new(ctx);
145
- ${Object.entries(r).map(([n,o])=>{let c="";return o.includes("StorageValue")?c=`storage_value::new(b"${n}", ctx)`:o.includes("StorageMap")?c=`storage_map::new(b"${n}", ctx)`:o.includes("StorageDoubleMap")&&(c=`storage_double_map::new(b"${n}", ctx)`),`storage::add_field<${o}>(&mut id, b"${n}", ${c});`}).join(`
89
+ ${Object.entries(r).map(([o,s])=>{let i="";return s.includes("StorageValue")?i=`${e=="dubhe"?"storage_value_internal":"storage_value"}::new(b"${o}", ctx)`:s.includes("StorageMap")?i=`${e=="dubhe"?"storage_map_internal":"storage_map"}::new(b"${o}", ctx)`:s.includes("StorageDoubleMap")&&(i=`${e=="dubhe"?"storage_double_map_internal":"storage_double_map"}::new(b"${o}", ctx)`),`storage::add_field<${s}>(&mut id, b"${o}", ${i});`}).join(`
146
90
  `)}
147
91
 
148
92
  Schema { id }
@@ -157,41 +101,28 @@ ${e.name} = "0x0"
157
101
  }
158
102
 
159
103
  public fun migrate(_schema: &mut Schema, _ctx: &mut TxContext) { }
160
-
161
-
162
- public(package) fun upgrade(schema: &mut Schema, new_package_id: address, new_version: u32, ctx: &mut TxContext) {
163
- assert!(schema.dapp__metadata().contains(), 0);
164
- assert!(schema.dapp__admin().get() == ctx.sender(), 0);
165
- schema.dapp__package_id().set(new_package_id);
166
- let current_version = schema.dapp__version()[];
167
- assert!(current_version < new_version, 0);
168
- schema.dapp__version().set(new_version);
169
- schema.migrate(ctx);
170
- }
171
-
172
104
 
173
105
  // ======================================== View Functions ========================================
174
- ${Object.entries(r).map(([n,o])=>{let c=o.match(/<(.+)>/)[1].split(",").map(q=>q.trim()),p=[],m="",f="";return o.includes("StorageValue")?(p=[],m=`${c[0]}`,f="get()"):o.includes("StorageMap")?(p=[`key: ${c[0]}`],m=`${c[1]}`,f="get(key)"):o.includes("StorageDoubleMap")&&(p=[`key1: ${c[0]}`,`key2: ${c[1]}`],m=`${c[2]}`,f="get(key1, key2)"),`public fun get_${n}(self: &Schema, ${p}) : &${m} {
175
- self.borrow_${n}().${f}
106
+ ${Object.entries(r).map(([o,s])=>{let i=s.match(/<(.+)>/)[1].split(",").map(X=>X.trim()),u=[],p="",h="";return s.includes("StorageValue")?(u=[],p=`${i[0]}`,h="get()"):s.includes("StorageMap")?(u=[`key: ${i[0]}`],p=`${i[1]}`,h="get(key)"):s.includes("StorageDoubleMap")&&(u=[`key1: ${i[0]}`,`key2: ${i[1]}`],p=`${i[2]}`,h="get(key1, key2)"),`public fun get_${o}(self: &Schema, ${u}) : &${p} {
107
+ self.borrow_${o}().${h}
176
108
  }`}).join(`
177
109
  `)}
178
110
  // =========================================================================================================
179
- }`;await i(s,`${a}/contracts/${e}/sources/codegen/core/schema.move`,"formatAndWriteMove")}import{existsSync as B}from"fs";function L(e){return e.charAt(0).toUpperCase()+e.slice(1)}async function I(e,t){let r=`${t}/contracts/${e.name}/sources/scripts/deploy_hook.move`;if(!B(r)){let a=`module ${e.name}::${e.name}_deploy_hook {
111
+ }`;await c(a,`${n}/contracts/${e}/sources/codegen/core/schema.move`,"formatAndWriteMove")}import{existsSync as V}from"fs";async function B(e,t){let r=`${t}/contracts/${e.name}/sources/scripts/deploy_hook.move`;if(!V(r)){let n=`module ${e.name}::${e.name}_deploy_hook {
180
112
  use ${e.name}::${e.name}_schema::Schema;
181
- ${e.plugins?.length?e.plugins.map(s=>`use ${s}::${s}_schema::Schema as ${L(s)}Schema;`).join(`
182
- `):""}
113
+ ${e.name!=="dubhe"?"use dubhe::dubhe_schema::Schema as DubheSchema;":""}
183
114
 
184
- public(package) fun run(_schema: &mut Schema, ${e.plugins?.length?e.plugins.map(s=>`_${s}_schema: &mut ${L(s)}Schema`).join(", ")+", ":""} _ctx: &mut TxContext) {
115
+ public(package) fun run(${e.name!=="dubhe"?"_dubhe_schema: &mut DubheSchema,":""}_schema: &mut Schema, _ctx: &mut TxContext) {
185
116
 
186
117
  }
187
- }`;await i(a,r,"formatAndWriteMove")}}async function G(e,t){if(!B(`${t}/contracts/${e.name}/sources/scripts/migrate.move`)){let r=`module ${e.name}::${e.name}_migrate {
118
+ }`;await c(n,r,"formatAndWriteMove")}}async function I(e,t){if(!V(`${t}/contracts/${e.name}/sources/scripts/migrate.move`)){let r=`module ${e.name}::${e.name}_migrate {
188
119
  const ON_CHAIN_VERSION: u32 = 1;
189
120
 
190
121
  public fun on_chain_version(): u32 {
191
122
  ON_CHAIN_VERSION
192
123
  }
193
124
  }
194
- `;await i(r,`${t}/contracts/${e.name}/sources/scripts/migrate.move`,"formatAndWriteMove")}}async function K(e,t){let r=`module ${e.name}::${e.name}_dapp_key {
125
+ `;await c(r,`${t}/contracts/${e.name}/sources/scripts/migrate.move`,"formatAndWriteMove")}}async function j(e,t){let r=`module ${e.name}::${e.name}_dapp_key {
195
126
  /// Authorization token for the app.
196
127
  public struct DappKey has copy, drop {}
197
128
 
@@ -199,272 +130,100 @@ ${e.name} = "0x0"
199
130
  DappKey { }
200
131
  }
201
132
  }
202
- `;await i(r,`${t}/contracts/${e.name}/sources/codegen/core/dapp_key.move`,"formatAndWriteMove")}function d(e){return e.split("_").map(t=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function ce(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}function z(e,t){return t!=null?Object.keys(t).map(a=>`use ${e}::${e}_${ce(a)}::${a};`).join(`
203
- `):""}async function k(e,t,r,a){console.log(`
204
- \u{1F4E6} Starting Schema Event Generation...`);for(let n of Object.keys(r)){let o=n,c=r[n];console.log(` \u2514\u2500 ${o} event: ${JSON.stringify(c)}`);let p=`module ${e}::${e}_${o}_event {
133
+ `;await c(r,`${t}/contracts/${e.name}/sources/codegen/core/dapp_key.move`,"formatAndWriteMove")}function l(e){return e.split("_").map(t=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function ae(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}function G(e,t){return t!=null?Object.keys(t).map(n=>`use ${e}::${e}_${ae(n)}::${n};`).join(`
134
+ `):""}async function D(e,t,r,n){console.log(`
135
+ \u{1F4E6} Starting Schema Event Generation...`);for(let o of Object.keys(r)){let s=o,i=r[o];console.log(` \u2514\u2500 ${s} event: ${JSON.stringify(i)}`);let u=`module ${e}::${e}_${s}_event {
205
136
  use sui::event;
206
137
  use std::ascii::String;
207
- ${z(e,t)}
138
+ ${G(e,t)}
208
139
 
209
- public struct ${d(o)}Event has copy, drop {
210
- ${u(c)}
140
+ public struct ${l(s)}Event has copy, drop {
141
+ ${m(i)}
211
142
  }
212
143
 
213
- public fun new(${u(c)}): ${d(o)}Event {
214
- ${d(o)}Event {
215
- ${g(c)}
144
+ public fun new(${m(i)}): ${l(s)}Event {
145
+ ${l(s)}Event {
146
+ ${$(i)}
216
147
  }
217
148
  }
218
- }`;await i(p,`${a}/contracts/${e}/sources/codegen/data/${o}_event.move`,"formatAndWriteMove")}let s=`module ${e}::${e}_events {
149
+ }`;await c(u,`${n}/contracts/${e}/sources/codegen/data/${s}_event.move`,"formatAndWriteMove")}let a=`module ${e}::${e}_events {
219
150
  use std::ascii::{String, string};
220
- ${z(e,t)}
221
- ${Object.entries(r).map(([n,o])=>`
222
- use ${e}::${e}_${n}_event::${d(n)}Event;
223
- use ${e}::${e}_${n}_event;
224
- public fun ${n}_event(${u(o)}) {
225
- dubhe::storage_event::emit_set_record<${d(n)}Event, ${d(n)}Event, ${d(n)}Event>(
226
- string(b"${n}_event"),
151
+ ${G(e,t)}
152
+ ${Object.entries(r).map(([o,s])=>`
153
+ use ${e}::${e}_${o}_event::${l(o)}Event;
154
+ use ${e}::${e}_${o}_event;
155
+ public fun ${o}_event(${m(s)}) {
156
+ dubhe::storage_event::emit_set_record<${l(o)}Event, ${l(o)}Event, ${l(o)}Event>(
157
+ string(b"${o}_event"),
227
158
  option::none(),
228
159
  option::none(),
229
- option::some(${e}_${n}_event::new(${g(o)}))
160
+ option::some(${e}_${o}_event::new(${$(s)}))
230
161
  )
231
162
  }
232
163
  `).join(`
233
164
  `)}
234
- }`;await i(s,`${a}/contracts/${e}/sources/codegen/events.move`,"formatAndWriteMove")}import{existsSync as pe}from"fs";import ue from"node:fs/promises";async function H(e,t){pe(`${t}/contracts/${e.name}/sources/systems`)||await ue.mkdir(`${t}/contracts/${e.name}/sources/systems`,{recursive:!0})}async function Q(e,t,r){console.log(`
235
- \u{1F4E6} Starting Schema Error Generation...`);let a=`module ${e}::${e}_errors {
236
- ${Object.entries(t).map(([s,n])=>(console.log(` \u2514\u2500 ${s}: ${n}`),`#[error]
237
- const ${s.toUpperCase()}: vector<u8> = b"${n}";
238
- public fun ${s}_error(condition: bool) { assert!(condition, ${s.toUpperCase()}) }
165
+ }`;await c(a,`${n}/contracts/${e}/sources/codegen/events.move`,"formatAndWriteMove")}import{existsSync as K}from"fs";import z from"node:fs/promises";async function H(e,t){K(`${t}/contracts/${e.name}/sources/systems`)||await z.mkdir(`${t}/contracts/${e.name}/sources/systems`,{recursive:!0}),K(`${t}/contracts/${e.name}/sources/tests`)||await z.mkdir(`${t}/contracts/${e.name}/sources/tests`,{recursive:!0})}async function Q(e,t,r){console.log(`
166
+ \u{1F4E6} Starting Schema Error Generation...`);let n=`module ${e}::${e}_errors {
167
+ ${Object.entries(t).map(([a,o])=>(console.log(` \u2514\u2500 ${a}: ${o}`),`#[error]
168
+ const ${a.toUpperCase()}: vector<u8> = b"${o}";
169
+ public fun ${a}_error(condition: bool) { assert!(condition, ${a.toUpperCase()}) }
239
170
  `)).join(`
240
171
  `)}
241
- }`;await i(a,`${r}/contracts/${e}/sources/codegen/errors.move`,"formatAndWriteMove")}import{existsSync as P}from"fs";async function Z(e,t){await me(e,t),await de(e,t)}async function me(e,t){let r=`${t}/contracts/${e.name}/sources/codegen/core/metadata.move`;if(!P(r)){let a=`module ${e.name}::${e.name}_dapp_metadata {
242
- use std::ascii::String;
243
-
244
- public struct DappMetadata has drop, copy, store {
245
- name: String,
246
- description: String,
247
- cover_url: vector<String>,
248
- website_url: String,
249
- created_at: u64,
250
- partners: vector<String>,
251
- }
252
-
253
- public fun new(
254
- name: String,
255
- description: String,
256
- cover_url: vector<String>,
257
- website_url: String,
258
- created_at: u64,
259
- partners: vector<String>,
260
- ): DappMetadata {
261
- DappMetadata {
262
- name,
263
- description,
264
- cover_url,
265
- website_url,
266
- created_at,
267
- partners,
268
- }
269
- }
270
-
271
- public fun set(
272
- self: &mut DappMetadata,
273
- name: String,
274
- description: String,
275
- cover_url: vector<String>,
276
- website_url: String,
277
- created_at: u64,
278
- partners: vector<String>,
279
- ) {
280
- self.name = name;
281
- self.description = description;
282
- self.cover_url = cover_url;
283
- self.website_url = website_url;
284
- self.created_at = created_at;
285
- self.partners = partners;
286
- }
287
-
288
- public fun set_name(self: &mut DappMetadata, name: String) {
289
- self.name = name;
290
- }
291
-
292
- public fun set_description(self: &mut DappMetadata, description: String) {
293
- self.description = description;
294
- }
295
-
296
- public fun set_cover_url(self: &mut DappMetadata, cover_url: vector<String>) {
297
- self.cover_url = cover_url;
298
- }
299
-
300
- public fun set_website_url(self: &mut DappMetadata, website_url: String) {
301
- self.website_url = website_url;
302
- }
303
-
304
- public fun set_created_at(self: &mut DappMetadata, created_at: u64) {
305
- self.created_at = created_at;
306
- }
307
-
308
- public fun set_partners(self: &mut DappMetadata, partners: vector<String>) {
309
- self.partners = partners;
310
- }
311
-
312
- public fun get_name(self: &DappMetadata): String {
313
- self.name
314
- }
315
-
316
- public fun get_description(self: &DappMetadata): String {
317
- self.description
318
- }
319
-
320
- public fun get_cover_url(self: &DappMetadata): vector<String> {
321
- self.cover_url
322
- }
323
-
324
- public fun get_website_url(self: &DappMetadata): String {
325
- self.website_url
326
- }
327
-
328
- public fun get_created_at(self: &DappMetadata): u64 {
329
- self.created_at
330
- }
331
-
332
- public fun get_partners(self: &DappMetadata): vector<String> {
333
- self.partners
334
- }
335
- }
336
- `;await i(a,r,"formatAndWriteMove")}}async function de(e,t){let r=`${t}/contracts/${e.name}/sources/codegen/core/system.move`;if(!P(r)){let a=`module ${e.name}::${e.name}_dapp_system {
337
- use std::ascii::String;
338
- use std::ascii;
339
- use dubhe::type_info;
340
- use sui::clock::Clock;
341
- use sui::transfer::public_share_object;
342
- use ${e.name}::${e.name}_schema::Schema;
343
- use ${e.name}::${e.name}_dapp_metadata;
344
- use ${e.name}::${e.name}_dapp_metadata::DappMetadata;
345
- use dubhe::storage::add_field;
346
- use dubhe::storage_value;
347
- use dubhe::storage_value::StorageValue;
348
-
349
- public entry fun set_metadata(
350
- schema: &mut Schema,
351
- name: String,
352
- description: String,
353
- cover_url: vector<String>,
354
- website_url: String,
355
- partners: vector<String>,
356
- ctx: &TxContext,
357
- ) {
358
- let admin = schema.dapp__admin().try_get();
359
- assert!(admin == option::some(ctx.sender()), 0);
360
- let created_at = schema.dapp__metadata().get().get_created_at();
361
- schema.dapp__metadata().set(
362
- ${e.name}_dapp_metadata::new(
363
- name,
364
- description,
365
- cover_url,
366
- website_url,
367
- created_at,
368
- partners
369
- )
370
- );
371
- }
372
-
373
-
374
- public entry fun transfer_ownership(schema: &mut Schema, new_admin: address, ctx: &mut TxContext) {
375
- let admin = schema.dapp__admin().try_get();
376
- assert!(admin == option::some(ctx.sender()), 0);
377
- schema.dapp__admin().set(new_admin);
378
- }
379
-
380
- public entry fun set_safe_mode(schema: &mut Schema, safe_mode: bool, ctx: &TxContext) {
381
- let admin = schema.dapp__admin().try_get();
382
- assert!(admin == option::some(ctx.sender()), 0);
383
- schema.dapp__safe_mode().set(safe_mode);
384
- }
385
-
386
- public fun ensure_no_safe_mode(schema: &mut Schema) {
387
- assert!(!schema.dapp__safe_mode()[], 0);
388
- }
389
-
390
- public fun ensure_has_authority(schema: &mut Schema, ctx: &TxContext) {
391
- assert!(schema.dapp__admin().get() == ctx.sender(), 0);
392
- }
393
-
394
- public fun ensure_has_schema<S: key + store>(schema: &mut Schema, new_schema: &S) {
395
- let schema_id = object::id_address(new_schema);
396
- assert!(schema.dapp__authorised_schemas().get().contains(&schema_id), 0);
397
- }
398
-
399
- public(package) fun create(schema: &mut Schema, name: String, description: String, clock: &Clock, ctx: &mut TxContext){
400
- add_field<StorageValue<address>>(schema.id(), b"dapp__admin", storage_value::new(b"dapp__admin", ctx));
401
- add_field<StorageValue<address>>(schema.id(), b"dapp__package_id", storage_value::new(b"dapp__package_id", ctx));
402
- add_field<StorageValue<u32>>(schema.id(), b"dapp__version", storage_value::new(b"dapp__version", ctx));
403
- add_field<StorageValue<DappMetadata>>(schema.id(), b"dapp__metadata", storage_value::new(b"dapp__metadata", ctx));
404
- add_field<StorageValue<bool>>(schema.id(), b"dapp__safe_mode", storage_value::new(b"dapp__safe_mode", ctx));
405
- add_field<StorageValue<vector<address>>>(schema.id(), b"dapp__authorised_schemas", storage_value::new(b"dapp__authorised_schemas", ctx));
406
- schema.dapp__metadata().set(
407
- ${e.name}_dapp_metadata::new(
408
- name,
409
- description,
410
- vector[],
411
- ascii::string(b""),
412
- clock.timestamp_ms(),
413
- vector[]
414
- )
415
- );
416
- let package_id = type_info::current_package_id<Schema>();
417
- schema.dapp__package_id().set(package_id);
418
- schema.dapp__admin().set(ctx.sender());
419
- schema.dapp__version().set(1);
420
- schema.dapp__safe_mode().set(false);
421
- schema.dapp__authorised_schemas().set(vector[]);
422
- }
423
-
424
- public(package) fun add_schema<S: key + store>(schema: &mut Schema, new_schema: S) {
425
- let mut schemas = schema.dapp__authorised_schemas()[];
426
- schemas.push_back(object::id_address<S>(&new_schema));
427
- schema.dapp__authorised_schemas().set(schemas);
428
- public_share_object(new_schema);
429
- }
430
- }
431
-
432
- `;await i(a,r,"formatAndWriteMove")}}function S(e){return e.charAt(0).toUpperCase()+e.slice(1)}async function J(e,t){let r=`module ${e.name}::${e.name}_init_test {
172
+ }`;await c(n,`${r}/contracts/${e}/sources/codegen/errors.move`,"formatAndWriteMove")}async function Z(e,t){let r=`module ${e.name}::${e.name}_init_test {
433
173
  use sui::clock;
434
174
  use sui::test_scenario;
435
175
  use sui::test_scenario::Scenario;
436
- ${e.plugins?.length?e.plugins.map(s=>`use ${s}::${s}_schema::Schema as ${S(s)}Schema;`).join(`
437
- `):""}
176
+ use dubhe::dubhe_schema::Schema as DubheSchema;
177
+ ${e.name!=="dubhe"?`use ${e.name}::${e.name}_schema::Schema;`:""}
438
178
 
439
- public fun deploy_dapp_for_testing(scenario: &mut Scenario, ${e.plugins?.length?e.plugins.map(s=>`${s}_schema: &mut ${S(s)}Schema`).join(", "):""}) {
179
+ public fun deploy_dapp_for_testing(scenario: &mut Scenario): ${e.name!=="dubhe"?"(DubheSchema, Schema)":"DubheSchema"} {
180
+ ${e.name!=="dubhe"?"let mut dubhe_schema = dubhe::dubhe_init_test::create_dubhe_schema_for_other_contract(scenario);":""}
440
181
  let ctx = test_scenario::ctx(scenario);
441
182
  let clock = clock::create_for_testing(ctx);
442
- ${e.name}::${e.name}_genesis::run(&clock, ${e.plugins?.length?e.plugins.map(s=>`${s}_schema`).join(", ")+", ":""} ctx);
183
+ ${e.name}::${e.name}_genesis::run(${e.name!=="dubhe"?"&mut dubhe_schema,":""}&clock, ctx);
443
184
  clock::destroy_for_testing(clock);
444
185
  test_scenario::next_tx(scenario, ctx.sender());
186
+ ${e.name!=="dubhe"?`
187
+ let schema = test_scenario::take_shared<Schema>(scenario);
188
+ (dubhe_schema, schema)
189
+ `:"test_scenario::take_shared<DubheSchema>(scenario)"}
445
190
  }
191
+
192
+ ${e.name=="dubhe"?`
193
+ public fun create_dubhe_schema_for_other_contract(scenario: &mut Scenario): DubheSchema {
194
+ let ctx = test_scenario::ctx(scenario);
195
+ let mut schema = dubhe::dubhe_schema::create(ctx);
196
+ dubhe::dubhe_deploy_hook::run(&mut schema, ctx);
197
+ sui::transfer::public_share_object(schema);
198
+ test_scenario::next_tx(scenario, ctx.sender());
199
+ test_scenario::take_shared<DubheSchema>(scenario)
200
+ }
201
+ `:""}
446
202
  }
447
- `;await i(r,`${t}/contracts/${e.name}/sources/codegen/core/init_test.move`,"formatAndWriteMove");let a=`module ${e.name}::${e.name}_genesis {
203
+ `;await c(r,`${t}/contracts/${e.name}/sources/codegen/core/init_test.move`,"formatAndWriteMove");let n=`module ${e.name}::${e.name}_genesis {
448
204
  use std::ascii::string;
449
205
 
450
206
  use sui::clock::Clock;
451
207
 
452
- use ${e.name}::${e.name}_dapp_system;
453
- ${e.plugins?.length?e.plugins.map(s=>`use ${s}::${s}_schema::Schema as ${S(s)}Schema;`).join(`
454
- `):""}
455
- public entry fun run(clock: &Clock, ${e.plugins?.length?e.plugins.map(s=>`${s}_schema: &mut ${S(s)}Schema`).join(", ")+", ":""} ctx: &mut TxContext) {
208
+ ${e.name!=="dubhe"?"use dubhe::dubhe_schema::Schema as DubheSchema;":""}
209
+ public entry fun run(${e.name!=="dubhe"?"_dubhe_schema: &mut DubheSchema,":""}clock: &Clock, ctx: &mut TxContext) {
456
210
  // Create schemas
457
211
  let mut schema = ${e.name}::${e.name}_schema::create(ctx);
458
212
  // Setup default storage
459
- ${e.name}_dapp_system::create(&mut schema, string(b"${e.name}"),string(b"${e.description}"), clock , ctx);
213
+ dubhe::dubhe_dapp_system::create_dapp(
214
+ ${e.name!=="dubhe"?"_dubhe_schema":"&mut schema"},
215
+ ${e.name}::${e.name}_dapp_key::new(),
216
+ dubhe::dubhe_dapp_metadata::new(string(b"${e.name}"), string(b"${e.description}"), vector[], string(b""), clock.timestamp_ms(), vector[]),
217
+ ctx
218
+ );
460
219
  // Logic that needs to be automated once the contract is deployed
461
- ${e.name}::${e.name}_deploy_hook::run(&mut schema, ${e.plugins?.length?e.plugins.map(s=>`${s}_schema`).join(", ")+", ":""} ctx);
220
+ ${e.name}::${e.name}_deploy_hook::run(${e.name!=="dubhe"?"_dubhe_schema,":""}&mut schema, ctx);
462
221
  // Authorize schemas and public share objects
463
222
  sui::transfer::public_share_object(schema);
464
223
  }
465
224
  }
466
- `;await i(a,`${t}/contracts/${e.name}/sources/codegen/core/genesis.move`,"formatAndWriteMove")}async function yt(e,t,r){console.log(`
467
- \u{1F680} Starting Schema Generation Process...`),console.log("\u{1F4CB} Project Configuration:"),console.log(` \u2514\u2500 Name: ${e.name}`),console.log(` \u2514\u2500 Description: ${e.description||"No description provided"}`),console.log(` \u2514\u2500 Network: ${r||"testnet"}`);let a=t??process.cwd();A(`${a}/contracts/${e.name}`)&&w(`${a}/contracts/${e.name}/sources/codegen`),A(`${a}/contracts/${e.name}/Move.toml`)||await O(e,a),A(`${a}/contracts/${e.name}/sources/script/deploy_hook.move`)||await I(e,a),e.events&&(e.data?await k(e.name,e.data,e.events,a):await k(e.name,null,e.events,a)),e.data?(await F(e.name,e.data,a),await D(e.name,e.data,e.schemas,a)):await D(e.name,null,e.schemas,a),e.errors&&await Q(e.name,e.errors,a),await Z(e,a),await J(e,a),await H(e,a),await G(e,a),await K(e,a),console.log(`
225
+ `;await c(n,`${t}/contracts/${e.name}/sources/codegen/core/genesis.move`,"formatAndWriteMove")}async function pt(e,t,r){console.log(`
226
+ \u{1F680} Starting Schema Generation Process...`),console.log("\u{1F4CB} Project Configuration:"),console.log(` \u2514\u2500 Name: ${e.name}`),console.log(` \u2514\u2500 Description: ${e.description||"No description provided"}`),console.log(` \u2514\u2500 Network: ${r||"testnet"}`);let n=t??process.cwd();A(`${n}/contracts/${e.name}`)&&x(`${n}/contracts/${e.name}/sources/codegen`),A(`${n}/contracts/${e.name}/Move.toml`)||await F(e,n),A(`${n}/contracts/${e.name}/sources/script/deploy_hook.move`)||await B(e,n),e.events&&(e.data?await D(e.name,e.data,e.events,n):await D(e.name,null,e.events,n)),e.data?(await L(e.name,e.data,n),await w(e.name,e.data,e.schemas,n)):await w(e.name,null,e.schemas,n),e.errors&&await Q(e.name,e.errors,n),await Z(e,n),await H(e,n),await I(e,n),await j(e,n),console.log(`
468
227
  \u2705 Schema Generation Process Complete!
469
- `)}import{findUp as le}from"find-up";import M from"path";import _e from"esbuild";var y=class extends Error{name="NotInsideProjectError";message="You are not inside a Dubhe project"};import{rmSync as ge}from"fs";import{pathToFileURL as fe}from"url";import he from"os";var be=["dubhe.config.js","dubhe.config.mjs","dubhe.config.ts","dubhe.config.mts"],T="dubhe.config.example.mjs";async function Vt(e){e=await X(e);try{return await _e.build({entryPoints:[e],format:"esm",outfile:T,platform:"node",bundle:!0,packages:"external"}),e=await X(T,!0),(await import(e+`?update=${Date.now()}`)).dubheConfig}finally{ge(T,{force:!0})}}async function X(e,t){return e===void 0?e=await $e():M.isAbsolute(e)||(e=M.join(process.cwd(),e),e=M.normalize(e)),t&&he.platform()==="win32"?fe(e).href:e}async function $e(){let e=await le(be);if(e===void 0)throw new y;return e}function Lt(...e){if(e.length===1)return`StorageValue<${e[0]}>`;if(e.length===2)return`StorageMap<${e[0]}, ${e[1]}>`;if(e.length===3)return`StorageDoubleMap<${e[0]}, ${e[1]}, ${e[2]}>`;throw new Error("Invalid number of arguments for storage()")}var v=e=>{if(typeof e!="object"||e===null)return e;let t={};for(let r in e)if(e.hasOwnProperty(r)){let a=e[r];typeof a=="object"&&a!==null?Array.isArray(a)?t[r]=Y(a):a.hasOwnProperty("variant")?t[r]={[a.variant]:{}}:a.hasOwnProperty("fields")?t[r]=v(a.fields):t[r]=v(a):t[r]=a}return t},Y=e=>{let t=[];return e.forEach(r=>{typeof r=="object"&&r!==null?Array.isArray(r)?t.push(Y(r)):r.hasOwnProperty("variant")?t.push({[r.variant]:{}}):r.hasOwnProperty("fields")?t.push(v(r.fields)):t.push(v(r)):t.push(r)}),t};var Se=(r=>(r.Event="event",r.Schema="schema",r))(Se||{});export{Se as SubscriptionKind,i as formatAndWriteMove,Re as formatAndWriteTypescript,C as formatMove,V as formatTypescript,Vt as loadConfig,v as parseData,je as posixPath,X as resolveConfigPath,yt as schemaGen,Lt as storage};
228
+ `)}import{findUp as ie}from"find-up";import k from"path";import ce from"esbuild";var _=class extends Error{name="NotInsideProjectError";message="You are not inside a Dubhe project"};import{rmSync as ue}from"fs";import{pathToFileURL as me}from"url";import pe from"os";var le=["dubhe.config.js","dubhe.config.mjs","dubhe.config.ts","dubhe.config.mts"],T="dubhe.config.example.mjs";async function St(e){e=await J(e);try{return await ce.build({entryPoints:[e],format:"esm",outfile:T,platform:"node",bundle:!0,packages:"external"}),e=await J(T,!0),(await import(e+`?update=${Date.now()}`)).dubheConfig}finally{ue(T,{force:!0})}}async function J(e,t){return e===void 0?e=await de():k.isAbsolute(e)||(e=k.join(process.cwd(),e),e=k.normalize(e)),t&&pe.platform()==="win32"?me(e).href:e}async function de(){let e=await ie(le);if(e===void 0)throw new _;return e}function Ct(...e){if(e.length===1)return`StorageValue<${e[0]}>`;if(e.length===2)return`StorageMap<${e[0]}, ${e[1]}>`;if(e.length===3)return`StorageDoubleMap<${e[0]}, ${e[1]}, ${e[2]}>`;throw new Error("Invalid number of arguments for storage()")}var S=e=>{if(typeof e!="object"||e===null)return e;let t={};for(let r in e)if(e.hasOwnProperty(r)){let n=e[r];typeof n=="object"&&n!==null?Array.isArray(n)?t[r]=P(n):n.hasOwnProperty("variant")?t[r]={[n.variant]:{}}:n.hasOwnProperty("fields")?t[r]=S(n.fields):t[r]=S(n):t[r]=n}return t},P=e=>{let t=[];return e.forEach(r=>{typeof r=="object"&&r!==null?Array.isArray(r)?t.push(P(r)):r.hasOwnProperty("variant")?t.push({[r.variant]:{}}):r.hasOwnProperty("fields")?t.push(S(r.fields)):t.push(S(r)):t.push(r)}),t};var ge=(r=>(r.Event="event",r.Schema="schema",r))(ge||{});export{ge as SubscriptionKind,c as formatAndWriteMove,Ae as formatAndWriteTypescript,C as formatMove,M as formatTypescript,St as loadConfig,S as parseData,Te as posixPath,J as resolveConfigPath,pt as schemaGen,Ct as storage};
470
229
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/codegen/utils/format.ts","../src/codegen/utils/formatAndWrite.ts","../src/debug.ts","../src/codegen/debug.ts","../src/codegen/utils/posixPath.ts","../src/codegen/utils/renderMove/schemaGen.ts","../src/codegen/utils/renderMove/common.ts","../src/codegen/utils/renderMove/generateToml.ts","../src/codegen/utils/renderMove/generateSchema.ts","../src/codegen/utils/renderMove/generateScript.ts","../src/codegen/utils/renderMove/generateDappKey.ts","../src/codegen/utils/renderMove/generateEvent.ts","../src/codegen/utils/renderMove/generateSystem.ts","../src/codegen/utils/renderMove/generateError.ts","../src/codegen/utils/renderMove/generateDefaultSchema.ts","../src/codegen/utils/renderMove/generateInit.ts","../src/codegen/utils/config.ts","../src/codegen/utils/errors.ts","../src/codegen/types/index.ts","../src/parseData/parser/index.ts","../src/primitives/index.ts"],"sourcesContent":["import prettier from 'prettier';\nimport prettierPluginMove from 'prettier-plugin-move-js';\n\nexport async function formatMove(content: string, prettierConfigPath?: string): Promise<string> {\n let config;\n if (prettierConfigPath) {\n config = await prettier.resolveConfig(prettierConfigPath);\n }\n try {\n return prettier.format(content, {\n plugins: [prettierPluginMove],\n parser: 'move-parse',\n printWidth: 120,\n semi: true,\n tabWidth: 2,\n useTabs: false,\n bracketSpacing: true,\n ...config\n });\n } catch (error) {\n let message;\n if (error instanceof Error) {\n message = error.message;\n } else {\n message = error;\n }\n console.log(`Error during output formatting: ${message}`);\n return content;\n }\n}\n\nexport async function formatTypescript(content: string): Promise<string> {\n return prettier.format(content, {\n parser: 'typescript'\n });\n}\n","import fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { formatMove, formatTypescript } from './format';\nimport { debug } from '../debug';\n\nexport async function formatAndWriteMove(\n output: string,\n fullOutputPath: string,\n logPrefix?: string\n): Promise<void> {\n const formattedOutput = await formatMove(output);\n let schemaPrefix = ` // Copyright (c) Obelisk Labs, Inc.\n // SPDX-License-Identifier: Apache-2.0\n #[allow(unused_use)]\n \n /* Autogenerated file. Do not edit manually. */\n \n `;\n\n let initPrefix = `#[test_only]`;\n\n let code = schemaPrefix + formattedOutput;\n\n let deployHookPrefix = `#[allow(lint(share_owned))]`;\n\n if (\n fullOutputPath.includes('.toml') ||\n fullOutputPath.includes('system') ||\n fullOutputPath.includes('migrate')\n ) {\n code = formattedOutput;\n } else if (fullOutputPath.includes('init')) {\n code = initPrefix + formattedOutput;\n } else if (fullOutputPath.includes('genesis')) {\n code = deployHookPrefix + formattedOutput;\n }\n\n await fs.mkdir(path.dirname(fullOutputPath), { recursive: true });\n await fs.writeFile(fullOutputPath, code);\n debug(`${logPrefix}: ${fullOutputPath}`);\n}\n\n/**\n * Formats typescript code using prettier and write it to a file\n * @param output typescript code\n * @param fullOutputPath full path to the output file\n * @param logPrefix prefix for debug logs\n */\nexport async function formatAndWriteTypescript(\n output: string,\n fullOutputPath: string,\n logPrefix: string\n): Promise<void> {\n const formattedOutput = await formatTypescript(output);\n\n await fs.mkdir(path.dirname(fullOutputPath), { recursive: true });\n\n await fs.writeFile(fullOutputPath, formattedOutput);\n debug(`${logPrefix}: ${fullOutputPath}`);\n}\n","import createDebug from 'debug';\n\nexport const debug = createDebug('dubhe:common');\nexport const error = createDebug('dubhe:common');\n\n// Pipe debug output to stdout instead of stderr\ndebug.log = console.debug.bind(console);\n\n// Pipe error output to stderr\nerror.log = console.error.bind(console);\n","import { debug as parentDebug } from '../debug';\n\nexport const debug = parentDebug.extend('codegen');\nexport const error = parentDebug.extend('codegen');\n\n// Pipe debug output to stdout instead of stderr\ndebug.log = console.debug.bind(console);\n\n// Pipe error output to stderr\nerror.log = console.error.bind(console);\n","/**\n * Explicitly normalize a given path to a posix path (using `/` as separator).\n * This should be used for generating Solidity files that will be consumed by solc,\n * because solc expects `/` as path separator, but path.join produces `\\` if the user is on windows.\n */\nexport function posixPath(path: string): string {\n return path.replace(/\\\\/g, '/');\n}\n","import { SchemaType, DubheConfig } from '../../types';\nimport { rmdirSync, existsSync } from 'fs';\nimport { deleteFolderRecursive } from './common';\nimport { generateToml } from './generateToml';\nimport { generateSchemaData, generateSchemaStructure } from './generateSchema';\nimport { generateDeployHook, generateMigrate } from './generateScript';\nimport { generateDappKey } from './generateDappKey';\nimport { generateSchemaEvent } from './generateEvent';\nimport { generateSystem } from './generateSystem';\nimport { generateSchemaHub } from './generateSchemaHub';\nimport { generateSchemaError } from './generateError';\nimport { generateDefaultSchema } from './generateDefaultSchema';\nimport { generateInit } from './generateInit';\n\nexport async function schemaGen(\n config: DubheConfig,\n srcPrefix?: string,\n network?: 'mainnet' | 'testnet' | 'devnet' | 'localnet'\n) {\n console.log('\\n🚀 Starting Schema Generation Process...');\n console.log('📋 Project Configuration:');\n console.log(` └─ Name: ${config.name}`);\n console.log(` └─ Description: ${config.description || 'No description provided'}`);\n console.log(` └─ Network: ${network || 'testnet'}`);\n\n const path = srcPrefix ?? process.cwd();\n\n if (existsSync(`${path}/contracts/${config.name}`)) {\n deleteFolderRecursive(`${path}/contracts/${config.name}/sources/codegen`);\n }\n\n if (!existsSync(`${path}/contracts/${config.name}/Move.toml`)) {\n await generateToml(config, path);\n }\n\n if (!existsSync(`${path}/contracts/${config.name}/sources/script/deploy_hook.move`)) {\n await generateDeployHook(config, path);\n }\n\n if (config.events) {\n if (config.data) {\n await generateSchemaEvent(config.name, config.data, config.events, path);\n } else {\n await generateSchemaEvent(config.name, null, config.events, path);\n }\n }\n\n if (config.data) {\n await generateSchemaData(config.name, config.data, path);\n await generateSchemaStructure(config.name, config.data, config.schemas, path);\n } else {\n await generateSchemaStructure(config.name, null, config.schemas, path);\n }\n\n if (config.errors) {\n await generateSchemaError(config.name, config.errors, path);\n }\n\n await generateDefaultSchema(config, path);\n await generateInit(config, path);\n await generateSystem(config, path);\n await generateMigrate(config, path);\n await generateDappKey(config, path);\n console.log('\\n✅ Schema Generation Process Complete!\\n');\n}\n","import { MoveType } from '../../types';\nimport fs from 'fs';\n\nexport function deleteFolderRecursive(path: string) {\n if (fs.existsSync(path)) {\n fs.readdirSync(path).forEach((file) => {\n const curPath = `${path}/${file}`;\n if (fs.lstatSync(curPath).isDirectory()) {\n deleteFolderRecursive(curPath);\n } else {\n fs.unlinkSync(curPath);\n }\n });\n fs.rmdirSync(path);\n }\n}\n\nexport function capitalizeFirstLetter(input: string): string {\n return input.charAt(0).toUpperCase() + input.slice(1);\n}\n\n/**\n *\n * @param values\n * @param prefixArgs\n * @return [ name, age, birth_time ]\n */\nexport function getStructAttrs(values: Record<string, string> | string): string {\n return Object.entries(values)\n .map(([key, _]) => `${key}`)\n .join(',');\n}\n\nfunction isAddress(str: string): boolean {\n const regex = /^0x[a-fA-F0-9]+$/;\n return regex.test(str);\n}\n\n/**\n *\n * @param values\n * @return ( bool , u64 , u64)\n */\n// export function getStructTypes(values: SchemaType): string {\nexport function getStructTypes(values: Record<string, string>): string {\n return `(${Object.entries(values).map(([_, type]) => `${type}`)})`;\n}\n\n/**\n *\n * @param values\n * @return Attributes and types of the struct. [ name: string, age: u64 ]\n */\nexport function getStructAttrsWithType(values: Record<string, string>): string[] {\n return Object.entries(values).map(([key, type]) => `${key}: ${type}`);\n}\n\n/**\n * @param values\n * @return [ data.name, data.age ]\n */\nexport function getStructAttrsQuery(values: Record<string, string>): string[] {\n return Object.entries(values).map(([key, _]) => `self.${key}`);\n}\n\nexport function containsString(obj: Record<string, any>, searchString: string): boolean {\n for (const key in obj) {\n if (obj.hasOwnProperty(key)) {\n const value = obj[key];\n if (\n (typeof value === 'string' && value === searchString) ||\n (typeof value === 'string' && value.includes(searchString) && value.includes('>'))\n ) {\n return true;\n }\n }\n }\n return false;\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateToml(config: DubheConfig, srcPrefix: string) {\n console.log('\\n📄 Starting Move.toml Generation...');\n console.log(` └─ Output path: ${srcPrefix}/contracts/${config.name}/Move.toml`);\n\n let code = `[package]\nname = \"${config.name}\"\nversion = \"1.0.0\"\nedition = \"2024\"\n\n[dependencies]\nSui = { git = \"https://github.com/MystenLabs/sui.git\", subdir = \"crates/sui-framework/packages/sui-framework\", rev = \"mainnet-v1.38.3\" }\nDubhe = { git = \"https://github.com/0xobelisk/dubhe-framework.git\", rev = \"dubhe-mainnet-v1.1.0\" }\n${config.plugins?.length ? config.plugins.map((plugin) => `${plugin} = { git = \"https://github.com/0xobelisk/merak.git\", rev = \"main\", subdir = \"contracts/${plugin}\" }`).join('\\n') : '' }\n\n[addresses]\nsui = \"0x2\"\n${config.name} = \"0x0\"\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/Move.toml`,\n 'formatAndWriteMove'\n );\n console.log('✅ Move.toml Generation Complete\\n');\n}\n","import { BaseType, SchemaData, SchemaType } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport {\n getStructAttrsWithType,\n getStructAttrs,\n getStructTypes,\n getStructAttrsQuery,\n containsString\n} from './common';\n\nfunction sortByFirstLetter(arr: string[]): string[] {\n return arr.sort((a, b) => {\n const firstLetterA = a.charAt(0).toLowerCase();\n const firstLetterB = b.charAt(0).toLowerCase();\n\n if (firstLetterA < firstLetterB) {\n return -1;\n }\n if (firstLetterA > firstLetterB) {\n return 1;\n }\n return 0;\n });\n}\n\nexport function capitalizeAndRemoveUnderscores(input: string): string {\n return input\n .split('_')\n .map((word, index) => {\n return index === 0\n ? word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n : word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();\n })\n .join('');\n}\n\nexport function renderSetAttrsFunc(\n schemaName: string,\n fields: BaseType | Record<string, BaseType>\n): string {\n return Object.entries(fields)\n .map(\n ([key, type]) =>\n `public(package) fun set_${key}(self: &mut ${schemaName}, ${key}: ${type}) {\n self.${key} = ${key};\n }`\n )\n .join('\\n');\n}\n\nexport function renderSetFunc(schemaName: string, fields: Record<string, string>): string {\n return `public(package) fun set(self: &mut ${schemaName}, ${getStructAttrsWithType(fields)}) {\n ${Object.entries(fields)\n .map(([fieldName]) => `self.${fieldName} = ${fieldName};`)\n .join('\\n')}\n }`;\n}\n\nexport function renderGetAllFunc(schemaName: string, fields: Record<string, string>): string {\n return `public fun get(self: &${schemaName}): ${getStructTypes(fields)} {\n (${getStructAttrsQuery(fields)})\n }`;\n}\n\nexport function renderGetAttrsFunc(\n schemaName: string,\n fields: BaseType | Record<string, BaseType>\n): string {\n return Object.entries(fields)\n .map(\n ([key, type]) => `public fun get_${key}(self: &${schemaName}): ${type} {\n self.${key}\n }`\n )\n .join('\\n');\n}\n\nfunction convertToSnakeCase(input: string): string {\n return input\n .replace(/([A-Z])/g, '_$1')\n .toLowerCase()\n .replace(/^_/, '');\n}\n\nexport async function generateSchemaData(\n projectName: string,\n data: Record<string, SchemaData>,\n path: string\n) {\n console.log('\\n📦 Starting Schema Data Generation...');\n for (const key of Object.keys(data)) {\n const name = key;\n const fields = data[key];\n console.log(\n ` └─ ${name} ${Array.isArray(fields) ? '(enum)' : '(struct)'}: ${JSON.stringify(fields)}`\n );\n let code = '';\n\n const enumNames = Object.keys(data)\n .filter((item) => Array.isArray(data[item]))\n .map((item) => item);\n\n if (Array.isArray(fields)) {\n const sortByFirstLetterFields = sortByFirstLetter(fields);\n code = `module ${projectName}::${projectName}_${convertToSnakeCase(name)} {\n public enum ${name} has copy, drop , store {\n ${sortByFirstLetterFields}\n }\n \n ${sortByFirstLetterFields\n .map((field: string) => {\n return `public fun new_${convertToSnakeCase(field)}(): ${name} {\n ${name}::${field}\n }`;\n })\n .join('')}`;\n } else {\n code = `module ${projectName}::${projectName}_${convertToSnakeCase(name)} {\n use std::ascii::String;\n \n\t\t\t\t\t\t${Object.keys(data)\n .map((name) => {\n if (containsString(fields, name)) {\n return `use ${projectName}::${projectName}_${convertToSnakeCase(name)}::${name};`;\n }\n return undefined;\n })\n .filter(Boolean)\n .join('\\n')}\n\n public struct ${name} has copy, drop , store {\n ${getStructAttrsWithType(fields)}\n }\n \n public fun new(${getStructAttrsWithType(fields)}): ${name} {\n ${name} {\n ${getStructAttrs(fields)}\n }\n }\n \n ${renderGetAllFunc(name, fields)}\n ${renderGetAttrsFunc(name, fields)}\n ${renderSetAttrsFunc(name, fields)}\n ${renderSetFunc(name, fields)}\n }`;\n }\n\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/data/${convertToSnakeCase(name)}.move`,\n 'formatAndWriteMove'\n );\n }\n}\n\nfunction generateImport(projectName: string, data: Record<string, SchemaData> | null) {\n if (data != null) {\n const names = Object.keys(data);\n return names\n .map((name) => {\n return `use ${projectName}::${projectName}_${convertToSnakeCase(name)}::${name};`;\n })\n .join('\\n');\n } else {\n return '';\n }\n}\n\nexport async function generateSchemaStructure(\n projectName: string,\n data: Record<string, SchemaData> | null,\n schemas: Record<string, SchemaType>,\n path: string\n) {\n console.log('\\n📦 Starting Schema Structure Generation...');\n Object.entries(schemas).forEach(([key, value]) => {\n console.log(` └─ ${key}: ${value}`);\n });\n const schemaMoudle = `module ${projectName}::${projectName}_schema {\n use std::ascii::String;\n use std::ascii::string;\n use sui::package::UpgradeCap;\n use std::type_name; \n use dubhe::storage;\n use dubhe::storage_value::{Self, StorageValue};\n use dubhe::storage_map::{Self, StorageMap};\n use dubhe::storage_double_map::{Self, StorageDoubleMap};\n use sui::dynamic_field as df;\n use ${projectName}::${projectName}_dapp_metadata::DappMetadata;\n \n ${generateImport(projectName, data)}\n\n public struct Schema has key, store { id: UID } \n\n // Default storage\n public fun borrow_dapp__admin(self: &Schema): &StorageValue<address> {\n storage::borrow_field(&self.id, b\"dapp__admin\")\n }\n\n public fun borrow_dapp__package_id(self: &Schema): &StorageValue<address> {\n storage::borrow_field(&self.id, b\"dapp__package_id\")\n }\n\n public fun borrow_dapp__version(self: &Schema): &StorageValue<u32> {\n storage::borrow_field(&self.id, b\"dapp__version\")\n }\n\n public fun borrow_dapp__metadata(self: &Schema): &StorageValue<DappMetadata> {\n storage::borrow_field(&self.id, b\"dapp__metadata\")\n }\n\n public fun borrow_dapp__safe_mode(self: &Schema): &StorageValue<bool> {\n storage::borrow_field(&self.id, b\"dapp__safe_mode\")\n }\n\n public fun borrow_dapp__authorised_schemas(self: &Schema): &StorageValue<vector<address>> {\n storage::borrow_field(&self.id, b\"dapp__authorised_schemas\")\n }\n\n public fun borrow_dapp__schemas(self: &Schema): &StorageValue<vector<address>> {\n storage::borrow_field(&self.id, b\"dapp__schemas\")\n }\n\n public(package) fun dapp__admin(self: &mut Schema): &mut StorageValue<address> {\n storage::borrow_mut_field(&mut self.id, b\"dapp__admin\")\n }\n\n public(package) fun dapp__package_id(self: &mut Schema): &mut StorageValue<address> {\n storage::borrow_mut_field(&mut self.id, b\"dapp__package_id\")\n }\n\n public(package) fun dapp__version(self: &mut Schema): &mut StorageValue<u32> {\n storage::borrow_mut_field(&mut self.id, b\"dapp__version\")\n }\n\n public(package) fun dapp__metadata(self: &mut Schema): &mut StorageValue<DappMetadata> {\n storage::borrow_mut_field(&mut self.id, b\"dapp__metadata\")\n }\n\n public(package) fun dapp__safe_mode(self: &mut Schema): &mut StorageValue<bool> {\n storage::borrow_mut_field(&mut self.id, b\"dapp__safe_mode\")\n }\n\n public(package) fun dapp__authorised_schemas(self: &mut Schema): &mut StorageValue<vector<address>> {\n storage::borrow_mut_field(&mut self.id, b\"dapp__authorised_schemas\")\n }\n \n ${Object.entries(schemas)\n .map(([key, value]) => {\n return `public fun borrow_${key}(self: &Schema) : &${value} {\n storage::borrow_field(&self.id, b\"${key}\")\n }\n \n public(package) fun ${key}(self: &mut Schema): &mut ${value} {\n storage::borrow_mut_field(&mut self.id, b\"${key}\")\n }\n `;\n })\n .join('')} \n \n \n public(package) fun create(ctx: &mut TxContext): Schema {\n let mut id = object::new(ctx);\n ${Object.entries(schemas)\n .map(([key, value]) => {\n let storage_type = '';\n if (value.includes('StorageValue')) {\n storage_type = `storage_value::new(b\"${key}\", ctx)`;\n } else if (value.includes('StorageMap')) {\n storage_type = `storage_map::new(b\"${key}\", ctx)`;\n } else if (value.includes('StorageDoubleMap')) {\n storage_type = `storage_double_map::new(b\"${key}\", ctx)`;\n }\n return `storage::add_field<${value}>(&mut id, b\"${key}\", ${storage_type});`;\n })\n .join('\\n')}\n \n Schema { id }\n }\n \n public(package) fun id(self: &mut Schema): &mut UID {\n\t\t\t\t\t &mut self.id\n\t\t\t\t\t}\n\t\t\t\t\n\t\t\t\t\tpublic(package) fun borrow_id(self: &Schema): &UID {\n\t\t\t\t\t &self.id\n\t\t\t\t\t}\n \n public fun migrate(_schema: &mut Schema, _ctx: &mut TxContext) { }\n\n\n public(package) fun upgrade(schema: &mut Schema, new_package_id: address, new_version: u32, ctx: &mut TxContext) {\n assert!(schema.dapp__metadata().contains(), 0);\n assert!(schema.dapp__admin().get() == ctx.sender(), 0);\n schema.dapp__package_id().set(new_package_id);\n let current_version = schema.dapp__version()[];\n assert!(current_version < new_version, 0);\n schema.dapp__version().set(new_version);\n schema.migrate(ctx);\n }\n\n \n // ======================================== View Functions ========================================\n ${Object.entries(schemas)\n .map(([key, value]) => {\n // @ts-ignore\n let all_types = value\n .match(/<(.+)>/)[1]\n .split(',')\n .map((type) => type.trim());\n let para_key: string[] = [];\n let para_value = '';\n let borrow_key = '';\n if (value.includes('StorageValue')) {\n para_key = [];\n para_value = `${all_types[0]}`;\n borrow_key = 'get()';\n } else if (value.includes('StorageMap')) {\n para_key = [`key: ${all_types[0]}`];\n para_value = `${all_types[1]}`;\n borrow_key = 'get(key)';\n } else if (value.includes('StorageDoubleMap')) {\n para_key = [`key1: ${all_types[0]}`, `key2: ${all_types[1]}`];\n para_value = `${all_types[2]}`;\n borrow_key = 'get(key1, key2)';\n }\n return `public fun get_${key}(self: &Schema, ${para_key}) : &${para_value} {\n\t\t\t\t\t\t\t\t\tself.borrow_${key}().${borrow_key}\n\t\t\t\t\t\t\t\t}`;\n })\n .join('\\n')}\n // =========================================================================================================\n\t\t\t}`;\n await formatAndWriteMove(\n schemaMoudle,\n\n `${path}/contracts/${projectName}/sources/codegen/core/schema.move`,\n 'formatAndWriteMove'\n );\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\nimport { capitalizeAndRemoveUnderscores } from './generateSchema';\n\nimport { readFileSync } from 'fs';\n\nfunction capitalizeFirstLetter(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nexport async function generateDeployHook(config: DubheConfig, srcPrefix: string) {\n const path = `${srcPrefix}/contracts/${config.name}/sources/scripts/deploy_hook.move`;\n if (!existsSync(path)) {\n const code = `module ${config.name}::${config.name}_deploy_hook {\n\t\t\t use ${config.name}::${config.name}_schema::Schema;\n ${config.plugins?.length ? config.plugins.map((plugin) => `use ${plugin}::${plugin}_schema::Schema as ${capitalizeFirstLetter(plugin)}Schema;`).join('\\n') : '' }\n\n public(package) fun run(_schema: &mut Schema, ${config.plugins?.length ? config.plugins.map((plugin) => `_${plugin}_schema: &mut ${capitalizeFirstLetter(plugin)}Schema`).join(', ') + ', ' : ''} _ctx: &mut TxContext) {\n\n }\n}`;\n await formatAndWriteMove(code, path, 'formatAndWriteMove');\n }\n}\n\nexport async function generateMigrate(config: DubheConfig, srcPrefix: string) {\n if (!existsSync(`${srcPrefix}/contracts/${config.name}/sources/scripts/migrate.move`)) {\n let code = `module ${config.name}::${config.name}_migrate {\n const ON_CHAIN_VERSION: u32 = 1;\n\n public fun on_chain_version(): u32 {\n ON_CHAIN_VERSION\n }\n}\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/scripts/migrate.move`,\n 'formatAndWriteMove'\n );\n }\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateDappKey(config: DubheConfig, srcPrefix: string) {\n let code = `module ${config.name}::${config.name}_dapp_key {\n\\t/// Authorization token for the app.\n\\tpublic struct DappKey has copy, drop {}\n\n\\tpublic(package) fun new(): DappKey {\n\\t\\tDappKey { }\n\\t}\n}\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/codegen/core/dapp_key.move`,\n 'formatAndWriteMove'\n );\n}\n","import { BaseType, EventData, SchemaData, SchemaType } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport {\n getStructAttrsWithType,\n getStructAttrs,\n getStructTypes,\n getStructAttrsQuery\n} from './common';\n\n// account_not_found => AccountNotFound,\nfunction toPascalCase(str: string): string {\n return str\n .split('_')\n .map((word) => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())\n .join('');\n}\n\nfunction convertToSnakeCase(input: string): string {\n return input\n .replace(/([A-Z])/g, '_$1')\n .toLowerCase()\n .replace(/^_/, '');\n}\n\nfunction generateImport(projectName: string, data: Record<string, SchemaData> | null) {\n if (data != null) {\n const names = Object.keys(data);\n return names\n .map((name) => {\n return `use ${projectName}::${projectName}_${convertToSnakeCase(name)}::${name};`;\n })\n .join('\\n');\n } else {\n return '';\n }\n}\n\nexport async function generateSchemaEvent(\n projectName: string,\n data: Record<string, SchemaData> | null,\n events: Record<string, EventData>,\n path: string\n) {\n console.log('\\n📦 Starting Schema Event Generation...');\n for (const key of Object.keys(events)) {\n const name = key;\n const fields = events[key];\n console.log(` └─ ${name} event: ${JSON.stringify(fields)}`);\n\n let code = `module ${projectName}::${projectName}_${name}_event {\n\t\t\t\t\t\tuse sui::event;\n\t\t\t\t\t\tuse std::ascii::String;\n\t\t\t\t\t\t${generateImport(projectName, data)}\n\n public struct ${toPascalCase(name)}Event has copy, drop {\n ${getStructAttrsWithType(fields as Record<string, string>)}\n }\n\n public fun new(${getStructAttrsWithType(fields as Record<string, string>)}): ${toPascalCase(name)}Event {\n ${toPascalCase(name)}Event {\n ${getStructAttrs(fields as Record<string, string>)}\n }\n }\n }`;\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/data/${name}_event.move`,\n 'formatAndWriteMove'\n );\n }\n\n let code = `module ${projectName}::${projectName}_events {\n\t \tuse std::ascii::{String, string};\n\t \t${generateImport(projectName, data)}\n\t\t${Object.entries(events)\n .map(([name, fields]) => {\n return `\nuse ${projectName}::${projectName}_${name}_event::${toPascalCase(name)}Event;\nuse ${projectName}::${projectName}_${name}_event;\n\t\t\tpublic fun ${name}_event(${getStructAttrsWithType(fields as Record<string, string>)}) {\n\t\t\t dubhe::storage_event::emit_set_record<${toPascalCase(name)}Event, ${toPascalCase(name)}Event, ${toPascalCase(name)}Event>(\n\t\t\t\tstring(b\"${name}_event\"),\n\t\t\t\toption::none(),\n\t\t\t \toption::none(),\n\t\t\t option::some(${projectName}_${name}_event::new(${getStructAttrs(fields as Record<string, string>)}))\n\t\t\t )\n\t\t\t}\n\t\t`;\n })\n .join('\\n')}\t\t\n }`;\n\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/events.move`,\n 'formatAndWriteMove'\n );\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\n\nexport async function generateSystem(config: DubheConfig, srcPrefix: string) {\n if (!existsSync(`${srcPrefix}/contracts/${config.name}/sources/systems`)) {\n await fs.mkdir(`${srcPrefix}/contracts/${config.name}/sources/systems`, { recursive: true });\n }\n}\n","import { BaseType, ErrorData, SchemaType } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport {\n getStructAttrsWithType,\n getStructAttrs,\n getStructTypes,\n getStructAttrsQuery\n} from './common';\n\nfunction convertToSnakeCase(input: string): string {\n return input\n .replace(/([A-Z])/g, '_$1')\n .toLowerCase()\n .replace(/^_/, '');\n}\n\nexport async function generateSchemaError(projectName: string, errors: ErrorData, path: string) {\n console.log('\\n📦 Starting Schema Error Generation...');\n\n let code = `module ${projectName}::${projectName}_errors {\n\t\t${Object.entries(errors)\n .map(([name, message]) => {\n console.log(` └─ ${name}: ${message}`);\n return `#[error]\n\t\t\t\tconst ${name.toUpperCase()}: vector<u8> = b\"${message}\";\n\t\t\t\tpublic fun ${name}_error(condition: bool) { assert!(condition, ${name.toUpperCase()}) }\n\t\t`;\n })\n .join('\\n')}\t\t\n }`;\n\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/errors.move`,\n 'formatAndWriteMove'\n );\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\nimport { capitalizeAndRemoveUnderscores } from './generateSchema';\n\nexport async function generateDefaultSchema(config: DubheConfig, srcPrefix: string) {\n await generateDappSchemaMetadata(config, srcPrefix);\n await generateDappSystem(config, srcPrefix);\n}\n\nasync function generateDappSchemaMetadata(config: DubheConfig, srcPrefix: string) {\n const path = `${srcPrefix}/contracts/${config.name}/sources/codegen/core/metadata.move`;\n if (!existsSync(path)) {\n let code = `module ${config.name}::${config.name}_dapp_metadata {\n use std::ascii::String;\n\n public struct DappMetadata has drop, copy, store {\n name: String,\n description: String,\n cover_url: vector<String>,\n website_url: String,\n created_at: u64,\n partners: vector<String>,\n }\n\n public fun new(\n name: String,\n description: String,\n cover_url: vector<String>,\n website_url: String,\n created_at: u64,\n partners: vector<String>,\n ): DappMetadata {\n DappMetadata {\n name,\n description,\n cover_url,\n website_url,\n created_at,\n partners,\n }\n }\n\n public fun set(\n self: &mut DappMetadata,\n name: String,\n description: String,\n cover_url: vector<String>,\n website_url: String,\n created_at: u64,\n partners: vector<String>,\n ) {\n self.name = name;\n self.description = description;\n self.cover_url = cover_url;\n self.website_url = website_url;\n self.created_at = created_at;\n self.partners = partners;\n }\n\n public fun set_name(self: &mut DappMetadata, name: String) {\n self.name = name;\n }\n\n public fun set_description(self: &mut DappMetadata, description: String) {\n self.description = description;\n }\n\n public fun set_cover_url(self: &mut DappMetadata, cover_url: vector<String>) {\n self.cover_url = cover_url;\n }\n\n public fun set_website_url(self: &mut DappMetadata, website_url: String) {\n self.website_url = website_url;\n }\n\n public fun set_created_at(self: &mut DappMetadata, created_at: u64) {\n self.created_at = created_at;\n }\n\n public fun set_partners(self: &mut DappMetadata, partners: vector<String>) {\n self.partners = partners;\n }\n\n public fun get_name(self: &DappMetadata): String {\n self.name\n }\n\n public fun get_description(self: &DappMetadata): String {\n self.description\n }\n\n public fun get_cover_url(self: &DappMetadata): vector<String> {\n self.cover_url\n }\n\n public fun get_website_url(self: &DappMetadata): String {\n self.website_url\n }\n\n public fun get_created_at(self: &DappMetadata): u64 {\n self.created_at\n }\n\n public fun get_partners(self: &DappMetadata): vector<String> {\n self.partners\n }\n}\n`;\n await formatAndWriteMove(code, path, 'formatAndWriteMove');\n }\n}\n\nasync function generateDappSystem(config: DubheConfig, srcPrefix: string) {\n const path = `${srcPrefix}/contracts/${config.name}/sources/codegen/core/system.move`;\n if (!existsSync(path)) {\n let code = `module ${config.name}::${config.name}_dapp_system {\n use std::ascii::String;\n use std::ascii;\n use dubhe::type_info;\n use sui::clock::Clock;\n use sui::transfer::public_share_object;\n use ${config.name}::${config.name}_schema::Schema;\n use ${config.name}::${config.name}_dapp_metadata;\n use ${config.name}::${config.name}_dapp_metadata::DappMetadata;\n use dubhe::storage::add_field;\n use dubhe::storage_value;\n use dubhe::storage_value::StorageValue;\n\n public entry fun set_metadata(\n schema: &mut Schema,\n name: String,\n description: String,\n cover_url: vector<String>,\n website_url: String,\n partners: vector<String>,\n ctx: &TxContext,\n ) {\n let admin = schema.dapp__admin().try_get();\n assert!(admin == option::some(ctx.sender()), 0);\n let created_at = schema.dapp__metadata().get().get_created_at();\n schema.dapp__metadata().set(\n ${config.name}_dapp_metadata::new(\n name,\n description,\n cover_url,\n website_url,\n created_at,\n partners\n )\n );\n }\n\n\n public entry fun transfer_ownership(schema: &mut Schema, new_admin: address, ctx: &mut TxContext) {\n let admin = schema.dapp__admin().try_get();\n assert!(admin == option::some(ctx.sender()), 0);\n schema.dapp__admin().set(new_admin);\n }\n\n public entry fun set_safe_mode(schema: &mut Schema, safe_mode: bool, ctx: &TxContext) {\n let admin = schema.dapp__admin().try_get();\n assert!(admin == option::some(ctx.sender()), 0);\n schema.dapp__safe_mode().set(safe_mode);\n }\n\n public fun ensure_no_safe_mode(schema: &mut Schema) {\n assert!(!schema.dapp__safe_mode()[], 0);\n }\n\n public fun ensure_has_authority(schema: &mut Schema, ctx: &TxContext) {\n assert!(schema.dapp__admin().get() == ctx.sender(), 0);\n }\n\n public fun ensure_has_schema<S: key + store>(schema: &mut Schema, new_schema: &S) {\n let schema_id = object::id_address(new_schema);\n assert!(schema.dapp__authorised_schemas().get().contains(&schema_id), 0);\n }\n\n public(package) fun create(schema: &mut Schema, name: String, description: String, clock: &Clock, ctx: &mut TxContext){\n add_field<StorageValue<address>>(schema.id(), b\"dapp__admin\", storage_value::new(b\"dapp__admin\", ctx));\n add_field<StorageValue<address>>(schema.id(), b\"dapp__package_id\", storage_value::new(b\"dapp__package_id\", ctx));\n add_field<StorageValue<u32>>(schema.id(), b\"dapp__version\", storage_value::new(b\"dapp__version\", ctx));\n add_field<StorageValue<DappMetadata>>(schema.id(), b\"dapp__metadata\", storage_value::new(b\"dapp__metadata\", ctx));\n add_field<StorageValue<bool>>(schema.id(), b\"dapp__safe_mode\", storage_value::new(b\"dapp__safe_mode\", ctx));\n add_field<StorageValue<vector<address>>>(schema.id(), b\"dapp__authorised_schemas\", storage_value::new(b\"dapp__authorised_schemas\", ctx));\n schema.dapp__metadata().set(\n ${config.name}_dapp_metadata::new(\n name,\n description,\n vector[],\n ascii::string(b\"\"),\n clock.timestamp_ms(),\n vector[]\n )\n );\n let package_id = type_info::current_package_id<Schema>();\n schema.dapp__package_id().set(package_id);\n schema.dapp__admin().set(ctx.sender());\n schema.dapp__version().set(1);\n schema.dapp__safe_mode().set(false);\n schema.dapp__authorised_schemas().set(vector[]);\n }\n\n public(package) fun add_schema<S: key + store>(schema: &mut Schema, new_schema: S) {\n let mut schemas = schema.dapp__authorised_schemas()[];\n schemas.push_back(object::id_address<S>(&new_schema));\n schema.dapp__authorised_schemas().set(schemas);\n public_share_object(new_schema);\n }\n}\n\n`;\n await formatAndWriteMove(code, path, 'formatAndWriteMove');\n }\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\nimport { capitalizeAndRemoveUnderscores } from './generateSchema';\n\nfunction capitalizeFirstLetter(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nexport async function generateInit(config: DubheConfig, srcPrefix: string) {\n let init_test_code = `module ${config.name}::${config.name}_init_test {\n use sui::clock;\n use sui::test_scenario;\n use sui::test_scenario::Scenario;\n ${config.plugins?.length ? config.plugins.map((plugin) => `use ${plugin}::${plugin}_schema::Schema as ${capitalizeFirstLetter(plugin)}Schema;`).join('\\n') : ''}\n \n public fun deploy_dapp_for_testing(scenario: &mut Scenario, ${config.plugins?.length ? config.plugins.map((plugin) => `${plugin}_schema: &mut ${capitalizeFirstLetter(plugin)}Schema`).join(', ') : ''}) {\n let ctx = test_scenario::ctx(scenario);\n let clock = clock::create_for_testing(ctx);\n ${config.name}::${config.name}_genesis::run(&clock, ${config.plugins?.length ? config.plugins.map((plugin) => `${plugin}_schema`).join(', ') + ', ' : ''} ctx);\n clock::destroy_for_testing(clock);\n test_scenario::next_tx(scenario, ctx.sender());\n }\n}\n`;\n await formatAndWriteMove(\n init_test_code,\n `${srcPrefix}/contracts/${config.name}/sources/codegen/core/init_test.move`,\n 'formatAndWriteMove'\n );\n\n let init_code = `module ${config.name}::${config.name}_genesis {\n use std::ascii::string;\n\n use sui::clock::Clock;\n\n use ${config.name}::${config.name}_dapp_system;\n ${config.plugins?.length ? config.plugins.map((plugin) => `use ${plugin}::${plugin}_schema::Schema as ${capitalizeFirstLetter(plugin)}Schema;`).join('\\n') : ''}\n public entry fun run(clock: &Clock, ${config.plugins?.length ? config.plugins.map((plugin) => `${plugin}_schema: &mut ${capitalizeFirstLetter(plugin)}Schema`).join(', ') + ', ' : ''} ctx: &mut TxContext) {\n // Create schemas\n let mut schema = ${config.name}::${config.name}_schema::create(ctx);\n // Setup default storage\n ${config.name}_dapp_system::create(&mut schema, string(b\"${config.name}\"),string(b\"${config.description}\"), clock , ctx);\n // Logic that needs to be automated once the contract is deployed\n ${config.name}::${config.name}_deploy_hook::run(&mut schema, ${config.plugins?.length ? config.plugins.map((plugin) => `${plugin}_schema`).join(', ') + ', ' : ''} ctx);\n // Authorize schemas and public share objects\n sui::transfer::public_share_object(schema);\n }\n}\n`;\n await formatAndWriteMove(\n init_code,\n\n `${srcPrefix}/contracts/${config.name}/sources/codegen/core/genesis.move`,\n 'formatAndWriteMove'\n );\n}\n","import { findUp } from 'find-up';\nimport path from 'path';\nimport esbuild from 'esbuild';\nimport { NotInsideProjectError } from './errors';\nimport { rmSync } from 'fs';\nimport { pathToFileURL } from 'url';\nimport os from 'os';\n\n// In order of preference files are checked\nconst configFiles = ['dubhe.config.js', 'dubhe.config.mjs', 'dubhe.config.ts', 'dubhe.config.mts'];\nconst TEMP_CONFIG = 'dubhe.config.example.mjs';\n\nexport async function loadConfig(configPath?: string): Promise<unknown> {\n configPath = await resolveConfigPath(configPath);\n try {\n await esbuild.build({\n entryPoints: [configPath],\n format: 'esm',\n outfile: TEMP_CONFIG,\n // https://esbuild.github.io/getting-started/#bundling-for-node\n platform: 'node',\n // bundle local imports (otherwise it may error, js can't import ts)\n bundle: true,\n // avoid bundling external imports (it's unnecessary and esbuild can't handle all node features)\n packages: 'external'\n });\n configPath = await resolveConfigPath(TEMP_CONFIG, true);\n // Node.js caches dynamic imports, so without appending a cache breaking\n // param like `?update={Date.now()}` this import always returns the same config\n // if called multiple times in a single process, like the `dev-contracts` cli\n return (await import(configPath + `?update=${Date.now()}`)).dubheConfig;\n } finally {\n rmSync(TEMP_CONFIG, { force: true });\n }\n}\n\nexport async function resolveConfigPath(configPath: string | undefined, toFileURL?: boolean) {\n if (configPath === undefined) {\n configPath = await getUserConfigPath();\n } else {\n if (!path.isAbsolute(configPath)) {\n configPath = path.join(process.cwd(), configPath);\n configPath = path.normalize(configPath);\n }\n }\n\n // Add `file:///` for Windows support\n // (see https://github.com/nodejs/node/issues/31710)\n return toFileURL && os.platform() === 'win32' ? pathToFileURL(configPath).href : configPath;\n}\n\nasync function getUserConfigPath() {\n const tsConfigPath = await findUp(configFiles);\n if (tsConfigPath === undefined) {\n throw new NotInsideProjectError();\n }\n return tsConfigPath;\n}\n","export class NotInsideProjectError extends Error {\n name = 'NotInsideProjectError';\n message = 'You are not inside a Dubhe project';\n}\n","export type BaseType =\n | 'String'\n | 'vector<String>'\n | 'address'\n | 'bool'\n | 'u8'\n | 'u32'\n | 'u64'\n | 'u128'\n | 'vector<address>'\n | 'vector<bool>'\n | 'vector<u8>'\n | 'vector<vector<u8>>'\n | 'vector<u32>'\n | 'vector<u64>'\n | 'vector<u128>'\n | string;\n\nexport type StorageDataType = 'Struct' | 'Enum';\n\nexport type StorageMapType = 'Map' | 'Bag' | 'Table';\n\ntype Address = string;\ntype Bool = boolean;\ntype U8 = number;\ntype U32 = number;\ntype U64 = number;\ntype U128 = number;\ntype Vector<T> = T[];\n\nexport type BaseValueType =\n | String\n | Address\n | Bool\n | U8\n | U32\n | U64\n | U128\n | Vector<Address>\n | Vector<Bool>\n | Vector<U8>\n | Vector<Vector<U8>>\n | Vector<U64>\n | Vector<U128>;\n\nexport type SchemaData = Record<string, string> | string[];\nexport type SchemaType = string;\nexport type EventData = Record<string, string>;\nexport type ErrorData = Record<string, string>;\n\ntype DataType = any;\n\nexport function storage<T extends DataType>(value: T): SchemaType;\nexport function storage<K extends DataType, V extends DataType>(key: K, value: V): SchemaType;\nexport function storage<K1 extends DataType, K2 extends DataType, V extends DataType>(\n key1: K1,\n key2: K2,\n value: V\n): SchemaType;\nexport function storage(...args: DataType[]): SchemaType {\n if (args.length === 1) {\n return `StorageValue<${args[0]}>`;\n } else if (args.length === 2) {\n return `StorageMap<${args[0]}, ${args[1]}>`;\n } else if (args.length === 3) {\n return `StorageDoubleMap<${args[0]}, ${args[1]}, ${args[2]}>`;\n }\n throw new Error('Invalid number of arguments for storage()');\n}\n\nexport type Plugin = 'merak';\n\nexport type DubheConfig = {\n name: string;\n description: string;\n data?: Record<string, SchemaData>;\n schemas: Record<string, SchemaType>;\n events?: Record<string, EventData>;\n errors?: ErrorData;\n plugins?: Plugin[];\n};\n\nexport type MoveType =\n | 'string'\n | 'vector<string>'\n | 'String'\n | 'vector<String>'\n | 'address'\n | 'bool'\n | 'u8'\n | 'u32'\n | 'u64'\n | 'u128'\n | 'vector<address>'\n | 'vector<bool>'\n | 'vector<u8>'\n | 'vector<vector<u8>>'\n | 'vector<u32>'\n | 'vector<u64>'\n | 'vector<u128>';\n","export const parseData = (data: any) => {\n if (typeof data !== 'object' || data === null) {\n return data;\n }\n const parsedData: any = {};\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n // @ts-ignore\n const value = data[key];\n // console.log(\"===========\", value)\n if (typeof value === 'object' && value !== null) {\n if (Array.isArray(value)) {\n parsedData[key] = handleArray(value);\n } else if (value.hasOwnProperty('variant')) {\n parsedData[key] = { [value.variant]: {} };\n } else if (value.hasOwnProperty('fields')) {\n parsedData[key] = parseData(value.fields);\n } else {\n parsedData[key] = parseData(value);\n }\n } else {\n parsedData[key] = value;\n }\n }\n }\n return parsedData;\n};\n\nconst handleArray = (data: any[]): any[] => {\n let returnData: any[] = [];\n data.forEach((item) => {\n if (typeof item === 'object' && item !== null) {\n if (Array.isArray(item)) {\n returnData.push(handleArray(item));\n } else if (item.hasOwnProperty('variant')) {\n returnData.push({ [item.variant]: {} });\n } else if (item.hasOwnProperty('fields')) {\n returnData.push(parseData(item.fields));\n } else {\n returnData.push(parseData(item));\n }\n } else {\n returnData.push(item);\n }\n });\n return returnData;\n};\n","export enum SubscriptionKind {\n Event = 'event',\n Schema = 'schema'\n}\n\nexport type SubscribableType =\n | { kind: SubscriptionKind.Event; name?: string; sender?: string }\n | { kind: SubscriptionKind.Schema; name?: string };\n"],"mappings":"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","names":["prettier","prettierPluginMove","formatMove","content","prettierConfigPath","config","error","message","formatTypescript","fs","path","createDebug","debug","error","debug","error","formatAndWriteMove","output","fullOutputPath","logPrefix","formattedOutput","formatMove","schemaPrefix","initPrefix","code","deployHookPrefix","fs","path","debug","formatAndWriteTypescript","formatTypescript","posixPath","path","existsSync","fs","deleteFolderRecursive","path","file","curPath","getStructAttrs","values","key","_","getStructTypes","values","_","type","getStructAttrsWithType","key","getStructAttrsQuery","containsString","obj","searchString","value","generateToml","config","srcPrefix","code","plugin","formatAndWriteMove","sortByFirstLetter","arr","a","b","firstLetterA","firstLetterB","renderSetAttrsFunc","schemaName","fields","key","type","renderSetFunc","getStructAttrsWithType","fieldName","renderGetAllFunc","getStructTypes","getStructAttrsQuery","renderGetAttrsFunc","convertToSnakeCase","input","generateSchemaData","projectName","data","path","name","code","enumNames","item","sortByFirstLetterFields","sortByFirstLetter","field","containsString","getStructAttrs","formatAndWriteMove","generateImport","generateSchemaStructure","schemas","value","schemaMoudle","storage_type","all_types","para_key","para_value","borrow_key","existsSync","capitalizeFirstLetter","str","generateDeployHook","config","srcPrefix","path","code","plugin","formatAndWriteMove","generateMigrate","generateDappKey","config","srcPrefix","code","formatAndWriteMove","toPascalCase","str","word","convertToSnakeCase","input","generateImport","projectName","data","name","generateSchemaEvent","events","path","key","fields","code","getStructAttrsWithType","getStructAttrs","formatAndWriteMove","existsSync","fs","generateSystem","config","srcPrefix","generateSchemaError","projectName","errors","path","code","name","message","formatAndWriteMove","existsSync","generateDefaultSchema","config","srcPrefix","generateDappSchemaMetadata","generateDappSystem","path","code","formatAndWriteMove","capitalizeFirstLetter","str","generateInit","config","srcPrefix","init_test_code","plugin","formatAndWriteMove","init_code","schemaGen","config","srcPrefix","network","path","existsSync","deleteFolderRecursive","generateToml","generateDeployHook","generateSchemaEvent","generateSchemaData","generateSchemaStructure","generateSchemaError","generateDefaultSchema","generateInit","generateSystem","generateMigrate","generateDappKey","findUp","path","esbuild","NotInsideProjectError","rmSync","pathToFileURL","os","configFiles","TEMP_CONFIG","loadConfig","configPath","resolveConfigPath","esbuild","toFileURL","getUserConfigPath","path","tsConfigPath","findUp","NotInsideProjectError","storage","args","parseData","data","parsedData","key","value","handleArray","returnData","item","SubscriptionKind"]}
1
+ {"version":3,"sources":["../src/codegen/utils/format.ts","../src/codegen/utils/formatAndWrite.ts","../src/debug.ts","../src/codegen/debug.ts","../src/codegen/utils/posixPath.ts","../src/codegen/utils/renderMove/schemaGen.ts","../src/codegen/utils/renderMove/common.ts","../src/codegen/utils/renderMove/generateToml.ts","../src/codegen/utils/renderMove/generateSchema.ts","../src/codegen/utils/renderMove/generateScript.ts","../src/codegen/utils/renderMove/generateDappKey.ts","../src/codegen/utils/renderMove/generateEvent.ts","../src/codegen/utils/renderMove/generateSystem.ts","../src/codegen/utils/renderMove/generateError.ts","../src/codegen/utils/renderMove/generateInit.ts","../src/codegen/utils/config.ts","../src/codegen/utils/errors.ts","../src/codegen/types/index.ts","../src/parseData/parser/index.ts","../src/primitives/index.ts"],"sourcesContent":["import prettier from 'prettier';\nimport prettierPluginMove from 'prettier-plugin-move-js';\n\nexport async function formatMove(content: string, prettierConfigPath?: string): Promise<string> {\n let config;\n if (prettierConfigPath) {\n config = await prettier.resolveConfig(prettierConfigPath);\n }\n try {\n return prettier.format(content, {\n plugins: [prettierPluginMove],\n parser: 'move-parse',\n printWidth: 120,\n semi: true,\n tabWidth: 2,\n useTabs: false,\n bracketSpacing: true,\n ...config\n });\n } catch (error) {\n let message;\n if (error instanceof Error) {\n message = error.message;\n } else {\n message = error;\n }\n console.log(`Error during output formatting: ${message}`);\n return content;\n }\n}\n\nexport async function formatTypescript(content: string): Promise<string> {\n return prettier.format(content, {\n parser: 'typescript'\n });\n}\n","import fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { formatMove, formatTypescript } from './format';\nimport { debug } from '../debug';\n\nexport async function formatAndWriteMove(\n output: string,\n fullOutputPath: string,\n logPrefix?: string\n): Promise<void> {\n const formattedOutput = await formatMove(output);\n let schemaPrefix = ` // Copyright (c) Obelisk Labs, Inc.\n // SPDX-License-Identifier: Apache-2.0\n #[allow(unused_use)]\n \n /* Autogenerated file. Do not edit manually. */\n \n `;\n\n let initPrefix = `#[test_only]`;\n\n let code = schemaPrefix + formattedOutput;\n\n let deployHookPrefix = `#[allow(lint(share_owned))]`;\n\n if (\n fullOutputPath.includes('.toml') ||\n fullOutputPath.includes('system') ||\n fullOutputPath.includes('migrate')\n ) {\n code = formattedOutput;\n } else if (fullOutputPath.includes('init')) {\n code = initPrefix + formattedOutput;\n } else if (fullOutputPath.includes('genesis')) {\n code = deployHookPrefix + formattedOutput;\n }\n\n await fs.mkdir(path.dirname(fullOutputPath), { recursive: true });\n await fs.writeFile(fullOutputPath, code);\n debug(`${logPrefix}: ${fullOutputPath}`);\n}\n\n/**\n * Formats typescript code using prettier and write it to a file\n * @param output typescript code\n * @param fullOutputPath full path to the output file\n * @param logPrefix prefix for debug logs\n */\nexport async function formatAndWriteTypescript(\n output: string,\n fullOutputPath: string,\n logPrefix: string\n): Promise<void> {\n const formattedOutput = await formatTypescript(output);\n\n await fs.mkdir(path.dirname(fullOutputPath), { recursive: true });\n\n await fs.writeFile(fullOutputPath, formattedOutput);\n debug(`${logPrefix}: ${fullOutputPath}`);\n}\n","import createDebug from 'debug';\n\nexport const debug = createDebug('dubhe:common');\nexport const error = createDebug('dubhe:common');\n\n// Pipe debug output to stdout instead of stderr\ndebug.log = console.debug.bind(console);\n\n// Pipe error output to stderr\nerror.log = console.error.bind(console);\n","import { debug as parentDebug } from '../debug';\n\nexport const debug = parentDebug.extend('codegen');\nexport const error = parentDebug.extend('codegen');\n\n// Pipe debug output to stdout instead of stderr\ndebug.log = console.debug.bind(console);\n\n// Pipe error output to stderr\nerror.log = console.error.bind(console);\n","/**\n * Explicitly normalize a given path to a posix path (using `/` as separator).\n * This should be used for generating Solidity files that will be consumed by solc,\n * because solc expects `/` as path separator, but path.join produces `\\` if the user is on windows.\n */\nexport function posixPath(path: string): string {\n return path.replace(/\\\\/g, '/');\n}\n","import { SchemaType, DubheConfig } from '../../types';\nimport { rmdirSync, existsSync } from 'fs';\nimport { deleteFolderRecursive } from './common';\nimport { generateToml } from './generateToml';\nimport { generateSchemaData, generateSchemaStructure } from './generateSchema';\nimport { generateDeployHook, generateMigrate } from './generateScript';\nimport { generateDappKey } from './generateDappKey';\nimport { generateSchemaEvent } from './generateEvent';\nimport { generateSystemsAndTests } from './generateSystem';\nimport { generateSchemaHub } from './generateSchemaHub';\nimport { generateSchemaError } from './generateError';\nimport { generateDefaultSchema } from './generateDefaultSchema';\nimport { generateInit } from './generateInit';\n\nexport async function schemaGen(\n config: DubheConfig,\n srcPrefix?: string,\n network?: 'mainnet' | 'testnet' | 'devnet' | 'localnet'\n) {\n console.log('\\n🚀 Starting Schema Generation Process...');\n console.log('📋 Project Configuration:');\n console.log(` └─ Name: ${config.name}`);\n console.log(` └─ Description: ${config.description || 'No description provided'}`);\n console.log(` └─ Network: ${network || 'testnet'}`);\n\n const path = srcPrefix ?? process.cwd();\n\n if (existsSync(`${path}/contracts/${config.name}`)) {\n deleteFolderRecursive(`${path}/contracts/${config.name}/sources/codegen`);\n }\n\n if (!existsSync(`${path}/contracts/${config.name}/Move.toml`)) {\n await generateToml(config, path);\n }\n\n if (!existsSync(`${path}/contracts/${config.name}/sources/script/deploy_hook.move`)) {\n await generateDeployHook(config, path);\n }\n\n if (config.events) {\n if (config.data) {\n await generateSchemaEvent(config.name, config.data, config.events, path);\n } else {\n await generateSchemaEvent(config.name, null, config.events, path);\n }\n }\n\n if (config.data) {\n await generateSchemaData(config.name, config.data, path);\n await generateSchemaStructure(config.name, config.data, config.schemas, path);\n } else {\n await generateSchemaStructure(config.name, null, config.schemas, path);\n }\n\n if (config.errors) {\n await generateSchemaError(config.name, config.errors, path);\n }\n\n // await generateDefaultSchema(config, path);\n await generateInit(config, path);\n await generateSystemsAndTests(config, path);\n await generateMigrate(config, path);\n await generateDappKey(config, path);\n console.log('\\n✅ Schema Generation Process Complete!\\n');\n}\n","import { MoveType } from '../../types';\nimport fs from 'fs';\n\nexport function deleteFolderRecursive(path: string) {\n if (fs.existsSync(path)) {\n fs.readdirSync(path).forEach((file) => {\n const curPath = `${path}/${file}`;\n if (fs.lstatSync(curPath).isDirectory()) {\n deleteFolderRecursive(curPath);\n } else {\n fs.unlinkSync(curPath);\n }\n });\n fs.rmdirSync(path);\n }\n}\n\nexport function capitalizeFirstLetter(input: string): string {\n return input.charAt(0).toUpperCase() + input.slice(1);\n}\n\n/**\n *\n * @param values\n * @param prefixArgs\n * @return [ name, age, birth_time ]\n */\nexport function getStructAttrs(values: Record<string, string> | string): string {\n return Object.entries(values)\n .map(([key, _]) => `${key}`)\n .join(',');\n}\n\nfunction isAddress(str: string): boolean {\n const regex = /^0x[a-fA-F0-9]+$/;\n return regex.test(str);\n}\n\n/**\n *\n * @param values\n * @return ( bool , u64 , u64)\n */\n// export function getStructTypes(values: SchemaType): string {\nexport function getStructTypes(values: Record<string, string>): string {\n return `(${Object.entries(values).map(([_, type]) => `${type}`)})`;\n}\n\n/**\n *\n * @param values\n * @return Attributes and types of the struct. [ name: string, age: u64 ]\n */\nexport function getStructAttrsWithType(values: Record<string, string>): string[] {\n return Object.entries(values).map(([key, type]) => `${key}: ${type}`);\n}\n\n/**\n * @param values\n * @return [ data.name, data.age ]\n */\nexport function getStructAttrsQuery(values: Record<string, string>): string[] {\n return Object.entries(values).map(([key, _]) => `self.${key}`);\n}\n\nexport function containsString(obj: Record<string, any>, searchString: string): boolean {\n for (const key in obj) {\n if (obj.hasOwnProperty(key)) {\n const value = obj[key];\n if (\n (typeof value === 'string' && value === searchString) ||\n (typeof value === 'string' && value.includes(searchString) && value.includes('>'))\n ) {\n return true;\n }\n }\n }\n return false;\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateToml(config: DubheConfig, srcPrefix: string) {\n console.log('\\n📄 Starting Move.toml Generation...');\n console.log(` └─ Output path: ${srcPrefix}/contracts/${config.name}/Move.toml`);\n\n let code = `[package]\nname = \"${config.name}\"\nversion = \"1.0.0\"\nedition = \"2024\"\n\n[dependencies]\nSui = { git = \"https://github.com/MystenLabs/sui.git\", subdir = \"crates/sui-framework/packages/sui-framework\", rev = \"mainnet-v1.46.3\" }\nDubhe = { git = \"https://github.com/0xobelisk/dubhe-framework.git\", subdir = \"contracts/dubhe\", rev = \"develop\" }\n\n[addresses]\nsui = \"0x2\"\n${config.name} = \"0x0\"\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/Move.toml`,\n 'formatAndWriteMove'\n );\n console.log('✅ Move.toml Generation Complete\\n');\n}\n","import { BaseType, SchemaData, SchemaType } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport {\n getStructAttrsWithType,\n getStructAttrs,\n getStructTypes,\n getStructAttrsQuery,\n containsString\n} from './common';\n\nfunction sortByFirstLetter(arr: string[]): string[] {\n return arr.sort((a, b) => {\n const firstLetterA = a.charAt(0).toLowerCase();\n const firstLetterB = b.charAt(0).toLowerCase();\n\n if (firstLetterA < firstLetterB) {\n return -1;\n }\n if (firstLetterA > firstLetterB) {\n return 1;\n }\n return 0;\n });\n}\n\nexport function capitalizeAndRemoveUnderscores(input: string): string {\n return input\n .split('_')\n .map((word, index) => {\n return index === 0\n ? word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n : word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();\n })\n .join('');\n}\n\nexport function renderSetAttrsFunc(\n schemaName: string,\n fields: BaseType | Record<string, BaseType>\n): string {\n return Object.entries(fields)\n .map(\n ([key, type]) =>\n `public(package) fun set_${key}(self: &mut ${schemaName}, ${key}: ${type}) {\n self.${key} = ${key};\n }`\n )\n .join('\\n');\n}\n\nexport function renderSetFunc(schemaName: string, fields: Record<string, string>): string {\n return `public(package) fun set(self: &mut ${schemaName}, ${getStructAttrsWithType(fields)}) {\n ${Object.entries(fields)\n .map(([fieldName]) => `self.${fieldName} = ${fieldName};`)\n .join('\\n')}\n }`;\n}\n\nexport function renderGetAllFunc(schemaName: string, fields: Record<string, string>): string {\n return `public fun get(self: &${schemaName}): ${getStructTypes(fields)} {\n (${getStructAttrsQuery(fields)})\n }`;\n}\n\nexport function renderGetAttrsFunc(\n schemaName: string,\n fields: BaseType | Record<string, BaseType>\n): string {\n return Object.entries(fields)\n .map(\n ([key, type]) => `public fun get_${key}(self: &${schemaName}): ${type} {\n self.${key}\n }`\n )\n .join('\\n');\n}\n\nfunction convertToSnakeCase(input: string): string {\n return input\n .replace(/([A-Z])/g, '_$1')\n .toLowerCase()\n .replace(/^_/, '');\n}\n\nexport async function generateSchemaData(\n projectName: string,\n data: Record<string, SchemaData>,\n path: string\n) {\n console.log('\\n📦 Starting Schema Data Generation...');\n for (const key of Object.keys(data)) {\n const name = key;\n const fields = data[key];\n console.log(\n ` └─ ${name} ${Array.isArray(fields) ? '(enum)' : '(struct)'}: ${JSON.stringify(fields)}`\n );\n let code = '';\n\n const enumNames = Object.keys(data)\n .filter((item) => Array.isArray(data[item]))\n .map((item) => item);\n\n if (Array.isArray(fields)) {\n const sortByFirstLetterFields = sortByFirstLetter(fields);\n code = `module ${projectName}::${projectName}_${convertToSnakeCase(name)} {\n public enum ${name} has copy, drop , store {\n ${sortByFirstLetterFields}\n }\n \n ${sortByFirstLetterFields\n .map((field: string) => {\n return `public fun new_${convertToSnakeCase(field)}(): ${name} {\n ${name}::${field}\n }`;\n })\n .join('')}`;\n } else {\n code = `module ${projectName}::${projectName}_${convertToSnakeCase(name)} {\n use std::ascii::String;\n \n\t\t\t\t\t\t${Object.keys(data)\n .map((name) => {\n if (containsString(fields, name)) {\n return `use ${projectName}::${projectName}_${convertToSnakeCase(name)}::${name};`;\n }\n return undefined;\n })\n .filter(Boolean)\n .join('\\n')}\n\n public struct ${name} has copy, drop , store {\n ${getStructAttrsWithType(fields)}\n }\n \n public fun new(${getStructAttrsWithType(fields)}): ${name} {\n ${name} {\n ${getStructAttrs(fields)}\n }\n }\n \n ${renderGetAllFunc(name, fields)}\n ${renderGetAttrsFunc(name, fields)}\n ${renderSetAttrsFunc(name, fields)}\n ${renderSetFunc(name, fields)}\n }`;\n }\n\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/data/${convertToSnakeCase(name)}.move`,\n 'formatAndWriteMove'\n );\n }\n}\n\nfunction generateImport(projectName: string, data: Record<string, SchemaData> | null) {\n if (data != null) {\n const names = Object.keys(data);\n return names\n .map((name) => {\n return `use ${projectName}::${projectName}_${convertToSnakeCase(name)}::${name};`;\n })\n .join('\\n');\n } else {\n return '';\n }\n}\n\nexport async function generateSchemaStructure(\n projectName: string,\n data: Record<string, SchemaData> | null,\n schemas: Record<string, SchemaType>,\n path: string\n) {\n console.log('\\n📦 Starting Schema Structure Generation...');\n Object.entries(schemas).forEach(([key, value]) => {\n console.log(` └─ ${key}: ${value}`);\n });\n const schemaMoudle = `module ${projectName}::${projectName}_schema {\n use std::ascii::String;\n use std::ascii::string;\n use sui::package::UpgradeCap;\n use std::type_name; \n use dubhe::storage;\n use dubhe::${projectName == 'dubhe' ? 'storage_value_internal' : 'storage_value'}::{Self, StorageValue};\n use dubhe::${projectName == 'dubhe' ? 'storage_map_internal' : 'storage_map'}::{Self, StorageMap};\n use dubhe::${projectName == 'dubhe' ? 'storage_double_map_internal' : 'storage_double_map'}::{Self, StorageDoubleMap};\n use sui::dynamic_field as df;\n \n ${generateImport(projectName, data)}\n\n public struct Schema has key, store { id: UID } \n \n ${Object.entries(schemas)\n .map(([key, value]) => {\n return `public fun borrow_${key}(self: &Schema) : &${value} {\n storage::borrow_field(&self.id, b\"${key}\")\n }\n \n public(package) fun ${key}(self: &mut Schema): &mut ${value} {\n storage::borrow_mut_field(&mut self.id, b\"${key}\")\n }\n `;\n })\n .join('')} \n \n \n public(package) fun create(ctx: &mut TxContext): Schema {\n let mut id = object::new(ctx);\n ${Object.entries(schemas)\n .map(([key, value]) => {\n let storage_type = '';\n if (value.includes('StorageValue')) {\n storage_type = `${projectName == 'dubhe' ? 'storage_value_internal' : 'storage_value'}::new(b\"${key}\", ctx)`;\n } else if (value.includes('StorageMap')) {\n storage_type = `${projectName == 'dubhe' ? 'storage_map_internal' : 'storage_map'}::new(b\"${key}\", ctx)`;\n } else if (value.includes('StorageDoubleMap')) {\n storage_type = `${projectName == 'dubhe' ? 'storage_double_map_internal' : 'storage_double_map'}::new(b\"${key}\", ctx)`;\n }\n return `storage::add_field<${value}>(&mut id, b\"${key}\", ${storage_type});`;\n })\n .join('\\n')}\n \n Schema { id }\n }\n \n public(package) fun id(self: &mut Schema): &mut UID {\n\t\t\t\t\t &mut self.id\n\t\t\t\t\t}\n\t\t\t\t\n\t\t\t\t\tpublic(package) fun borrow_id(self: &Schema): &UID {\n\t\t\t\t\t &self.id\n\t\t\t\t\t}\n \n public fun migrate(_schema: &mut Schema, _ctx: &mut TxContext) { }\n \n // ======================================== View Functions ========================================\n ${Object.entries(schemas)\n .map(([key, value]) => {\n // @ts-ignore\n let all_types = value\n .match(/<(.+)>/)[1]\n .split(',')\n .map((type) => type.trim());\n let para_key: string[] = [];\n let para_value = '';\n let borrow_key = '';\n if (value.includes('StorageValue')) {\n para_key = [];\n para_value = `${all_types[0]}`;\n borrow_key = 'get()';\n } else if (value.includes('StorageMap')) {\n para_key = [`key: ${all_types[0]}`];\n para_value = `${all_types[1]}`;\n borrow_key = 'get(key)';\n } else if (value.includes('StorageDoubleMap')) {\n para_key = [`key1: ${all_types[0]}`, `key2: ${all_types[1]}`];\n para_value = `${all_types[2]}`;\n borrow_key = 'get(key1, key2)';\n }\n return `public fun get_${key}(self: &Schema, ${para_key}) : &${para_value} {\n\t\t\t\t\t\t\t\t\tself.borrow_${key}().${borrow_key}\n\t\t\t\t\t\t\t\t}`;\n })\n .join('\\n')}\n // =========================================================================================================\n\t\t\t}`;\n await formatAndWriteMove(\n schemaMoudle,\n\n `${path}/contracts/${projectName}/sources/codegen/core/schema.move`,\n 'formatAndWriteMove'\n );\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\nimport { capitalizeAndRemoveUnderscores } from './generateSchema';\n\nimport { readFileSync } from 'fs';\n\nfunction capitalizeFirstLetter(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nexport async function generateDeployHook(config: DubheConfig, srcPrefix: string) {\n const path = `${srcPrefix}/contracts/${config.name}/sources/scripts/deploy_hook.move`;\n if (!existsSync(path)) {\n const code = `module ${config.name}::${config.name}_deploy_hook {\n\t\t\t use ${config.name}::${config.name}_schema::Schema;\n ${config.name !== 'dubhe' ? `use dubhe::dubhe_schema::Schema as DubheSchema;` : '' }\n\n public(package) fun run(${config.name !== 'dubhe' ? `_dubhe_schema: &mut DubheSchema,` : ''}_schema: &mut Schema, _ctx: &mut TxContext) {\n\n }\n}`;\n await formatAndWriteMove(code, path, 'formatAndWriteMove');\n }\n}\n\nexport async function generateMigrate(config: DubheConfig, srcPrefix: string) {\n if (!existsSync(`${srcPrefix}/contracts/${config.name}/sources/scripts/migrate.move`)) {\n let code = `module ${config.name}::${config.name}_migrate {\n const ON_CHAIN_VERSION: u32 = 1;\n\n public fun on_chain_version(): u32 {\n ON_CHAIN_VERSION\n }\n}\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/scripts/migrate.move`,\n 'formatAndWriteMove'\n );\n }\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateDappKey(config: DubheConfig, srcPrefix: string) {\n let code = `module ${config.name}::${config.name}_dapp_key {\n\\t/// Authorization token for the app.\n\\tpublic struct DappKey has copy, drop {}\n\n\\tpublic(package) fun new(): DappKey {\n\\t\\tDappKey { }\n\\t}\n}\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/codegen/core/dapp_key.move`,\n 'formatAndWriteMove'\n );\n}\n","import { BaseType, EventData, SchemaData, SchemaType } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport {\n getStructAttrsWithType,\n getStructAttrs,\n getStructTypes,\n getStructAttrsQuery\n} from './common';\n\n// account_not_found => AccountNotFound,\nfunction toPascalCase(str: string): string {\n return str\n .split('_')\n .map((word) => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())\n .join('');\n}\n\nfunction convertToSnakeCase(input: string): string {\n return input\n .replace(/([A-Z])/g, '_$1')\n .toLowerCase()\n .replace(/^_/, '');\n}\n\nfunction generateImport(projectName: string, data: Record<string, SchemaData> | null) {\n if (data != null) {\n const names = Object.keys(data);\n return names\n .map((name) => {\n return `use ${projectName}::${projectName}_${convertToSnakeCase(name)}::${name};`;\n })\n .join('\\n');\n } else {\n return '';\n }\n}\n\nexport async function generateSchemaEvent(\n projectName: string,\n data: Record<string, SchemaData> | null,\n events: Record<string, EventData>,\n path: string\n) {\n console.log('\\n📦 Starting Schema Event Generation...');\n for (const key of Object.keys(events)) {\n const name = key;\n const fields = events[key];\n console.log(` └─ ${name} event: ${JSON.stringify(fields)}`);\n\n let code = `module ${projectName}::${projectName}_${name}_event {\n\t\t\t\t\t\tuse sui::event;\n\t\t\t\t\t\tuse std::ascii::String;\n\t\t\t\t\t\t${generateImport(projectName, data)}\n\n public struct ${toPascalCase(name)}Event has copy, drop {\n ${getStructAttrsWithType(fields as Record<string, string>)}\n }\n\n public fun new(${getStructAttrsWithType(fields as Record<string, string>)}): ${toPascalCase(name)}Event {\n ${toPascalCase(name)}Event {\n ${getStructAttrs(fields as Record<string, string>)}\n }\n }\n }`;\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/data/${name}_event.move`,\n 'formatAndWriteMove'\n );\n }\n\n let code = `module ${projectName}::${projectName}_events {\n\t \tuse std::ascii::{String, string};\n\t \t${generateImport(projectName, data)}\n\t\t${Object.entries(events)\n .map(([name, fields]) => {\n return `\nuse ${projectName}::${projectName}_${name}_event::${toPascalCase(name)}Event;\nuse ${projectName}::${projectName}_${name}_event;\n\t\t\tpublic fun ${name}_event(${getStructAttrsWithType(fields as Record<string, string>)}) {\n\t\t\t dubhe::storage_event::emit_set_record<${toPascalCase(name)}Event, ${toPascalCase(name)}Event, ${toPascalCase(name)}Event>(\n\t\t\t\tstring(b\"${name}_event\"),\n\t\t\t\toption::none(),\n\t\t\t \toption::none(),\n\t\t\t option::some(${projectName}_${name}_event::new(${getStructAttrs(fields as Record<string, string>)}))\n\t\t\t )\n\t\t\t}\n\t\t`;\n })\n .join('\\n')}\t\t\n }`;\n\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/events.move`,\n 'formatAndWriteMove'\n );\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\n\nexport async function generateSystemsAndTests(config: DubheConfig, srcPrefix: string) {\n if (!existsSync(`${srcPrefix}/contracts/${config.name}/sources/systems`)) {\n await fs.mkdir(`${srcPrefix}/contracts/${config.name}/sources/systems`, { recursive: true });\n }\n if (!existsSync(`${srcPrefix}/contracts/${config.name}/sources/tests`)) {\n await fs.mkdir(`${srcPrefix}/contracts/${config.name}/sources/tests`, { recursive: true });\n }\n}\n","import { BaseType, ErrorData, SchemaType } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport {\n getStructAttrsWithType,\n getStructAttrs,\n getStructTypes,\n getStructAttrsQuery\n} from './common';\n\nfunction convertToSnakeCase(input: string): string {\n return input\n .replace(/([A-Z])/g, '_$1')\n .toLowerCase()\n .replace(/^_/, '');\n}\n\nexport async function generateSchemaError(projectName: string, errors: ErrorData, path: string) {\n console.log('\\n📦 Starting Schema Error Generation...');\n\n let code = `module ${projectName}::${projectName}_errors {\n\t\t${Object.entries(errors)\n .map(([name, message]) => {\n console.log(` └─ ${name}: ${message}`);\n return `#[error]\n\t\t\t\tconst ${name.toUpperCase()}: vector<u8> = b\"${message}\";\n\t\t\t\tpublic fun ${name}_error(condition: bool) { assert!(condition, ${name.toUpperCase()}) }\n\t\t`;\n })\n .join('\\n')}\t\t\n }`;\n\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/errors.move`,\n 'formatAndWriteMove'\n );\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\nimport { capitalizeAndRemoveUnderscores } from './generateSchema';\n\nfunction capitalizeFirstLetter(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nexport async function generateInit(config: DubheConfig, srcPrefix: string) {\n let init_test_code = `module ${config.name}::${config.name}_init_test {\n use sui::clock;\n use sui::test_scenario;\n use sui::test_scenario::Scenario;\n use dubhe::dubhe_schema::Schema as DubheSchema;\n ${config.name !== 'dubhe' ? `use ${config.name}::${config.name}_schema::Schema;` : '' }\n \n public fun deploy_dapp_for_testing(scenario: &mut Scenario): ${config.name !== 'dubhe' ? `(DubheSchema, Schema)` : 'DubheSchema'} {\n ${config.name !== 'dubhe' ? `let mut dubhe_schema = dubhe::dubhe_init_test::create_dubhe_schema_for_other_contract(scenario);` : ''}\n let ctx = test_scenario::ctx(scenario);\n let clock = clock::create_for_testing(ctx);\n ${config.name}::${config.name}_genesis::run(${config.name !== 'dubhe' ? `&mut dubhe_schema,` : ''}&clock, ctx);\n clock::destroy_for_testing(clock);\n test_scenario::next_tx(scenario, ctx.sender());\n ${config.name !== 'dubhe' ? `\n let schema = test_scenario::take_shared<Schema>(scenario);\n (dubhe_schema, schema)\n ` : 'test_scenario::take_shared<DubheSchema>(scenario)'\n }\n }\n\n ${config.name == 'dubhe' ? `\n public fun create_dubhe_schema_for_other_contract(scenario: &mut Scenario): DubheSchema {\n let ctx = test_scenario::ctx(scenario);\n let mut schema = dubhe::dubhe_schema::create(ctx);\n dubhe::dubhe_deploy_hook::run(&mut schema, ctx);\n sui::transfer::public_share_object(schema);\n test_scenario::next_tx(scenario, ctx.sender());\n test_scenario::take_shared<DubheSchema>(scenario)\n }\n ` : ''}\n}\n`;\n await formatAndWriteMove(\n init_test_code,\n `${srcPrefix}/contracts/${config.name}/sources/codegen/core/init_test.move`,\n 'formatAndWriteMove'\n );\n\n let init_code = `module ${config.name}::${config.name}_genesis {\n use std::ascii::string;\n\n use sui::clock::Clock;\n\n ${config.name !== 'dubhe' ? `use dubhe::dubhe_schema::Schema as DubheSchema;` : '' }\n public entry fun run(${config.name !== 'dubhe' ? `_dubhe_schema: &mut DubheSchema,` : ''}clock: &Clock, ctx: &mut TxContext) {\n // Create schemas\n let mut schema = ${config.name}::${config.name}_schema::create(ctx);\n // Setup default storage\n dubhe::dubhe_dapp_system::create_dapp(\n ${config.name !== 'dubhe' ? `_dubhe_schema` : '&mut schema'}, \n ${config.name}::${config.name}_dapp_key::new(), \n dubhe::dubhe_dapp_metadata::new(string(b\"${config.name}\"), string(b\"${config.description}\"), vector[], string(b\"\"), clock.timestamp_ms(), vector[]), \n ctx\n );\n // Logic that needs to be automated once the contract is deployed\n ${config.name}::${config.name}_deploy_hook::run(${config.name !== 'dubhe' ? `_dubhe_schema,` : ''}&mut schema, ctx);\n // Authorize schemas and public share objects\n sui::transfer::public_share_object(schema);\n }\n}\n`;\n await formatAndWriteMove(\n init_code,\n\n `${srcPrefix}/contracts/${config.name}/sources/codegen/core/genesis.move`,\n 'formatAndWriteMove'\n );\n}\n","import { findUp } from 'find-up';\nimport path from 'path';\nimport esbuild from 'esbuild';\nimport { NotInsideProjectError } from './errors';\nimport { rmSync } from 'fs';\nimport { pathToFileURL } from 'url';\nimport os from 'os';\n\n// In order of preference files are checked\nconst configFiles = ['dubhe.config.js', 'dubhe.config.mjs', 'dubhe.config.ts', 'dubhe.config.mts'];\nconst TEMP_CONFIG = 'dubhe.config.example.mjs';\n\nexport async function loadConfig(configPath?: string): Promise<unknown> {\n configPath = await resolveConfigPath(configPath);\n try {\n await esbuild.build({\n entryPoints: [configPath],\n format: 'esm',\n outfile: TEMP_CONFIG,\n // https://esbuild.github.io/getting-started/#bundling-for-node\n platform: 'node',\n // bundle local imports (otherwise it may error, js can't import ts)\n bundle: true,\n // avoid bundling external imports (it's unnecessary and esbuild can't handle all node features)\n packages: 'external'\n });\n configPath = await resolveConfigPath(TEMP_CONFIG, true);\n // Node.js caches dynamic imports, so without appending a cache breaking\n // param like `?update={Date.now()}` this import always returns the same config\n // if called multiple times in a single process, like the `dev-contracts` cli\n return (await import(configPath + `?update=${Date.now()}`)).dubheConfig;\n } finally {\n rmSync(TEMP_CONFIG, { force: true });\n }\n}\n\nexport async function resolveConfigPath(configPath: string | undefined, toFileURL?: boolean) {\n if (configPath === undefined) {\n configPath = await getUserConfigPath();\n } else {\n if (!path.isAbsolute(configPath)) {\n configPath = path.join(process.cwd(), configPath);\n configPath = path.normalize(configPath);\n }\n }\n\n // Add `file:///` for Windows support\n // (see https://github.com/nodejs/node/issues/31710)\n return toFileURL && os.platform() === 'win32' ? pathToFileURL(configPath).href : configPath;\n}\n\nasync function getUserConfigPath() {\n const tsConfigPath = await findUp(configFiles);\n if (tsConfigPath === undefined) {\n throw new NotInsideProjectError();\n }\n return tsConfigPath;\n}\n","export class NotInsideProjectError extends Error {\n name = 'NotInsideProjectError';\n message = 'You are not inside a Dubhe project';\n}\n","export type BaseType =\n | 'String'\n | 'vector<String>'\n | 'address'\n | 'bool'\n | 'u8'\n | 'u32'\n | 'u64'\n | 'u128'\n | 'vector<address>'\n | 'vector<bool>'\n | 'vector<u8>'\n | 'vector<vector<u8>>'\n | 'vector<u32>'\n | 'vector<u64>'\n | 'vector<u128>'\n | string;\n\nexport type StorageDataType = 'Struct' | 'Enum';\n\nexport type StorageMapType = 'Map' | 'Bag' | 'Table';\n\ntype Address = string;\ntype Bool = boolean;\ntype U8 = number;\ntype U32 = number;\ntype U64 = number;\ntype U128 = number;\ntype Vector<T> = T[];\n\nexport type BaseValueType =\n | String\n | Address\n | Bool\n | U8\n | U32\n | U64\n | U128\n | Vector<Address>\n | Vector<Bool>\n | Vector<U8>\n | Vector<Vector<U8>>\n | Vector<U64>\n | Vector<U128>;\n\nexport type SchemaData = Record<string, string> | string[];\nexport type SchemaType = string;\nexport type EventData = Record<string, string>;\nexport type ErrorData = Record<string, string>;\n\ntype DataType = any;\n\nexport function storage<T extends DataType>(value: T): SchemaType;\nexport function storage<K extends DataType, V extends DataType>(key: K, value: V): SchemaType;\nexport function storage<K1 extends DataType, K2 extends DataType, V extends DataType>(\n key1: K1,\n key2: K2,\n value: V\n): SchemaType;\nexport function storage(...args: DataType[]): SchemaType {\n if (args.length === 1) {\n return `StorageValue<${args[0]}>`;\n } else if (args.length === 2) {\n return `StorageMap<${args[0]}, ${args[1]}>`;\n } else if (args.length === 3) {\n return `StorageDoubleMap<${args[0]}, ${args[1]}, ${args[2]}>`;\n }\n throw new Error('Invalid number of arguments for storage()');\n}\n\nexport type Plugin = 'merak';\n\nexport type DubheConfig = {\n name: string;\n description: string;\n data?: Record<string, SchemaData>;\n schemas: Record<string, SchemaType>;\n events?: Record<string, EventData>;\n errors?: ErrorData;\n plugins?: Plugin[];\n};\n\nexport type MoveType =\n | 'string'\n | 'vector<string>'\n | 'String'\n | 'vector<String>'\n | 'address'\n | 'bool'\n | 'u8'\n | 'u32'\n | 'u64'\n | 'u128'\n | 'vector<address>'\n | 'vector<bool>'\n | 'vector<u8>'\n | 'vector<vector<u8>>'\n | 'vector<u32>'\n | 'vector<u64>'\n | 'vector<u128>';\n","export const parseData = (data: any) => {\n if (typeof data !== 'object' || data === null) {\n return data;\n }\n const parsedData: any = {};\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n // @ts-ignore\n const value = data[key];\n // console.log(\"===========\", value)\n if (typeof value === 'object' && value !== null) {\n if (Array.isArray(value)) {\n parsedData[key] = handleArray(value);\n } else if (value.hasOwnProperty('variant')) {\n parsedData[key] = { [value.variant]: {} };\n } else if (value.hasOwnProperty('fields')) {\n parsedData[key] = parseData(value.fields);\n } else {\n parsedData[key] = parseData(value);\n }\n } else {\n parsedData[key] = value;\n }\n }\n }\n return parsedData;\n};\n\nconst handleArray = (data: any[]): any[] => {\n let returnData: any[] = [];\n data.forEach((item) => {\n if (typeof item === 'object' && item !== null) {\n if (Array.isArray(item)) {\n returnData.push(handleArray(item));\n } else if (item.hasOwnProperty('variant')) {\n returnData.push({ [item.variant]: {} });\n } else if (item.hasOwnProperty('fields')) {\n returnData.push(parseData(item.fields));\n } else {\n returnData.push(parseData(item));\n }\n } else {\n returnData.push(item);\n }\n });\n return returnData;\n};\n","export enum SubscriptionKind {\n Event = 'event',\n Schema = 'schema'\n}\n\nexport type SubscribableType =\n | { kind: SubscriptionKind.Event; name?: string; sender?: string }\n | { kind: SubscriptionKind.Schema; name?: string };\n"],"mappings":"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","names":["prettier","prettierPluginMove","formatMove","content","prettierConfigPath","config","error","message","formatTypescript","fs","path","createDebug","debug","error","debug","error","formatAndWriteMove","output","fullOutputPath","logPrefix","formattedOutput","formatMove","schemaPrefix","initPrefix","code","deployHookPrefix","fs","path","debug","formatAndWriteTypescript","formatTypescript","posixPath","path","existsSync","fs","deleteFolderRecursive","path","file","curPath","getStructAttrs","values","key","_","getStructTypes","values","_","type","getStructAttrsWithType","key","getStructAttrsQuery","containsString","obj","searchString","value","generateToml","config","srcPrefix","code","formatAndWriteMove","sortByFirstLetter","arr","a","b","firstLetterA","firstLetterB","renderSetAttrsFunc","schemaName","fields","key","type","renderSetFunc","getStructAttrsWithType","fieldName","renderGetAllFunc","getStructTypes","getStructAttrsQuery","renderGetAttrsFunc","convertToSnakeCase","input","generateSchemaData","projectName","data","path","name","code","enumNames","item","sortByFirstLetterFields","sortByFirstLetter","field","containsString","getStructAttrs","formatAndWriteMove","generateImport","generateSchemaStructure","schemas","value","schemaMoudle","storage_type","all_types","para_key","para_value","borrow_key","existsSync","generateDeployHook","config","srcPrefix","path","existsSync","code","formatAndWriteMove","generateMigrate","generateDappKey","config","srcPrefix","code","formatAndWriteMove","toPascalCase","str","word","convertToSnakeCase","input","generateImport","projectName","data","name","generateSchemaEvent","events","path","key","fields","code","getStructAttrsWithType","getStructAttrs","formatAndWriteMove","existsSync","fs","generateSystemsAndTests","config","srcPrefix","generateSchemaError","projectName","errors","path","code","name","message","formatAndWriteMove","generateInit","config","srcPrefix","init_test_code","formatAndWriteMove","init_code","schemaGen","config","srcPrefix","network","path","existsSync","deleteFolderRecursive","generateToml","generateDeployHook","generateSchemaEvent","generateSchemaData","generateSchemaStructure","generateSchemaError","generateInit","generateSystemsAndTests","generateMigrate","generateDappKey","findUp","path","esbuild","NotInsideProjectError","rmSync","pathToFileURL","os","configFiles","TEMP_CONFIG","loadConfig","configPath","resolveConfigPath","esbuild","toFileURL","getUserConfigPath","path","tsConfigPath","findUp","NotInsideProjectError","storage","args","parseData","data","parsedData","key","value","handleArray","returnData","item","SubscriptionKind"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@0xobelisk/sui-common",
3
- "version": "1.1.14",
3
+ "version": "1.2.0-pre.1",
4
4
  "description": "Common low level logic shared between packages",
5
5
  "keywords": [
6
6
  "sui",
@@ -12,15 +12,33 @@ export async function generateInit(config: DubheConfig, srcPrefix: string) {
12
12
  use sui::clock;
13
13
  use sui::test_scenario;
14
14
  use sui::test_scenario::Scenario;
15
- ${config.plugins?.length ? config.plugins.map((plugin) => `use ${plugin}::${plugin}_schema::Schema as ${capitalizeFirstLetter(plugin)}Schema;`).join('\n') : ''}
15
+ use dubhe::dubhe_schema::Schema as DubheSchema;
16
+ ${config.name !== 'dubhe' ? `use ${config.name}::${config.name}_schema::Schema;` : '' }
16
17
 
17
- public fun deploy_dapp_for_testing(scenario: &mut Scenario, ${config.plugins?.length ? config.plugins.map((plugin) => `${plugin}_schema: &mut ${capitalizeFirstLetter(plugin)}Schema`).join(', ') : ''}) {
18
+ public fun deploy_dapp_for_testing(scenario: &mut Scenario): ${config.name !== 'dubhe' ? `(DubheSchema, Schema)` : 'DubheSchema'} {
19
+ ${config.name !== 'dubhe' ? `let mut dubhe_schema = dubhe::dubhe_init_test::create_dubhe_schema_for_other_contract(scenario);` : ''}
18
20
  let ctx = test_scenario::ctx(scenario);
19
21
  let clock = clock::create_for_testing(ctx);
20
- ${config.name}::${config.name}_genesis::run(&clock, ${config.plugins?.length ? config.plugins.map((plugin) => `${plugin}_schema`).join(', ') + ', ' : ''} ctx);
22
+ ${config.name}::${config.name}_genesis::run(${config.name !== 'dubhe' ? `&mut dubhe_schema,` : ''}&clock, ctx);
21
23
  clock::destroy_for_testing(clock);
22
24
  test_scenario::next_tx(scenario, ctx.sender());
25
+ ${config.name !== 'dubhe' ? `
26
+ let schema = test_scenario::take_shared<Schema>(scenario);
27
+ (dubhe_schema, schema)
28
+ ` : 'test_scenario::take_shared<DubheSchema>(scenario)'
29
+ }
23
30
  }
31
+
32
+ ${config.name == 'dubhe' ? `
33
+ public fun create_dubhe_schema_for_other_contract(scenario: &mut Scenario): DubheSchema {
34
+ let ctx = test_scenario::ctx(scenario);
35
+ let mut schema = dubhe::dubhe_schema::create(ctx);
36
+ dubhe::dubhe_deploy_hook::run(&mut schema, ctx);
37
+ sui::transfer::public_share_object(schema);
38
+ test_scenario::next_tx(scenario, ctx.sender());
39
+ test_scenario::take_shared<DubheSchema>(scenario)
40
+ }
41
+ ` : ''}
24
42
  }
25
43
  `;
26
44
  await formatAndWriteMove(
@@ -34,15 +52,19 @@ export async function generateInit(config: DubheConfig, srcPrefix: string) {
34
52
 
35
53
  use sui::clock::Clock;
36
54
 
37
- use ${config.name}::${config.name}_dapp_system;
38
- ${config.plugins?.length ? config.plugins.map((plugin) => `use ${plugin}::${plugin}_schema::Schema as ${capitalizeFirstLetter(plugin)}Schema;`).join('\n') : ''}
39
- public entry fun run(clock: &Clock, ${config.plugins?.length ? config.plugins.map((plugin) => `${plugin}_schema: &mut ${capitalizeFirstLetter(plugin)}Schema`).join(', ') + ', ' : ''} ctx: &mut TxContext) {
55
+ ${config.name !== 'dubhe' ? `use dubhe::dubhe_schema::Schema as DubheSchema;` : '' }
56
+ public entry fun run(${config.name !== 'dubhe' ? `_dubhe_schema: &mut DubheSchema,` : ''}clock: &Clock, ctx: &mut TxContext) {
40
57
  // Create schemas
41
58
  let mut schema = ${config.name}::${config.name}_schema::create(ctx);
42
59
  // Setup default storage
43
- ${config.name}_dapp_system::create(&mut schema, string(b"${config.name}"),string(b"${config.description}"), clock , ctx);
60
+ dubhe::dubhe_dapp_system::create_dapp(
61
+ ${config.name !== 'dubhe' ? `_dubhe_schema` : '&mut schema'},
62
+ ${config.name}::${config.name}_dapp_key::new(),
63
+ dubhe::dubhe_dapp_metadata::new(string(b"${config.name}"), string(b"${config.description}"), vector[], string(b""), clock.timestamp_ms(), vector[]),
64
+ ctx
65
+ );
44
66
  // Logic that needs to be automated once the contract is deployed
45
- ${config.name}::${config.name}_deploy_hook::run(&mut schema, ${config.plugins?.length ? config.plugins.map((plugin) => `${plugin}_schema`).join(', ') + ', ' : ''} ctx);
67
+ ${config.name}::${config.name}_deploy_hook::run(${config.name !== 'dubhe' ? `_dubhe_schema,` : ''}&mut schema, ctx);
46
68
  // Authorize schemas and public share objects
47
69
  sui::transfer::public_share_object(schema);
48
70
  }
@@ -182,68 +182,14 @@ export async function generateSchemaStructure(
182
182
  use sui::package::UpgradeCap;
183
183
  use std::type_name;
184
184
  use dubhe::storage;
185
- use dubhe::storage_value::{Self, StorageValue};
186
- use dubhe::storage_map::{Self, StorageMap};
187
- use dubhe::storage_double_map::{Self, StorageDoubleMap};
185
+ use dubhe::${projectName == 'dubhe' ? 'storage_value_internal' : 'storage_value'}::{Self, StorageValue};
186
+ use dubhe::${projectName == 'dubhe' ? 'storage_map_internal' : 'storage_map'}::{Self, StorageMap};
187
+ use dubhe::${projectName == 'dubhe' ? 'storage_double_map_internal' : 'storage_double_map'}::{Self, StorageDoubleMap};
188
188
  use sui::dynamic_field as df;
189
- use ${projectName}::${projectName}_dapp_metadata::DappMetadata;
190
189
 
191
190
  ${generateImport(projectName, data)}
192
191
 
193
192
  public struct Schema has key, store { id: UID }
194
-
195
- // Default storage
196
- public fun borrow_dapp__admin(self: &Schema): &StorageValue<address> {
197
- storage::borrow_field(&self.id, b"dapp__admin")
198
- }
199
-
200
- public fun borrow_dapp__package_id(self: &Schema): &StorageValue<address> {
201
- storage::borrow_field(&self.id, b"dapp__package_id")
202
- }
203
-
204
- public fun borrow_dapp__version(self: &Schema): &StorageValue<u32> {
205
- storage::borrow_field(&self.id, b"dapp__version")
206
- }
207
-
208
- public fun borrow_dapp__metadata(self: &Schema): &StorageValue<DappMetadata> {
209
- storage::borrow_field(&self.id, b"dapp__metadata")
210
- }
211
-
212
- public fun borrow_dapp__safe_mode(self: &Schema): &StorageValue<bool> {
213
- storage::borrow_field(&self.id, b"dapp__safe_mode")
214
- }
215
-
216
- public fun borrow_dapp__authorised_schemas(self: &Schema): &StorageValue<vector<address>> {
217
- storage::borrow_field(&self.id, b"dapp__authorised_schemas")
218
- }
219
-
220
- public fun borrow_dapp__schemas(self: &Schema): &StorageValue<vector<address>> {
221
- storage::borrow_field(&self.id, b"dapp__schemas")
222
- }
223
-
224
- public(package) fun dapp__admin(self: &mut Schema): &mut StorageValue<address> {
225
- storage::borrow_mut_field(&mut self.id, b"dapp__admin")
226
- }
227
-
228
- public(package) fun dapp__package_id(self: &mut Schema): &mut StorageValue<address> {
229
- storage::borrow_mut_field(&mut self.id, b"dapp__package_id")
230
- }
231
-
232
- public(package) fun dapp__version(self: &mut Schema): &mut StorageValue<u32> {
233
- storage::borrow_mut_field(&mut self.id, b"dapp__version")
234
- }
235
-
236
- public(package) fun dapp__metadata(self: &mut Schema): &mut StorageValue<DappMetadata> {
237
- storage::borrow_mut_field(&mut self.id, b"dapp__metadata")
238
- }
239
-
240
- public(package) fun dapp__safe_mode(self: &mut Schema): &mut StorageValue<bool> {
241
- storage::borrow_mut_field(&mut self.id, b"dapp__safe_mode")
242
- }
243
-
244
- public(package) fun dapp__authorised_schemas(self: &mut Schema): &mut StorageValue<vector<address>> {
245
- storage::borrow_mut_field(&mut self.id, b"dapp__authorised_schemas")
246
- }
247
193
 
248
194
  ${Object.entries(schemas)
249
195
  .map(([key, value]) => {
@@ -265,11 +211,11 @@ export async function generateSchemaStructure(
265
211
  .map(([key, value]) => {
266
212
  let storage_type = '';
267
213
  if (value.includes('StorageValue')) {
268
- storage_type = `storage_value::new(b"${key}", ctx)`;
214
+ storage_type = `${projectName == 'dubhe' ? 'storage_value_internal' : 'storage_value'}::new(b"${key}", ctx)`;
269
215
  } else if (value.includes('StorageMap')) {
270
- storage_type = `storage_map::new(b"${key}", ctx)`;
216
+ storage_type = `${projectName == 'dubhe' ? 'storage_map_internal' : 'storage_map'}::new(b"${key}", ctx)`;
271
217
  } else if (value.includes('StorageDoubleMap')) {
272
- storage_type = `storage_double_map::new(b"${key}", ctx)`;
218
+ storage_type = `${projectName == 'dubhe' ? 'storage_double_map_internal' : 'storage_double_map'}::new(b"${key}", ctx)`;
273
219
  }
274
220
  return `storage::add_field<${value}>(&mut id, b"${key}", ${storage_type});`;
275
221
  })
@@ -287,18 +233,6 @@ export async function generateSchemaStructure(
287
233
  }
288
234
 
289
235
  public fun migrate(_schema: &mut Schema, _ctx: &mut TxContext) { }
290
-
291
-
292
- public(package) fun upgrade(schema: &mut Schema, new_package_id: address, new_version: u32, ctx: &mut TxContext) {
293
- assert!(schema.dapp__metadata().contains(), 0);
294
- assert!(schema.dapp__admin().get() == ctx.sender(), 0);
295
- schema.dapp__package_id().set(new_package_id);
296
- let current_version = schema.dapp__version()[];
297
- assert!(current_version < new_version, 0);
298
- schema.dapp__version().set(new_version);
299
- schema.migrate(ctx);
300
- }
301
-
302
236
 
303
237
  // ======================================== View Functions ========================================
304
238
  ${Object.entries(schemas)
@@ -14,9 +14,9 @@ export async function generateDeployHook(config: DubheConfig, srcPrefix: string)
14
14
  if (!existsSync(path)) {
15
15
  const code = `module ${config.name}::${config.name}_deploy_hook {
16
16
  use ${config.name}::${config.name}_schema::Schema;
17
- ${config.plugins?.length ? config.plugins.map((plugin) => `use ${plugin}::${plugin}_schema::Schema as ${capitalizeFirstLetter(plugin)}Schema;`).join('\n') : '' }
17
+ ${config.name !== 'dubhe' ? `use dubhe::dubhe_schema::Schema as DubheSchema;` : '' }
18
18
 
19
- public(package) fun run(_schema: &mut Schema, ${config.plugins?.length ? config.plugins.map((plugin) => `_${plugin}_schema: &mut ${capitalizeFirstLetter(plugin)}Schema`).join(', ') + ', ' : ''} _ctx: &mut TxContext) {
19
+ public(package) fun run(${config.name !== 'dubhe' ? `_dubhe_schema: &mut DubheSchema,` : ''}_schema: &mut Schema, _ctx: &mut TxContext) {
20
20
 
21
21
  }
22
22
  }`;
@@ -4,8 +4,11 @@ import { existsSync } from 'fs';
4
4
  import fs from 'node:fs/promises';
5
5
  import path from 'node:path';
6
6
 
7
- export async function generateSystem(config: DubheConfig, srcPrefix: string) {
7
+ export async function generateSystemsAndTests(config: DubheConfig, srcPrefix: string) {
8
8
  if (!existsSync(`${srcPrefix}/contracts/${config.name}/sources/systems`)) {
9
9
  await fs.mkdir(`${srcPrefix}/contracts/${config.name}/sources/systems`, { recursive: true });
10
10
  }
11
+ if (!existsSync(`${srcPrefix}/contracts/${config.name}/sources/tests`)) {
12
+ await fs.mkdir(`${srcPrefix}/contracts/${config.name}/sources/tests`, { recursive: true });
13
+ }
11
14
  }
@@ -11,9 +11,8 @@ version = "1.0.0"
11
11
  edition = "2024"
12
12
 
13
13
  [dependencies]
14
- Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "mainnet-v1.38.3" }
15
- Dubhe = { git = "https://github.com/0xobelisk/dubhe-framework.git", rev = "dubhe-mainnet-v1.1.0" }
16
- ${config.plugins?.length ? config.plugins.map((plugin) => `${plugin} = { git = "https://github.com/0xobelisk/merak.git", rev = "main", subdir = "contracts/${plugin}" }`).join('\n') : '' }
14
+ Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "mainnet-v1.46.3" }
15
+ Dubhe = { git = "https://github.com/0xobelisk/dubhe-framework.git", subdir = "contracts/dubhe", rev = "develop" }
17
16
 
18
17
  [addresses]
19
18
  sui = "0x2"
@@ -6,7 +6,7 @@ import { generateSchemaData, generateSchemaStructure } from './generateSchema';
6
6
  import { generateDeployHook, generateMigrate } from './generateScript';
7
7
  import { generateDappKey } from './generateDappKey';
8
8
  import { generateSchemaEvent } from './generateEvent';
9
- import { generateSystem } from './generateSystem';
9
+ import { generateSystemsAndTests } from './generateSystem';
10
10
  import { generateSchemaHub } from './generateSchemaHub';
11
11
  import { generateSchemaError } from './generateError';
12
12
  import { generateDefaultSchema } from './generateDefaultSchema';
@@ -56,9 +56,9 @@ export async function schemaGen(
56
56
  await generateSchemaError(config.name, config.errors, path);
57
57
  }
58
58
 
59
- await generateDefaultSchema(config, path);
59
+ // await generateDefaultSchema(config, path);
60
60
  await generateInit(config, path);
61
- await generateSystem(config, path);
61
+ await generateSystemsAndTests(config, path);
62
62
  await generateMigrate(config, path);
63
63
  await generateDappKey(config, path);
64
64
  console.log('\n✅ Schema Generation Process Complete!\n');