@0xobelisk/sui-common 0.5.16 → 0.5.18

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/LICENSE CHANGED
@@ -9,7 +9,7 @@ Parameters
9
9
 
10
10
  Licensor: Obelisk Labs
11
11
 
12
- Licensed Work: Obelisk Engine
12
+ Licensed Work: Dubhe
13
13
  The Licensed Work is (c) 2023 Obelisk Labs
14
14
 
15
15
  -----------------------------------------------------------------------------
package/dist/index.d.ts CHANGED
@@ -36,7 +36,7 @@ type SchemaType = {
36
36
  data?: SchemaData[];
37
37
  structure: Record<string, string>;
38
38
  };
39
- type ObeliskConfig = {
39
+ type DubheConfig = {
40
40
  name: string;
41
41
  description: string;
42
42
  systems: string[];
@@ -44,9 +44,9 @@ type ObeliskConfig = {
44
44
  };
45
45
  type MoveType = "string" | "vector<string>" | "String" | "vector<String>" | "address" | "bool" | "u8" | "u64" | "u128" | "vector<address>" | "vector<bool>" | "vector<u8>" | "vector<vector<u8>>" | "vector<u64>" | "vector<u128>";
46
46
 
47
- declare function schemaGen(config: ObeliskConfig, srcPrefix?: string, network?: 'mainnet' | 'testnet' | 'devnet' | 'localnet', frameworkId?: string): Promise<void>;
47
+ declare function schemaGen(config: DubheConfig, srcPrefix?: string, network?: 'mainnet' | 'testnet' | 'devnet' | 'localnet', frameworkId?: string): Promise<void>;
48
48
 
49
49
  declare function loadConfig(configPath?: string): Promise<unknown>;
50
50
  declare function resolveConfigPath(configPath: string | undefined, toFileURL?: boolean): Promise<string>;
51
51
 
52
- export { BaseType, BaseValueType, MoveType, ObeliskConfig, SchemaData, SchemaType, StorageDataType, StorageMapType, formatAndWriteMove, formatAndWriteTypescript, formatMove, formatTypescript, loadConfig, posixPath, resolveConfigPath, schemaGen };
52
+ export { BaseType, BaseValueType, DubheConfig, MoveType, SchemaData, SchemaType, StorageDataType, StorageMapType, formatAndWriteMove, formatAndWriteTypescript, formatMove, formatTypescript, loadConfig, posixPath, resolveConfigPath, schemaGen };
package/dist/index.js CHANGED
@@ -1,121 +1,121 @@
1
- import y from"prettier";import K from"prettier-plugin-move-js";async function h(e,t){let o;t&&(o=await y.resolveConfig(t));try{return y.format(e,{plugins:[K],parser:"move-parse",printWidth:120,semi:!0,tabWidth:2,useTabs:!1,bracketSpacing:!0,...o})}catch(r){let n;return r instanceof Error?n=r.message:n=r,console.log(`Error during output formatting: ${n}`),e}}async function w(e){return y.format(e,{parser:"typescript"})}import $ from"node:fs/promises";import A from"node:path";import v from"debug";var g=v("obelisk:common"),I=v("obelisk:common");g.log=console.debug.bind(console);I.log=console.error.bind(console);var f=g.extend("codegen"),U=g.extend("codegen");f.log=console.debug.bind(console);U.log=console.error.bind(console);async function c(e,t,o){let r=await h(e),n=` // Copyright (c) Obelisk Labs, Inc.
1
+ import y from"prettier";import K from"prettier-plugin-move-js";async function w(e,t){let r;t&&(r=await y.resolveConfig(t));try{return y.format(e,{plugins:[K],parser:"move-parse",printWidth:120,semi:!0,tabWidth:2,useTabs:!1,bracketSpacing:!0,...r})}catch(o){let s;return o instanceof Error?s=o.message:s=o,console.log(`Error during output formatting: ${s}`),e}}async function v(e){return y.format(e,{parser:"typescript"})}import $ from"node:fs/promises";import D from"node:path";import k from"debug";var g=k("dubhe:common"),I=k("dubhe:common");g.log=console.debug.bind(console);I.log=console.error.bind(console);var f=g.extend("codegen"),U=g.extend("codegen");f.log=console.debug.bind(console);U.log=console.error.bind(console);async function c(e,t,r){let o=await w(e),s=` // Copyright (c) Obelisk Labs, Inc.
2
2
  // SPDX-License-Identifier: MIT
3
3
  #[allow(unused_use)]
4
4
 
5
5
  /* Autogenerated file. Do not edit manually. */
6
6
 
7
- `,s=`#[allow(lint(share_owned))]
7
+ `,n=`#[allow(lint(share_owned))]
8
8
 
9
- `,a=n+r;t.includes(".toml")||t.includes("system")?a=r:t.includes("deploy_hook")&&(a=s+r),await $.mkdir(A.dirname(t),{recursive:!0}),await $.writeFile(t,a),f(`${o}: ${t}`)}async function ue(e,t,o){let r=await w(e);await $.mkdir(A.dirname(t),{recursive:!0}),await $.writeFile(t,r),f(`${o}: ${t}`)}function ge(e){return e.replace(/\\/g,"/")}import{existsSync as k}from"fs";import u from"fs";function _(e){u.existsSync(e)&&(u.readdirSync(e).forEach(t=>{let o=`${e}/${t}`;u.lstatSync(o).isDirectory()?_(o):u.unlinkSync(o)}),u.rmdirSync(e))}function C(e){return Object.entries(e).map(([t,o])=>`${t}`).join(",")}function D(e){return typeof e=="string"?e:`(${Object.entries(e).map(([t,o])=>`${o}`)})`}function d(e){return Object.entries(e).map(([t,o])=>`${t}: ${o}`)}function M(e,t){return typeof e=="string"?[`${t}self.value`]:Object.entries(e).map(([o,r])=>`${t}self.${o}`)}import{existsSync as L}from"fs";async function T(e,t){console.log(`
10
- \u2699\uFE0F Starting System Generation...`),e.systems.map(async o=>{if(console.log(` \u251C\u2500 Generating system: ${o}`),console.log(` \u2514\u2500 Output path: ${t}/contracts/${e.name}/sources/system/${o}.move`),!L(`${t}/contracts/${e.name}/sources/system/${o}.move`)){let r=`module ${e.name}::${o}_system {
9
+ `,a=s+o;t.includes(".toml")||t.includes("system")?a=o:t.includes("deploy_hook")&&(a=n+o),await $.mkdir(D.dirname(t),{recursive:!0}),await $.writeFile(t,a),f(`${r}: ${t}`)}async function le(e,t,r){let o=await v(e);await $.mkdir(D.dirname(t),{recursive:!0}),await $.writeFile(t,o),f(`${r}: ${t}`)}function ge(e){return e.replace(/\\/g,"/")}import{existsSync as _}from"fs";import l from"fs";function h(e){l.existsSync(e)&&(l.readdirSync(e).forEach(t=>{let r=`${e}/${t}`;l.lstatSync(r).isDirectory()?h(r):l.unlinkSync(r)}),l.rmdirSync(e))}function A(e){return Object.entries(e).map(([t,r])=>`${t}`).join(",")}function C(e){return`(${Object.entries(e).map(([t,r])=>`${r}`)})`}function d(e){return Object.entries(e).map(([t,r])=>`${t}: ${r}`)}function M(e){return Object.entries(e).map(([t,r])=>`self.${t}`)}import{existsSync as L}from"fs";async function j(e,t){console.log(`
10
+ \u2699\uFE0F Starting System Generation...`),e.systems.map(async r=>{if(console.log(` \u251C\u2500 Generating system: ${r}`),console.log(` \u2514\u2500 Output path: ${t}/contracts/${e.name}/sources/system/${r}.move`),!L(`${t}/contracts/${e.name}/sources/system/${r}.move`)){let o=`module ${e.name}::${r}_system {
11
11
 
12
12
  }
13
- `;await c(r,`${t}/contracts/${e.name}/sources/system/${o}.move`,"formatAndWriteMove")}}),console.log(`\u2705 System Generation Complete
14
- `)}async function O(e,t,o){console.log(`
15
- \u{1F4C4} Starting Move.toml Generation...`),console.log(` \u2514\u2500 Output path: ${t}/contracts/${e.name}/Move.toml`);let r=`[package]
13
+ `;await c(o,`${t}/contracts/${e.name}/sources/system/${r}.move`,"formatAndWriteMove")}}),console.log(`\u2705 System Generation Complete
14
+ `)}async function T(e,t,r){console.log(`
15
+ \u{1F4C4} Starting Move.toml Generation...`),console.log(` \u2514\u2500 Output path: ${t}/contracts/${e.name}/Move.toml`);let o=`[package]
16
16
  name = "${e.name}"
17
17
  version = "0.0.1"
18
18
  edition = "2024.beta"
19
19
 
20
20
  [dependencies]
21
- Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "mainnet-v1.31.1" }
22
- Obelisk = { git = "https://github.com/0xobelisk/obelisk-engine.git", subdir = "packages/obelisk-framework", rev = "main" }
21
+ Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "mainnet-v1.36.2" }
22
+ Dubhe = { git = "https://github.com/0xobelisk/dubhe.git", subdir = "packages/dubhe-framework", rev = "main" }
23
23
 
24
24
  [addresses]
25
25
  sui = "0x2"
26
- obelisk = "${o}"
26
+ dubhe = "${r}"
27
27
  ${e.name} = "0x0"
28
- `;await c(r,`${t}/contracts/${e.name}/Move.toml`,"formatAndWriteMove"),console.log(`\u2705 Move.toml Generation Complete
29
- `)}function m(e){return e.split("_").map((t,o)=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function V(e,t){return Object.entries(t).map(([o,r])=>`public(package) fun set_${o}(self: &mut ${e}, ${o}: ${r}) {
30
- self.${o} = ${o};
28
+ `;await c(o,`${t}/contracts/${e.name}/Move.toml`,"formatAndWriteMove"),console.log(`\u2705 Move.toml Generation Complete
29
+ `)}function p(e){return e.split("_").map((t,r)=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function V(e,t){return Object.entries(t).map(([r,o])=>`public(package) fun set_${r}(self: &mut ${e}, ${r}: ${o}) {
30
+ self.${r} = ${r};
31
31
  }`).join(`
32
32
  `)}function B(e,t){return`public(package) fun set(self: &mut ${e}, ${d(t)}) {
33
- ${Object.entries(t).map(([o])=>`self.${o} = ${o};`).join(`
33
+ ${Object.entries(t).map(([r])=>`self.${r} = ${r};`).join(`
34
34
  `)}
35
- }`}function H(e,t){return`public fun get(self: &${e}): ${D(t)} {
36
- (${M(t,"")})
37
- }`}function z(e,t){return Object.entries(t).map(([o,r])=>`public fun get_${o}(self: &${e}): ${r} {
38
- self.${o}
35
+ }`}function H(e,t){return`public fun get(self: &${e}): ${C(t)} {
36
+ (${M(t)})
37
+ }`}function z(e,t){return Object.entries(t).map(([r,o])=>`public fun get_${r}(self: &${e}): ${o} {
38
+ self.${r}
39
39
  }`).join(`
40
- `)}function l(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}async function j(e,t,o){console.log(`
41
- \u{1F4E6} Starting Schema Data Generation...`);for(let r in t){let n=t[r];if(n.data){console.log(` \u251C\u2500 Processing schema: ${r}`);for(let s of n.data){console.log(` \u2514\u2500 Generating ${s.name} ${Array.isArray(s.fields)?"(enum)":"(struct)"}`);let a="",p=n.data.filter(i=>Array.isArray(i.fields)).map(i=>i.name);Array.isArray(s.fields)?a=`module ${e}::${r}_${l(s.name)} {
42
- public enum ${s.name} has copy, drop , store {
43
- ${s.fields}
40
+ `)}function u(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}async function W(e,t,r){console.log(`
41
+ \u{1F4E6} Starting Schema Data Generation...`);for(let o in t){let s=t[o];if(s.data){console.log(` \u251C\u2500 Processing schema: ${o}`);for(let n of s.data){console.log(` \u2514\u2500 Generating ${n.name} ${Array.isArray(n.fields)?"(enum)":"(struct)"}`);let a="",m=s.data.filter(i=>Array.isArray(i.fields)).map(i=>i.name);Array.isArray(n.fields)?a=`module ${e}::${o}_${u(n.name)} {
42
+ public enum ${n.name} has copy, drop , store {
43
+ ${n.fields}
44
44
  }
45
45
 
46
- ${s.fields.map(i=>`public fun new_${l(i)}(): ${s.name} {
47
- ${s.name}::${i}
48
- }`).join("")}`:a=`module ${e}::${r}_${l(s.name)} {
46
+ ${n.fields.map(i=>`public fun new_${u(i)}(): ${n.name} {
47
+ ${n.name}::${i}
48
+ }`).join("")}`:a=`module ${e}::${o}_${u(n.name)} {
49
49
  use std::ascii::String;
50
- ${p.map(i=>`use ${e}::${r}_${l(i)}::${i};`).join(`
50
+ ${m.map(i=>`use ${e}::${o}_${u(i)}::${i};`).join(`
51
51
  `)}
52
52
 
53
- public struct ${s.name} has copy, drop , store {
54
- ${d(s.fields)}
53
+ public struct ${n.name} has copy, drop , store {
54
+ ${d(n.fields)}
55
55
  }
56
56
 
57
- public fun new(${d(s.fields)}): ${s.name} {
58
- ${s.name} {
59
- ${C(s.fields)}
57
+ public fun new(${d(n.fields)}): ${n.name} {
58
+ ${n.name} {
59
+ ${A(n.fields)}
60
60
  }
61
61
  }
62
62
 
63
- ${H(s.name,s.fields)}
64
- ${z(s.name,s.fields)}
65
- ${V(s.name,s.fields)}
66
- ${B(s.name,s.fields)}
67
- }`,await c(a,`${o}/contracts/${e}/sources/codegen/schemas/${r}_${l(s.name)}.move`,"formatAndWriteMove")}}}console.log(`\u2705 Schema Data Generation Complete
68
- `)}function N(e,t,o){return o.data?o.data.map(r=>`use ${e}::${t}_${l(r.name)}::${r.name};`).join(`
69
- `):""}async function W(e,t,o){console.log(`
70
- \u{1F528} Starting Schema Structure Generation...`);for(let r in t){console.log(` \u251C\u2500 Generating schema: ${r}`),console.log(` \u251C\u2500 Output path: ${o}/contracts/${e}/sources/codegen/schemas/${r}.move`),console.log(` \u2514\u2500 Structure fields: ${Object.keys(t[r].structure).length}`);let n=t[r],s=`module ${e}::${r}_schema {
63
+ ${H(n.name,n.fields)}
64
+ ${z(n.name,n.fields)}
65
+ ${V(n.name,n.fields)}
66
+ ${B(n.name,n.fields)}
67
+ }`,await c(a,`${r}/contracts/${e}/sources/codegen/schemas/${o}_${u(n.name)}.move`,"formatAndWriteMove")}}}console.log(`\u2705 Schema Data Generation Complete
68
+ `)}function N(e,t,r){return r.data?r.data.map(o=>`use ${e}::${t}_${u(o.name)}::${o.name};`).join(`
69
+ `):""}async function G(e,t,r){console.log(`
70
+ \u{1F528} Starting Schema Structure Generation...`);for(let o in t){console.log(` \u251C\u2500 Generating schema: ${o}`),console.log(` \u251C\u2500 Output path: ${r}/contracts/${e}/sources/codegen/schemas/${o}.move`),console.log(` \u2514\u2500 Structure fields: ${Object.keys(t[o].structure).length}`);let s=t[o],n=`module ${e}::${o}_schema {
71
71
  use std::ascii::String;
72
72
  use std::type_name;
73
- use obelisk::dapps_system;
74
- use obelisk::dapps_schema::Dapps;
75
- use obelisk::storage_value::{Self, StorageValue};
76
- use obelisk::storage_map::{Self, StorageMap};
77
- use obelisk::storage_double_map::{Self, StorageDoubleMap};
73
+ use dubhe::dapps_system;
74
+ use dubhe::dapps_schema::Dapps;
75
+ use dubhe::storage_value::{Self, StorageValue};
76
+ use dubhe::storage_map::{Self, StorageMap};
77
+ use dubhe::storage_double_map::{Self, StorageDoubleMap};
78
78
  use ${e}::dapp_key::DappKey;
79
- ${N(e,r,n)}
79
+ ${N(e,o,s)}
80
80
 
81
- public struct ${m(r)} has key, store {
81
+ public struct ${p(o)} has key, store {
82
82
  id: UID,
83
- ${d(n.structure)}
83
+ ${d(s.structure)}
84
84
  }
85
85
 
86
- ${Object.entries(n.structure).map(([a,p])=>`public fun borrow_${a}(self: &${m(r)}) : &${p} {
86
+ ${Object.entries(s.structure).map(([a,m])=>`public fun borrow_${a}(self: &${p(o)}) : &${m} {
87
87
  &self.${a}
88
88
  }
89
89
 
90
- public(package) fun borrow_mut_${a}(self: &mut ${m(r)}): &mut ${p} {
90
+ public(package) fun borrow_mut_${a}(self: &mut ${p(o)}): &mut ${m} {
91
91
  &mut self.${a}
92
92
  }
93
93
  `).join("")}
94
94
 
95
- public fun register(dapps: &mut Dapps, ctx: &mut TxContext): ${m(r)} {
95
+ public fun register(dapps: &mut Dapps, ctx: &mut TxContext): ${p(o)} {
96
96
  let package_id = dapps_system::current_package_id<DappKey>();
97
97
  assert!(dapps.borrow_metadata().contains_key(package_id), 0);
98
98
  assert!(dapps.borrow_admin().get(package_id) == ctx.sender(), 0);
99
- let schema = type_name::get<${m(r)}>().into_string();
99
+ let schema = type_name::get<${p(o)}>().into_string();
100
100
  assert!(!dapps.borrow_schemas().get(package_id).contains(&schema), 0);
101
- dapps_system::add_schema<${m(r)}>(dapps, package_id, ctx);
102
- ${m(r)} {
101
+ dapps_system::add_schema<${p(o)}>(dapps, package_id, ctx);
102
+ ${p(o)} {
103
103
  id: object::new(ctx),
104
- ${Object.entries(n.structure).map(([a,p])=>{let i="";return p.includes("StorageValue")?i="storage_value::new()":p.includes("StorageMap")?i="storage_map::new()":p.includes("StorageDoubleMap")&&(i="storage_double_map::new()"),`${a}: ${i},`}).join(" ")}
104
+ ${Object.entries(s.structure).map(([a,m])=>{let i="";return m.includes("StorageValue")?i="storage_value::new()":m.includes("StorageMap")?i="storage_map::new()":m.includes("StorageDoubleMap")&&(i="storage_double_map::new()"),`${a}: ${i},`}).join(" ")}
105
105
  }
106
106
  }
107
107
 
108
- }`;await c(s,`${o}/contracts/${e}/sources/codegen/schemas/${r}.move`,"formatAndWriteMove")}console.log(`\u2705 Schema Structure Generation Complete
109
- `)}import{existsSync as Q}from"fs";async function G(e,t){if(console.log(`
110
- \u{1F4DD} Starting Deploy Hook Generation...`),console.log(` \u2514\u2500 Output path: ${t}/contracts/${e.name}/sources/script/deploy_hook.move`),!Q(`${t}/contracts/${e.name}/sources/script/deploy_hook.move`)){let o=`module ${e.name}::deploy_hook {
111
- use obelisk::dapps_schema::Dapps;
112
- use obelisk::dapps_system;
108
+ }`;await c(n,`${r}/contracts/${e}/sources/codegen/schemas/${o}.move`,"formatAndWriteMove")}console.log(`\u2705 Schema Structure Generation Complete
109
+ `)}import{existsSync as Q}from"fs";async function R(e,t){if(console.log(`
110
+ \u{1F4DD} Starting Deploy Hook Generation...`),console.log(` \u2514\u2500 Output path: ${t}/contracts/${e.name}/sources/script/deploy_hook.move`),!Q(`${t}/contracts/${e.name}/sources/script/deploy_hook.move`)){let r=`module ${e.name}::deploy_hook {
111
+ use dubhe::dapps_schema::Dapps;
112
+ use dubhe::dapps_system;
113
113
  use ${e.name}::dapp_key::DappKey;
114
114
  use std::ascii;
115
115
  use sui::clock::Clock;
116
116
  use sui::transfer::public_share_object;
117
117
  #[test_only]
118
- use obelisk::dapps_schema;
118
+ use dubhe::dapps_schema;
119
119
  #[test_only]
120
120
  use sui::clock;
121
121
  #[test_only]
@@ -124,7 +124,7 @@ ${e.name} = "0x0"
124
124
  use sui::test_scenario::Scenario;
125
125
 
126
126
  public entry fun run(dapps: &mut Dapps, clock: &Clock, ctx: &mut TxContext) {
127
- // Register the dapp to obelisk.
127
+ // Register the dapp to dubhe.
128
128
  dapps_system::register<DappKey>(
129
129
  dapps,
130
130
  ascii::string(b"${e.name}"),
@@ -132,13 +132,13 @@ ${e.name} = "0x0"
132
132
  clock,
133
133
  ctx
134
134
  );
135
- ${Object.keys(e.schemas).map(r=>`let ${r} = ${e.name}::${r}_schema::register(dapps, ctx);`).join(`
135
+ ${Object.keys(e.schemas).map(o=>`let ${o} = ${e.name}::${o}_schema::register(dapps, ctx);`).join(`
136
136
  `)}
137
137
  // Logic that needs to be automated once the contract is deployed
138
138
 
139
139
 
140
140
  // Share the dapp object with the public
141
- ${Object.keys(e.schemas).map(r=>`public_share_object(${r});`).join(`
141
+ ${Object.keys(e.schemas).map(o=>`public_share_object(${o});`).join(`
142
142
  `)}
143
143
  }
144
144
 
@@ -159,9 +159,9 @@ ${e.name} = "0x0"
159
159
  (scenario, dapps)
160
160
  }
161
161
  }
162
- `;await c(o,`${t}/contracts/${e.name}/sources/script/deploy_hook.move`,"formatAndWriteMove")}console.log(`\u2705 Deploy Hook Generation Complete
163
- `)}async function R(e,t){console.log(`
164
- \u{1F511} Starting DappKey Generation...`),console.log(` \u2514\u2500 Output path: ${t}/contracts/${e.name}/sources/codegen/dapp_key.move`);let o=`module ${e.name}::dapp_key {
162
+ `;await c(r,`${t}/contracts/${e.name}/sources/script/deploy_hook.move`,"formatAndWriteMove")}console.log(`\u2705 Deploy Hook Generation Complete
163
+ `)}async function O(e,t){console.log(`
164
+ \u{1F511} Starting DappKey Generation...`),console.log(` \u2514\u2500 Output path: ${t}/contracts/${e.name}/sources/codegen/dapp_key.move`);let r=`module ${e.name}::dapp_key {
165
165
  /// Authorization token for the app.
166
166
  public struct DappKey has drop {}
167
167
 
@@ -169,9 +169,9 @@ ${e.name} = "0x0"
169
169
  DappKey { }
170
170
  }
171
171
  }
172
- `;await c(o,`${t}/contracts/${e.name}/sources/codegen/dapp_key.move`,"formatAndWriteMove"),console.log(`\u2705 DappKey Generation Complete
173
- `)}function E(e){switch(e){case"testnet":return"0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256";case"localnet":return"0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256";default:return"0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256"}}async function Ue(e,t,o,r){console.log(`
174
- \u{1F680} Starting Schema Generation Process...`),console.log("\u{1F4CB} Project Configuration:"),console.log(` \u251C\u2500 Name: ${e.name}`),console.log(` \u251C\u2500 Description: ${e.description||"No description provided"}`),console.log(` \u251C\u2500 Network: ${o||"testnet"}`),console.log(` \u2514\u2500 Framework ID: ${r||E(o??"testnet")}
175
- `);let n=t??process.cwd();r=r||E(o??"testnet"),k(`${n}/contracts/${e.name}`)&&_(`${n}/contracts/${e.name}/sources/codegen`),k(`${n}/contracts/${e.name}/Move.toml`)||await O(e,n,r),k(`${n}/contracts/${e.name}/sources/script/deploy_hook.move`)||await G(e,n),await T(e,n),await j(e.name,e.schemas,n),await W(e.name,e.schemas,n),await R(e,n),console.log(`\u2705 Schema Generation Process Complete!
176
- `)}import{findUp as X}from"find-up";import x from"path";import Y from"esbuild";var b=class extends Error{name="NotInsideProjectError";message="You are not inside a Obelisk project"};import{rmSync as Z}from"fs";import{pathToFileURL as q}from"url";import J from"os";var P=["obelisk.config.js","obelisk.config.mjs","obelisk.config.ts","obelisk.config.mts"],S="obelisk.config.example.mjs";async function Ze(e){e=await F(e);try{return await Y.build({entryPoints:[e],format:"esm",outfile:S,platform:"node",bundle:!0,packages:"external"}),e=await F(S,!0),(await import(e+`?update=${Date.now()}`)).obeliskConfig}finally{Z(S,{force:!0})}}async function F(e,t){return e===void 0?e=await ee():x.isAbsolute(e)||(e=x.join(process.cwd(),e),e=x.normalize(e)),t&&J.platform()==="win32"?q(e).href:e}async function ee(){let e=await X(P);if(e===void 0)throw new b;return e}export{c as formatAndWriteMove,ue as formatAndWriteTypescript,h as formatMove,w as formatTypescript,Ze as loadConfig,ge as posixPath,F as resolveConfigPath,Ue as schemaGen};
172
+ `;await c(r,`${t}/contracts/${e.name}/sources/codegen/dapp_key.move`,"formatAndWriteMove"),console.log(`\u2705 DappKey Generation Complete
173
+ `)}function E(e){switch(e){case"testnet":return"0x1736475f476c5dec96f33c03c778843f572239d3a887d795eef66d2836484c28";case"localnet":return"0x1736475f476c5dec96f33c03c778843f572239d3a887d795eef66d2836484c28";default:return"0x1736475f476c5dec96f33c03c778843f572239d3a887d795eef66d2836484c28"}}async function Ue(e,t,r,o){console.log(`
174
+ \u{1F680} Starting Schema Generation Process...`),console.log("\u{1F4CB} Project Configuration:"),console.log(` \u251C\u2500 Name: ${e.name}`),console.log(` \u251C\u2500 Description: ${e.description||"No description provided"}`),console.log(` \u251C\u2500 Network: ${r||"testnet"}`),console.log(` \u2514\u2500 Framework ID: ${o||E(r??"testnet")}
175
+ `);let s=t??process.cwd();o=o||E(r??"testnet"),_(`${s}/contracts/${e.name}`)&&h(`${s}/contracts/${e.name}/sources/codegen`),_(`${s}/contracts/${e.name}/Move.toml`)||await T(e,s,o),_(`${s}/contracts/${e.name}/sources/script/deploy_hook.move`)||await R(e,s),await j(e,s),await W(e.name,e.schemas,s),await G(e.name,e.schemas,s),await O(e,s),console.log(`\u2705 Schema Generation Process Complete!
176
+ `)}import{findUp as X}from"find-up";import x from"path";import Y from"esbuild";var b=class extends Error{name="NotInsideProjectError";message="You are not inside a Dubhe project"};import{rmSync as Z}from"fs";import{pathToFileURL as q}from"url";import J from"os";var P=["dubhe.config.js","dubhe.config.mjs","dubhe.config.ts","dubhe.config.mts"],S="dubhe.config.example.mjs";async function Ze(e){e=await F(e);try{return await Y.build({entryPoints:[e],format:"esm",outfile:S,platform:"node",bundle:!0,packages:"external"}),e=await F(S,!0),(await import(e+`?update=${Date.now()}`)).dubheConfig}finally{Z(S,{force:!0})}}async function F(e,t){return e===void 0?e=await ee():x.isAbsolute(e)||(e=x.join(process.cwd(),e),e=x.normalize(e)),t&&J.platform()==="win32"?q(e).href:e}async function ee(){let e=await X(P);if(e===void 0)throw new b;return e}export{c as formatAndWriteMove,le as formatAndWriteTypescript,w as formatMove,v as formatTypescript,Ze as loadConfig,ge as posixPath,F as resolveConfigPath,Ue as schemaGen};
177
177
  //# 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/generateSystem.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/config.ts","../src/codegen/utils/errors.ts"],"sourcesContent":["import prettier from 'prettier';\nimport prettierPluginMove from 'prettier-plugin-move-js';\n\nexport async function formatMove(\n\tcontent: string,\n\tprettierConfigPath?: string\n): Promise<string> {\n\tlet config;\n\tif (prettierConfigPath) {\n\t\tconfig = await prettier.resolveConfig(prettierConfigPath);\n\t}\n\ttry {\n\t\treturn prettier.format(content, {\n\t\t\tplugins: [prettierPluginMove],\n\t\t\tparser: 'move-parse',\n\t\t\tprintWidth: 120,\n\t\t\tsemi: true,\n\t\t\ttabWidth: 2,\n\t\t\tuseTabs: false,\n\t\t\tbracketSpacing: true,\n\t\t\t...config,\n\t\t});\n\t} catch (error) {\n\t\tlet message;\n\t\tif (error instanceof Error) {\n\t\t\tmessage = error.message;\n\t\t} else {\n\t\t\tmessage = error;\n\t\t}\n\t\tconsole.log(`Error during output formatting: ${message}`);\n\t\treturn content;\n\t}\n}\n\nexport async function formatTypescript(content: string): Promise<string> {\n\treturn prettier.format(content, {\n\t\tparser: 'typescript',\n\t});\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 =\n` // Copyright (c) Obelisk Labs, Inc.\n // SPDX-License-Identifier: MIT\n #[allow(unused_use)]\n \n /* Autogenerated file. Do not edit manually. */\n \n `\n\n let deployHookPrefix = `#[allow(lint(share_owned))]\n \n `\n\n let code = schemaPrefix + formattedOutput\n\n if (fullOutputPath.includes(\".toml\") || fullOutputPath.includes(\"system\")) {\n code = formattedOutput\n } else if (fullOutputPath.includes(\"deploy_hook\")) {\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(\"obelisk:common\");\nexport const error = createDebug(\"obelisk: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, ObeliskConfig } from '../../types';\nimport { rmdirSync, existsSync } from 'fs';\nimport { deleteFolderRecursive } from './common';\nimport { generateSystem } from './generateSystem';\nimport { generateToml } from './generateToml';\nimport { generateSchemaData, generateSchemaStructure } from './generateSchema';\nimport { generateDeployHook, generateMigrate } from './generateScript';\nimport { generateDappKey } from './generateDappKey';\n\nfunction matchFrameworkId(\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet'\n): string {\n\tswitch (network) {\n\t\tcase 'testnet':\n\t\t\treturn '0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256';\n\t\tcase 'localnet':\n\t\t\treturn '0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256';\n\t\tdefault:\n\t\t\treturn '0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256';\n\t}\n}\n\nexport async function schemaGen(\n\tconfig: ObeliskConfig,\n\tsrcPrefix?: string,\n\tnetwork?: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tframeworkId?: string\n) {\n\tconsole.log('\\nšŸš€ Starting Schema Generation Process...');\n\tconsole.log('šŸ“‹ Project Configuration:');\n\tconsole.log(` ā”œā”€ Name: ${config.name}`);\n\tconsole.log(\n\t\t` ā”œā”€ Description: ${config.description || 'No description provided'}`\n\t);\n\tconsole.log(` ā”œā”€ Network: ${network || 'testnet'}`);\n\tconsole.log(\n\t\t` └─ Framework ID: ${\n\t\t\tframeworkId || matchFrameworkId(network ?? 'testnet')\n\t\t}\\n`\n\t);\n\n\tconst path = srcPrefix ?? process.cwd();\n\n\tframeworkId = frameworkId || matchFrameworkId(network ?? 'testnet');\n\n\tif (existsSync(`${path}/contracts/${config.name}`)) {\n\t\tdeleteFolderRecursive(\n\t\t\t`${path}/contracts/${config.name}/sources/codegen`\n\t\t);\n\t}\n\n\tif (!existsSync(`${path}/contracts/${config.name}/Move.toml`)) {\n\t\tawait generateToml(config, path, frameworkId);\n\t}\n\n\tif (\n\t\t!existsSync(\n\t\t\t`${path}/contracts/${config.name}/sources/script/deploy_hook.move`\n\t\t)\n\t) {\n\t\tawait generateDeployHook(config, path);\n\t}\n\n\tawait generateSystem(config, path);\n\tawait generateSchemaData(config.name, config.schemas, path);\n\tawait generateSchemaStructure(config.name, config.schemas, path);\n\tawait generateDappKey(config, path);\n\tconsole.log('āœ… Schema Generation Process Complete!\\n');\n}\n","import { MoveType } from '../../types';\nimport fs from 'fs';\n\nexport function deleteFolderRecursive(path: string) {\n\tif (fs.existsSync(path)) {\n\t\tfs.readdirSync(path).forEach(file => {\n\t\t\tconst curPath = `${path}/${file}`;\n\t\t\tif (fs.lstatSync(curPath).isDirectory()) {\n\t\t\t\tdeleteFolderRecursive(curPath);\n\t\t\t} else {\n\t\t\t\tfs.unlinkSync(curPath);\n\t\t\t}\n\t\t});\n\t\tfs.rmdirSync(path);\n\t}\n}\n\nexport function capitalizeFirstLetter(input: string): string {\n\treturn 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(\n\tvalues: Record<string, string> | string\n): string {\n\treturn Object.entries(values)\n\t\t.map(([key, _]) => `${key}`)\n\t\t.join(',');\n}\n\nfunction isAddress(str: string): boolean {\n\tconst regex = /^0x[a-fA-F0-9]+$/;\n\treturn 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(\n\tvalues: MoveType | Record<string, MoveType>\n): string {\n\treturn typeof values === 'string'\n\t\t? values\n\t\t: `(${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(\n\tvalues: Record<string, string>\n): string[] {\n\treturn Object.entries(values).map(([key, type]) => `${key}: ${type}`);\n}\n\n/**\n * @param values\n * @param prefixArgs\n * @return [ data.name, data.age ]\n */\nexport function getStructAttrsQuery(\n\tvalues: MoveType | Record<string, MoveType>,\n\tprefixArgs: string\n): string[] {\n\treturn typeof values === 'string'\n\t\t? [`${prefixArgs}self.value`]\n\t\t: Object.entries(values).map(([key, _]) => `${prefixArgs}self.${key}`);\n}\n","import { ObeliskConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\n\nexport async function generateSystem(config: ObeliskConfig, srcPrefix: string) {\n\tconsole.log('\\nāš™ļø Starting System Generation...');\n\tconfig.systems.map(async systemName => {\n\t\tconsole.log(` ā”œā”€ Generating system: ${systemName}`);\n\t\tconsole.log(\n\t\t\t` └─ Output path: ${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`\n\t\t);\n\n\t\tif (\n\t\t\t!existsSync(\n\t\t\t\t`${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`\n\t\t\t)\n\t\t) {\n\t\t\tlet code = `module ${config.name}::${systemName}_system {\n\n}\n`;\n\t\t\tawait formatAndWriteMove(\n\t\t\t\tcode,\n\t\t\t\t`${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`,\n\t\t\t\t'formatAndWriteMove'\n\t\t\t);\n\t\t}\n\t});\n\tconsole.log('āœ… System Generation Complete\\n');\n}\n","import { ObeliskConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateToml(\n\tconfig: ObeliskConfig,\n\tsrcPrefix: string,\n\tframeworkId: string\n) {\n\tconsole.log('\\nšŸ“„ Starting Move.toml Generation...');\n\tconsole.log(\n\t\t` └─ Output path: ${srcPrefix}/contracts/${config.name}/Move.toml`\n\t);\n\n\tlet code = `[package]\nname = \"${config.name}\"\nversion = \"0.0.1\"\nedition = \"2024.beta\"\n\n[dependencies]\nSui = { git = \"https://github.com/MystenLabs/sui.git\", subdir = \"crates/sui-framework/packages/sui-framework\", rev = \"mainnet-v1.31.1\" }\nObelisk = { git = \"https://github.com/0xobelisk/obelisk-engine.git\", subdir = \"packages/obelisk-framework\", rev = \"main\" }\n\n[addresses]\nsui = \"0x2\"\nobelisk = \"${frameworkId}\"\n${config.name} = \"0x0\"\n`;\n\tawait formatAndWriteMove(\n\t\tcode,\n\t\t`${srcPrefix}/contracts/${config.name}/Move.toml`,\n\t\t'formatAndWriteMove'\n\t);\n\tconsole.log('āœ… Move.toml Generation Complete\\n');\n}\n","import { BaseType, SchemaType } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport {\n\tgetStructAttrsWithType,\n\tgetStructAttrs,\n\tgetStructTypes,\n\tgetStructAttrsQuery,\n} from './common';\n\nfunction capitalizeAndRemoveUnderscores(input: string): string {\n\treturn input\n\t\t.split('_')\n\t\t.map((word, index) => {\n\t\t\treturn index === 0\n\t\t\t\t? word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n\t\t\t\t: word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();\n\t\t})\n\t\t.join('');\n}\n\nexport function renderSetAttrsFunc(\n\tschemaName: string,\n\tfields: BaseType | Record<string, BaseType>\n): string {\n\treturn Object.entries(fields)\n\t\t.map(\n\t\t\t([key, type]) =>\n\t\t\t\t`public(package) fun set_${key}(self: &mut ${schemaName}, ${key}: ${type}) {\n self.${key} = ${key};\n }`\n\t\t)\n\t\t.join('\\n');\n}\n\nexport function renderSetFunc(\n\tschemaName: string,\n\tfields: Record<string, string>\n): string {\n\treturn `public(package) fun set(self: &mut ${schemaName}, ${getStructAttrsWithType(\n\t\tfields\n\t)}) {\n ${Object.entries(fields)\n\t\t\t\t.map(([fieldName]) => `self.${fieldName} = ${fieldName};`)\n\t\t\t\t.join('\\n')}\n }`;\n}\n\nexport function renderGetAllFunc(\n\tschemaName: string,\n\tfields: BaseType | Record<string, BaseType>\n): string {\n\treturn `public fun get(self: &${schemaName}): ${getStructTypes(fields)} {\n (${getStructAttrsQuery(fields, '')})\n }`;\n}\n\nexport function renderGetAttrsFunc(\n\tschemaName: string,\n\tfields: BaseType | Record<string, BaseType>\n): string {\n\treturn Object.entries(fields)\n\t\t.map(\n\t\t\t([\n\t\t\t\tkey,\n\t\t\t\ttype,\n\t\t\t]) => `public fun get_${key}(self: &${schemaName}): ${type} {\n self.${key}\n }`\n\t\t)\n\t\t.join('\\n');\n}\n\nfunction convertToSnakeCase(input: string): string {\n\treturn input\n\t\t.replace(/([A-Z])/g, '_$1')\n\t\t.toLowerCase()\n\t\t.replace(/^_/, '');\n}\n\nexport async function generateSchemaData(\n\tprojectName: string,\n\tschemas: Record<string, SchemaType>,\n\tpath: string\n) {\n\tconsole.log('\\nšŸ“¦ Starting Schema Data Generation...');\n\tfor (const schemaName in schemas) {\n\t\tconst schema = schemas[schemaName];\n\t\tif (schema.data) {\n\t\t\tconsole.log(` ā”œā”€ Processing schema: ${schemaName}`);\n\t\t\tfor (const item of schema.data) {\n\t\t\t\tconsole.log(\n\t\t\t\t\t` └─ Generating ${item.name} ${\n\t\t\t\t\t\tArray.isArray(item.fields) ? '(enum)' : '(struct)'\n\t\t\t\t\t}`\n\t\t\t\t);\n\t\t\t\tlet code = '';\n\n\t\t\t\tconst enumNames = schema.data\n\t\t\t\t\t.filter(item => Array.isArray(item.fields))\n\t\t\t\t\t.map(item => item.name);\n\n\t\t\t\tif (Array.isArray(item.fields)) {\n\t\t\t\t\tcode = `module ${projectName}::${schemaName}_${convertToSnakeCase(\n\t\t\t\t\t\titem.name\n\t\t\t\t\t)} {\n public enum ${item.name} has copy, drop , store {\n ${item.fields}\n }\n \n ${item.fields\n\t\t\t\t\t\t\t.map((field: string) => {\n\t\t\t\t\t\t\t\treturn `public fun new_${convertToSnakeCase(\n\t\t\t\t\t\t\t\t\tfield\n\t\t\t\t\t\t\t\t)}(): ${item.name} {\n ${item.name}::${field}\n }`;\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t.join('')}`;\n\t\t\t\t} else {\n\t\t\t\t\tcode = `module ${projectName}::${schemaName}_${convertToSnakeCase(\n\t\t\t\t\t\titem.name\n\t\t\t\t\t)} {\n use std::ascii::String;\n ${enumNames\n\t\t\t\t\t\t\t\t.map(\n\t\t\t\t\t\t\t\t\tname =>\n\t\t\t\t\t\t\t\t\t\t`use ${projectName}::${schemaName}_${convertToSnakeCase(\n\t\t\t\t\t\t\t\t\t\t\tname\n\t\t\t\t\t\t\t\t\t\t)}::${name};`\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t.join('\\n')}\n\n public struct ${item.name} has copy, drop , store {\n ${getStructAttrsWithType(item.fields)}\n }\n \n public fun new(${getStructAttrsWithType(\n\t\t\t\t\t\t\t\titem.fields\n\t\t\t\t\t\t\t)}): ${item.name} {\n ${item.name} {\n ${getStructAttrs(item.fields)}\n }\n }\n \n ${renderGetAllFunc(item.name, item.fields)}\n ${renderGetAttrsFunc(item.name, item.fields)}\n ${renderSetAttrsFunc(item.name, item.fields)}\n ${renderSetFunc(item.name, item.fields)}\n }`;\n\t\t\t\t}\n\n\t\t\t\tawait formatAndWriteMove(\n\t\t\t\t\tcode,\n\t\t\t\t\t`${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}_${convertToSnakeCase(\n\t\t\t\t\t\titem.name\n\t\t\t\t\t)}.move`,\n\t\t\t\t\t'formatAndWriteMove'\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\tconsole.log('āœ… Schema Data Generation Complete\\n');\n}\n\nfunction generateImport(\n\tprojectName: string,\n\tschemaName: string,\n\tschema: SchemaType\n) {\n\tif (schema.data) {\n\t\treturn schema.data\n\t\t\t.map(item => {\n\t\t\t\treturn `use ${projectName}::${schemaName}_${convertToSnakeCase(\n\t\t\t\t\titem.name\n\t\t\t\t)}::${item.name};`;\n\t\t\t})\n\t\t\t.join('\\n');\n\t} else {\n\t\treturn '';\n\t}\n}\n\nexport async function generateSchemaStructure(\n\tprojectName: string,\n\tschemas: Record<string, SchemaType>,\n\tpath: string\n) {\n\tconsole.log('\\nšŸ”Ø Starting Schema Structure Generation...');\n\tfor (const schemaName in schemas) {\n\t\tconsole.log(` ā”œā”€ Generating schema: ${schemaName}`);\n\t\tconsole.log(\n\t\t\t` ā”œā”€ Output path: ${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}.move`\n\t\t);\n\t\tconsole.log(\n\t\t\t` └─ Structure fields: ${\n\t\t\t\tObject.keys(schemas[schemaName].structure).length\n\t\t\t}`\n\t\t);\n\t\tconst schema = schemas[schemaName];\n\t\tconst schemaMoudle = `module ${projectName}::${schemaName}_schema {\n use std::ascii::String;\n use std::type_name;\n use obelisk::dapps_system;\n use obelisk::dapps_schema::Dapps;\n use obelisk::storage_value::{Self, StorageValue};\n use obelisk::storage_map::{Self, StorageMap};\n use obelisk::storage_double_map::{Self, StorageDoubleMap};\n use ${projectName}::dapp_key::DappKey;\n ${generateImport(projectName, schemaName, schema)}\n\n public struct ${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\tschemaName\n\t\t\t\t\t)} has key, store {\n id: UID,\n ${getStructAttrsWithType(schema.structure)}\n } \n \n ${Object.entries(schema.structure)\n\t\t\t\t\t\t\t.map(([key, value]) => {\n\t\t\t\t\t\t\t\treturn `public fun borrow_${key}(self: &${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\t\t\t\tschemaName\n\t\t\t\t\t\t\t\t)}) : &${value} {\n &self.${key}\n }\n \n public(package) fun borrow_mut_${key}(self: &mut ${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\tschemaName\n\t\t\t\t\t)}): &mut ${value} {\n &mut self.${key}\n }\n `;\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t.join('')} \n \n public fun register(dapps: &mut Dapps, ctx: &mut TxContext): ${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\tschemaName\n\t\t\t\t\t)} {\n let package_id = dapps_system::current_package_id<DappKey>();\n assert!(dapps.borrow_metadata().contains_key(package_id), 0);\n assert!(dapps.borrow_admin().get(package_id) == ctx.sender(), 0);\n let schema = type_name::get<${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\t\tschemaName\n\t\t\t\t\t\t)}>().into_string();\n assert!(!dapps.borrow_schemas().get(package_id).contains(&schema), 0);\n dapps_system::add_schema<${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\t\tschemaName\n\t\t\t\t\t\t)}>(dapps, package_id, ctx);\n ${capitalizeAndRemoveUnderscores(schemaName)} {\n id: object::new(ctx),\n ${Object.entries(schema.structure)\n\t\t\t\t\t\t\t\t.map(([key, value]) => {\n\t\t\t\t\t\t\t\t\tlet storage_type = '';\n\t\t\t\t\t\t\t\t\tif (value.includes('StorageValue')) {\n\t\t\t\t\t\t\t\t\t\tstorage_type = `storage_value::new()`;\n\t\t\t\t\t\t\t\t\t} else if (value.includes('StorageMap')) {\n\t\t\t\t\t\t\t\t\t\tstorage_type = `storage_map::new()`;\n\t\t\t\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\t\t\t\tvalue.includes('StorageDoubleMap')\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\tstorage_type = `storage_double_map::new()`;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\treturn `${key}: ${storage_type},`;\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t.join(' ')}\n }\n }\n \n }`;\n\t\tawait formatAndWriteMove(\n\t\t\tschemaMoudle,\n\t\t\t`${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}.move`,\n\t\t\t'formatAndWriteMove'\n\t\t);\n\t}\n\tconsole.log('āœ… Schema Structure Generation Complete\\n');\n}\n","import { ObeliskConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\n\nexport async function generateDeployHook(\n\tconfig: ObeliskConfig,\n\tsrcPrefix: string\n) {\n\tconsole.log('\\nšŸ“ Starting Deploy Hook Generation...');\n\tconsole.log(\n\t\t` └─ Output path: ${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`\n\t);\n\n\tif (\n\t\t!existsSync(\n\t\t\t`${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`\n\t\t)\n\t) {\n\t\tlet code = `module ${config.name}::deploy_hook {\n use obelisk::dapps_schema::Dapps;\n use obelisk::dapps_system;\n use ${config.name}::dapp_key::DappKey;\n use std::ascii;\n use sui::clock::Clock;\n use sui::transfer::public_share_object;\n #[test_only]\n use obelisk::dapps_schema;\n #[test_only]\n use sui::clock;\n #[test_only]\n use sui::test_scenario;\n #[test_only]\n use sui::test_scenario::Scenario;\n\n public entry fun run(dapps: &mut Dapps, clock: &Clock, ctx: &mut TxContext) {\n // Register the dapp to obelisk.\n dapps_system::register<DappKey>(\n dapps,\n ascii::string(b\"${config.name}\"),\n ascii::string(b\"${config.description}\"),\n clock,\n ctx\n );\n ${Object.keys(config.schemas)\n\t\t\t.map(schemaName => {\n\t\t\t\treturn `let ${schemaName} = ${config.name}::${schemaName}_schema::register(dapps, ctx);`;\n\t\t\t})\n\t\t\t.join('\\n')}\n // Logic that needs to be automated once the contract is deployed\n\n\n // Share the dapp object with the public\n ${Object.keys(config.schemas)\n\t\t\t.map(schemaName => {\n\t\t\t\treturn `public_share_object(${schemaName});`;\n\t\t\t})\n\t\t\t.join('\\n')}\n }\n\n #[test_only]\n public fun deploy_hook_for_testing(): (Scenario, Dapps) {\n let mut scenario = test_scenario::begin(@0xA);\n {\n let ctx = test_scenario::ctx(&mut scenario);\n dapps_schema::init_dapps_for_testing(ctx);\n test_scenario::next_tx(&mut scenario,@0xA);\n };\n let mut dapps = test_scenario::take_shared<Dapps>(&scenario);\n let ctx = test_scenario::ctx(&mut scenario);\n let clock = clock::create_for_testing(ctx);\n run(&mut dapps, &clock, ctx);\n clock::destroy_for_testing(clock);\n test_scenario::next_tx(&mut scenario,@0xA);\n (scenario, dapps)\n }\n}\n`;\n\t\tawait formatAndWriteMove(\n\t\t\tcode,\n\t\t\t`${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`,\n\t\t\t'formatAndWriteMove'\n\t\t);\n\t}\n\tconsole.log('āœ… Deploy Hook Generation Complete\\n');\n}\n\nexport function generateMigrate(config: ObeliskConfig, srcPrefix: string) {\n\tif (\n\t\t!existsSync(\n\t\t\t`${srcPrefix}/contracts/${config.name}/sources/script/migrate.move`\n\t\t)\n\t) {\n\t\tlet code = `module ${config.name}::migrate {\n use obelisk::world::{World, AdminCap};\n\n /// Not the right admin for this world\n const ENotAdmin: u64 = 0;\n const EWrongVersion: u64 = 1;\n const ENotUpgrade: u64 = 2;\n const VERSION: u64 = 1;\n\n public entry fun run(world: &mut World, admin_cap: &AdminCap) {\n assert!(world.admin() == object::id(admin_cap), ENotAdmin);\n assert!(world.version() < VERSION, ENotUpgrade);\n *obelisk::world::mut_version(world, admin_cap) = VERSION;\n }\n\n public fun assert_version(world: &World){\n assert!(world.version() == VERSION, EWrongVersion);\n }\n}\n`;\n\t\tformatAndWriteMove(\n\t\t\tcode,\n\t\t\t`${srcPrefix}/contracts/${config.name}/sources/script/migrate.move`,\n\t\t\t'formatAndWriteMove'\n\t\t);\n\t}\n}\n","import { ObeliskConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateDappKey(\n\tconfig: ObeliskConfig,\n\tsrcPrefix: string\n) {\n\tconsole.log('\\nšŸ”‘ Starting DappKey Generation...');\n\tconsole.log(\n\t\t` └─ Output path: ${srcPrefix}/contracts/${config.name}/sources/codegen/dapp_key.move`\n\t);\n\n\tlet code = `module ${config.name}::dapp_key {\n\\t/// Authorization token for the app.\n\\tpublic struct DappKey has drop {}\n\n\\tpublic(package) fun new(): DappKey {\n\\t\\tDappKey { }\n\\t}\n}\n`;\n\tawait formatAndWriteMove(\n\t\tcode,\n\t\t`${srcPrefix}/contracts/${config.name}/sources/codegen/dapp_key.move`,\n\t\t'formatAndWriteMove'\n\t);\n\tconsole.log('āœ… DappKey Generation Complete\\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 = [\n \"obelisk.config.js\",\n \"obelisk.config.mjs\",\n \"obelisk.config.ts\",\n \"obelisk.config.mts\",\n];\nconst TEMP_CONFIG = \"obelisk.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()}`)).obeliskConfig;\n } finally {\n rmSync(TEMP_CONFIG, { force: true });\n }\n}\n\nexport async function resolveConfigPath(\n configPath: string | undefined,\n toFileURL?: boolean\n) {\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\"\n ? pathToFileURL(configPath).href\n : 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","\nexport class NotInsideProjectError extends Error {\nname = \"NotInsideProjectError\";\nmessage = \"You are not inside a Obelisk project\";\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","deployHookPrefix","code","fs","path","debug","formatAndWriteTypescript","formatTypescript","posixPath","path","existsSync","fs","deleteFolderRecursive","path","file","curPath","getStructAttrs","values","key","_","getStructTypes","values","_","type","getStructAttrsWithType","key","getStructAttrsQuery","prefixArgs","existsSync","generateSystem","config","srcPrefix","systemName","code","formatAndWriteMove","generateToml","config","srcPrefix","frameworkId","code","formatAndWriteMove","capitalizeAndRemoveUnderscores","input","word","index","renderSetAttrsFunc","schemaName","fields","key","type","renderSetFunc","getStructAttrsWithType","fieldName","renderGetAllFunc","getStructTypes","getStructAttrsQuery","renderGetAttrsFunc","convertToSnakeCase","generateSchemaData","projectName","schemas","path","schema","item","code","enumNames","field","name","getStructAttrs","formatAndWriteMove","generateImport","generateSchemaStructure","schemaMoudle","value","storage_type","existsSync","generateDeployHook","config","srcPrefix","code","schemaName","formatAndWriteMove","generateDappKey","config","srcPrefix","code","formatAndWriteMove","matchFrameworkId","network","schemaGen","config","srcPrefix","frameworkId","path","existsSync","deleteFolderRecursive","generateToml","generateDeployHook","generateSystem","generateSchemaData","generateSchemaStructure","generateDappKey","findUp","path","esbuild","NotInsideProjectError","rmSync","pathToFileURL","os","configFiles","TEMP_CONFIG","loadConfig","configPath","resolveConfigPath","esbuild","toFileURL","getUserConfigPath","path","tsConfigPath","findUp","NotInsideProjectError"]}
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/generateSystem.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/config.ts","../src/codegen/utils/errors.ts"],"sourcesContent":["import prettier from 'prettier';\nimport prettierPluginMove from 'prettier-plugin-move-js';\n\nexport async function formatMove(\n\tcontent: string,\n\tprettierConfigPath?: string\n): Promise<string> {\n\tlet config;\n\tif (prettierConfigPath) {\n\t\tconfig = await prettier.resolveConfig(prettierConfigPath);\n\t}\n\ttry {\n\t\treturn prettier.format(content, {\n\t\t\tplugins: [prettierPluginMove],\n\t\t\tparser: 'move-parse',\n\t\t\tprintWidth: 120,\n\t\t\tsemi: true,\n\t\t\ttabWidth: 2,\n\t\t\tuseTabs: false,\n\t\t\tbracketSpacing: true,\n\t\t\t...config,\n\t\t});\n\t} catch (error) {\n\t\tlet message;\n\t\tif (error instanceof Error) {\n\t\t\tmessage = error.message;\n\t\t} else {\n\t\t\tmessage = error;\n\t\t}\n\t\tconsole.log(`Error during output formatting: ${message}`);\n\t\treturn content;\n\t}\n}\n\nexport async function formatTypescript(content: string): Promise<string> {\n\treturn prettier.format(content, {\n\t\tparser: 'typescript',\n\t});\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 =\n` // Copyright (c) Obelisk Labs, Inc.\n // SPDX-License-Identifier: MIT\n #[allow(unused_use)]\n \n /* Autogenerated file. Do not edit manually. */\n \n `\n\n let deployHookPrefix = `#[allow(lint(share_owned))]\n \n `\n\n let code = schemaPrefix + formattedOutput\n\n if (fullOutputPath.includes(\".toml\") || fullOutputPath.includes(\"system\")) {\n code = formattedOutput\n } else if (fullOutputPath.includes(\"deploy_hook\")) {\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 { generateSystem } from './generateSystem';\nimport { generateToml } from './generateToml';\nimport { generateSchemaData, generateSchemaStructure } from './generateSchema';\nimport { generateDeployHook, generateMigrate } from './generateScript';\nimport { generateDappKey } from './generateDappKey';\n\nfunction matchFrameworkId(\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet'\n): string {\n\tswitch (network) {\n\t\tcase 'testnet':\n\t\t\treturn '0x1736475f476c5dec96f33c03c778843f572239d3a887d795eef66d2836484c28';\n\t\tcase 'localnet':\n\t\t\treturn '0x1736475f476c5dec96f33c03c778843f572239d3a887d795eef66d2836484c28';\n\t\tdefault:\n\t\t\treturn '0x1736475f476c5dec96f33c03c778843f572239d3a887d795eef66d2836484c28';\n\t}\n}\n\nexport async function schemaGen(\n\tconfig: DubheConfig,\n\tsrcPrefix?: string,\n\tnetwork?: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tframeworkId?: string\n) {\n\tconsole.log('\\nšŸš€ Starting Schema Generation Process...');\n\tconsole.log('šŸ“‹ Project Configuration:');\n\tconsole.log(` ā”œā”€ Name: ${config.name}`);\n\tconsole.log(\n\t\t` ā”œā”€ Description: ${config.description || 'No description provided'}`\n\t);\n\tconsole.log(` ā”œā”€ Network: ${network || 'testnet'}`);\n\tconsole.log(\n\t\t` └─ Framework ID: ${\n\t\t\tframeworkId || matchFrameworkId(network ?? 'testnet')\n\t\t}\\n`\n\t);\n\n\tconst path = srcPrefix ?? process.cwd();\n\n\tframeworkId = frameworkId || matchFrameworkId(network ?? 'testnet');\n\n\tif (existsSync(`${path}/contracts/${config.name}`)) {\n\t\tdeleteFolderRecursive(\n\t\t\t`${path}/contracts/${config.name}/sources/codegen`\n\t\t);\n\t}\n\n\tif (!existsSync(`${path}/contracts/${config.name}/Move.toml`)) {\n\t\tawait generateToml(config, path, frameworkId);\n\t}\n\n\tif (\n\t\t!existsSync(\n\t\t\t`${path}/contracts/${config.name}/sources/script/deploy_hook.move`\n\t\t)\n\t) {\n\t\tawait generateDeployHook(config, path);\n\t}\n\n\tawait generateSystem(config, path);\n\tawait generateSchemaData(config.name, config.schemas, path);\n\tawait generateSchemaStructure(config.name, config.schemas, path);\n\tawait generateDappKey(config, path);\n\tconsole.log('āœ… Schema Generation Process Complete!\\n');\n}\n","import { MoveType } from '../../types';\nimport fs from 'fs';\n\nexport function deleteFolderRecursive(path: string) {\n\tif (fs.existsSync(path)) {\n\t\tfs.readdirSync(path).forEach(file => {\n\t\t\tconst curPath = `${path}/${file}`;\n\t\t\tif (fs.lstatSync(curPath).isDirectory()) {\n\t\t\t\tdeleteFolderRecursive(curPath);\n\t\t\t} else {\n\t\t\t\tfs.unlinkSync(curPath);\n\t\t\t}\n\t\t});\n\t\tfs.rmdirSync(path);\n\t}\n}\n\nexport function capitalizeFirstLetter(input: string): string {\n\treturn 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(\n\tvalues: Record<string, string> | string\n): string {\n\treturn Object.entries(values)\n\t\t.map(([key, _]) => `${key}`)\n\t\t.join(',');\n}\n\nfunction isAddress(str: string): boolean {\n\tconst regex = /^0x[a-fA-F0-9]+$/;\n\treturn 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(\n\tvalues: Record<string, string>\n): string {\n\treturn `(${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(\n\tvalues: Record<string, string>\n): string[] {\n\treturn Object.entries(values).map(([key, type]) => `${key}: ${type}`);\n}\n\n/**\n * @param values\n * @return [ data.name, data.age ]\n */\nexport function getStructAttrsQuery(\n\tvalues: Record<string, string>,\n): string[] {\n\treturn Object.entries(values).map(([key, _]) => `self.${key}`);\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\n\nexport async function generateSystem(config: DubheConfig, srcPrefix: string) {\n\tconsole.log('\\nāš™ļø Starting System Generation...');\n\tconfig.systems.map(async systemName => {\n\t\tconsole.log(` ā”œā”€ Generating system: ${systemName}`);\n\t\tconsole.log(\n\t\t\t` └─ Output path: ${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`\n\t\t);\n\n\t\tif (\n\t\t\t!existsSync(\n\t\t\t\t`${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`\n\t\t\t)\n\t\t) {\n\t\t\tlet code = `module ${config.name}::${systemName}_system {\n\n}\n`;\n\t\t\tawait formatAndWriteMove(\n\t\t\t\tcode,\n\t\t\t\t`${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`,\n\t\t\t\t'formatAndWriteMove'\n\t\t\t);\n\t\t}\n\t});\n\tconsole.log('āœ… System Generation Complete\\n');\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateToml(\n\tconfig: DubheConfig,\n\tsrcPrefix: string,\n\tframeworkId: string\n) {\n\tconsole.log('\\nšŸ“„ Starting Move.toml Generation...');\n\tconsole.log(\n\t\t` └─ Output path: ${srcPrefix}/contracts/${config.name}/Move.toml`\n\t);\n\n\tlet code = `[package]\nname = \"${config.name}\"\nversion = \"0.0.1\"\nedition = \"2024.beta\"\n\n[dependencies]\nSui = { git = \"https://github.com/MystenLabs/sui.git\", subdir = \"crates/sui-framework/packages/sui-framework\", rev = \"mainnet-v1.36.2\" }\nDubhe = { git = \"https://github.com/0xobelisk/dubhe.git\", subdir = \"packages/dubhe-framework\", rev = \"main\" }\n\n[addresses]\nsui = \"0x2\"\ndubhe = \"${frameworkId}\"\n${config.name} = \"0x0\"\n`;\n\tawait formatAndWriteMove(\n\t\tcode,\n\t\t`${srcPrefix}/contracts/${config.name}/Move.toml`,\n\t\t'formatAndWriteMove'\n\t);\n\tconsole.log('āœ… Move.toml Generation Complete\\n');\n}\n","import { BaseType, SchemaType } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport {\n\tgetStructAttrsWithType,\n\tgetStructAttrs,\n\tgetStructTypes,\n\tgetStructAttrsQuery,\n} from './common';\n\nfunction capitalizeAndRemoveUnderscores(input: string): string {\n\treturn input\n\t\t.split('_')\n\t\t.map((word, index) => {\n\t\t\treturn index === 0\n\t\t\t\t? word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n\t\t\t\t: word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();\n\t\t})\n\t\t.join('');\n}\n\nexport function renderSetAttrsFunc(\n\tschemaName: string,\n\tfields: BaseType | Record<string, BaseType>\n): string {\n\treturn Object.entries(fields)\n\t\t.map(\n\t\t\t([key, type]) =>\n\t\t\t\t`public(package) fun set_${key}(self: &mut ${schemaName}, ${key}: ${type}) {\n self.${key} = ${key};\n }`\n\t\t)\n\t\t.join('\\n');\n}\n\nexport function renderSetFunc(\n\tschemaName: string,\n\tfields: Record<string, string>\n): string {\n\treturn `public(package) fun set(self: &mut ${schemaName}, ${getStructAttrsWithType(\n\t\tfields\n\t)}) {\n ${Object.entries(fields)\n\t\t\t\t.map(([fieldName]) => `self.${fieldName} = ${fieldName};`)\n\t\t\t\t.join('\\n')}\n }`;\n}\n\nexport function renderGetAllFunc(\n\tschemaName: string,\n\tfields: Record<string, string>\n): string {\n\treturn `public fun get(self: &${schemaName}): ${getStructTypes(fields)} {\n (${getStructAttrsQuery(fields)})\n }`;\n}\n\nexport function renderGetAttrsFunc(\n\tschemaName: string,\n\tfields: BaseType | Record<string, BaseType>\n): string {\n\treturn Object.entries(fields)\n\t\t.map(\n\t\t\t([\n\t\t\t\tkey,\n\t\t\t\ttype,\n\t\t\t]) => `public fun get_${key}(self: &${schemaName}): ${type} {\n self.${key}\n }`\n\t\t)\n\t\t.join('\\n');\n}\n\nfunction convertToSnakeCase(input: string): string {\n\treturn input\n\t\t.replace(/([A-Z])/g, '_$1')\n\t\t.toLowerCase()\n\t\t.replace(/^_/, '');\n}\n\nexport async function generateSchemaData(\n\tprojectName: string,\n\tschemas: Record<string, SchemaType>,\n\tpath: string\n) {\n\tconsole.log('\\nšŸ“¦ Starting Schema Data Generation...');\n\tfor (const schemaName in schemas) {\n\t\tconst schema = schemas[schemaName];\n\t\tif (schema.data) {\n\t\t\tconsole.log(` ā”œā”€ Processing schema: ${schemaName}`);\n\t\t\tfor (const item of schema.data) {\n\t\t\t\tconsole.log(\n\t\t\t\t\t` └─ Generating ${item.name} ${\n\t\t\t\t\t\tArray.isArray(item.fields) ? '(enum)' : '(struct)'\n\t\t\t\t\t}`\n\t\t\t\t);\n\t\t\t\tlet code = '';\n\n\t\t\t\tconst enumNames = schema.data\n\t\t\t\t\t.filter(item => Array.isArray(item.fields))\n\t\t\t\t\t.map(item => item.name);\n\n\t\t\t\tif (Array.isArray(item.fields)) {\n\t\t\t\t\tcode = `module ${projectName}::${schemaName}_${convertToSnakeCase(\n\t\t\t\t\t\titem.name\n\t\t\t\t\t)} {\n public enum ${item.name} has copy, drop , store {\n ${item.fields}\n }\n \n ${item.fields\n\t\t\t\t\t\t\t.map((field: string) => {\n\t\t\t\t\t\t\t\treturn `public fun new_${convertToSnakeCase(\n\t\t\t\t\t\t\t\t\tfield\n\t\t\t\t\t\t\t\t)}(): ${item.name} {\n ${item.name}::${field}\n }`;\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t.join('')}`;\n\t\t\t\t} else {\n\t\t\t\t\tcode = `module ${projectName}::${schemaName}_${convertToSnakeCase(\n\t\t\t\t\t\titem.name\n\t\t\t\t\t)} {\n use std::ascii::String;\n ${enumNames\n\t\t\t\t\t\t\t\t.map(\n\t\t\t\t\t\t\t\t\tname =>\n\t\t\t\t\t\t\t\t\t\t`use ${projectName}::${schemaName}_${convertToSnakeCase(\n\t\t\t\t\t\t\t\t\t\t\tname\n\t\t\t\t\t\t\t\t\t\t)}::${name};`\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t.join('\\n')}\n\n public struct ${item.name} has copy, drop , store {\n ${getStructAttrsWithType(item.fields)}\n }\n \n public fun new(${getStructAttrsWithType(\n\t\t\t\t\t\t\t\titem.fields\n\t\t\t\t\t\t\t)}): ${item.name} {\n ${item.name} {\n ${getStructAttrs(item.fields)}\n }\n }\n \n ${renderGetAllFunc(item.name, item.fields)}\n ${renderGetAttrsFunc(item.name, item.fields)}\n ${renderSetAttrsFunc(item.name, item.fields)}\n ${renderSetFunc(item.name, item.fields)}\n }`;\n\t\t\t\t}\n\n\t\t\t\tawait formatAndWriteMove(\n\t\t\t\t\tcode,\n\t\t\t\t\t`${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}_${convertToSnakeCase(\n\t\t\t\t\t\titem.name\n\t\t\t\t\t)}.move`,\n\t\t\t\t\t'formatAndWriteMove'\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\tconsole.log('āœ… Schema Data Generation Complete\\n');\n}\n\nfunction generateImport(\n\tprojectName: string,\n\tschemaName: string,\n\tschema: SchemaType\n) {\n\tif (schema.data) {\n\t\treturn schema.data\n\t\t\t.map(item => {\n\t\t\t\treturn `use ${projectName}::${schemaName}_${convertToSnakeCase(\n\t\t\t\t\titem.name\n\t\t\t\t)}::${item.name};`;\n\t\t\t})\n\t\t\t.join('\\n');\n\t} else {\n\t\treturn '';\n\t}\n}\n\nexport async function generateSchemaStructure(\n\tprojectName: string,\n\tschemas: Record<string, SchemaType>,\n\tpath: string\n) {\n\tconsole.log('\\nšŸ”Ø Starting Schema Structure Generation...');\n\tfor (const schemaName in schemas) {\n\t\tconsole.log(` ā”œā”€ Generating schema: ${schemaName}`);\n\t\tconsole.log(\n\t\t\t` ā”œā”€ Output path: ${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}.move`\n\t\t);\n\t\tconsole.log(\n\t\t\t` └─ Structure fields: ${\n\t\t\t\tObject.keys(schemas[schemaName].structure).length\n\t\t\t}`\n\t\t);\n\t\tconst schema = schemas[schemaName];\n\t\tconst schemaMoudle = `module ${projectName}::${schemaName}_schema {\n use std::ascii::String;\n use std::type_name;\n use dubhe::dapps_system;\n use dubhe::dapps_schema::Dapps;\n use dubhe::storage_value::{Self, StorageValue};\n use dubhe::storage_map::{Self, StorageMap};\n use dubhe::storage_double_map::{Self, StorageDoubleMap};\n use ${projectName}::dapp_key::DappKey;\n ${generateImport(projectName, schemaName, schema)}\n\n public struct ${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\tschemaName\n\t\t\t\t\t)} has key, store {\n id: UID,\n ${getStructAttrsWithType(schema.structure)}\n } \n \n ${Object.entries(schema.structure)\n\t\t\t\t\t\t\t.map(([key, value]) => {\n\t\t\t\t\t\t\t\treturn `public fun borrow_${key}(self: &${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\t\t\t\tschemaName\n\t\t\t\t\t\t\t\t)}) : &${value} {\n &self.${key}\n }\n \n public(package) fun borrow_mut_${key}(self: &mut ${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\tschemaName\n\t\t\t\t\t)}): &mut ${value} {\n &mut self.${key}\n }\n `;\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t.join('')} \n \n public fun register(dapps: &mut Dapps, ctx: &mut TxContext): ${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\tschemaName\n\t\t\t\t\t)} {\n let package_id = dapps_system::current_package_id<DappKey>();\n assert!(dapps.borrow_metadata().contains_key(package_id), 0);\n assert!(dapps.borrow_admin().get(package_id) == ctx.sender(), 0);\n let schema = type_name::get<${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\t\tschemaName\n\t\t\t\t\t\t)}>().into_string();\n assert!(!dapps.borrow_schemas().get(package_id).contains(&schema), 0);\n dapps_system::add_schema<${capitalizeAndRemoveUnderscores(\n\t\t\t\t\t\t\tschemaName\n\t\t\t\t\t\t)}>(dapps, package_id, ctx);\n ${capitalizeAndRemoveUnderscores(schemaName)} {\n id: object::new(ctx),\n ${Object.entries(schema.structure)\n\t\t\t\t\t\t\t\t.map(([key, value]) => {\n\t\t\t\t\t\t\t\t\tlet storage_type = '';\n\t\t\t\t\t\t\t\t\tif (value.includes('StorageValue')) {\n\t\t\t\t\t\t\t\t\t\tstorage_type = `storage_value::new()`;\n\t\t\t\t\t\t\t\t\t} else if (value.includes('StorageMap')) {\n\t\t\t\t\t\t\t\t\t\tstorage_type = `storage_map::new()`;\n\t\t\t\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\t\t\t\tvalue.includes('StorageDoubleMap')\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\tstorage_type = `storage_double_map::new()`;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\treturn `${key}: ${storage_type},`;\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t.join(' ')}\n }\n }\n \n }`;\n\t\tawait formatAndWriteMove(\n\t\t\tschemaMoudle,\n\t\t\t`${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}.move`,\n\t\t\t'formatAndWriteMove'\n\t\t);\n\t}\n\tconsole.log('āœ… Schema Structure Generation Complete\\n');\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\nimport { existsSync } from 'fs';\n\nexport async function generateDeployHook(\n\tconfig: DubheConfig,\n\tsrcPrefix: string\n) {\n\tconsole.log('\\nšŸ“ Starting Deploy Hook Generation...');\n\tconsole.log(\n\t\t` └─ Output path: ${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`\n\t);\n\n\tif (\n\t\t!existsSync(\n\t\t\t`${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`\n\t\t)\n\t) {\n\t\tlet code = `module ${config.name}::deploy_hook {\n use dubhe::dapps_schema::Dapps;\n use dubhe::dapps_system;\n use ${config.name}::dapp_key::DappKey;\n use std::ascii;\n use sui::clock::Clock;\n use sui::transfer::public_share_object;\n #[test_only]\n use dubhe::dapps_schema;\n #[test_only]\n use sui::clock;\n #[test_only]\n use sui::test_scenario;\n #[test_only]\n use sui::test_scenario::Scenario;\n\n public entry fun run(dapps: &mut Dapps, clock: &Clock, ctx: &mut TxContext) {\n // Register the dapp to dubhe.\n dapps_system::register<DappKey>(\n dapps,\n ascii::string(b\"${config.name}\"),\n ascii::string(b\"${config.description}\"),\n clock,\n ctx\n );\n ${Object.keys(config.schemas)\n\t\t\t.map(schemaName => {\n\t\t\t\treturn `let ${schemaName} = ${config.name}::${schemaName}_schema::register(dapps, ctx);`;\n\t\t\t})\n\t\t\t.join('\\n')}\n // Logic that needs to be automated once the contract is deployed\n\n\n // Share the dapp object with the public\n ${Object.keys(config.schemas)\n\t\t\t.map(schemaName => {\n\t\t\t\treturn `public_share_object(${schemaName});`;\n\t\t\t})\n\t\t\t.join('\\n')}\n }\n\n #[test_only]\n public fun deploy_hook_for_testing(): (Scenario, Dapps) {\n let mut scenario = test_scenario::begin(@0xA);\n {\n let ctx = test_scenario::ctx(&mut scenario);\n dapps_schema::init_dapps_for_testing(ctx);\n test_scenario::next_tx(&mut scenario,@0xA);\n };\n let mut dapps = test_scenario::take_shared<Dapps>(&scenario);\n let ctx = test_scenario::ctx(&mut scenario);\n let clock = clock::create_for_testing(ctx);\n run(&mut dapps, &clock, ctx);\n clock::destroy_for_testing(clock);\n test_scenario::next_tx(&mut scenario,@0xA);\n (scenario, dapps)\n }\n}\n`;\n\t\tawait formatAndWriteMove(\n\t\t\tcode,\n\t\t\t`${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`,\n\t\t\t'formatAndWriteMove'\n\t\t);\n\t}\n\tconsole.log('āœ… Deploy Hook Generation Complete\\n');\n}\n\nexport function generateMigrate(config: DubheConfig, srcPrefix: string) {\n\tif (\n\t\t!existsSync(\n\t\t\t`${srcPrefix}/contracts/${config.name}/sources/script/migrate.move`\n\t\t)\n\t) {\n\t\tlet code = `module ${config.name}::migrate {\n use dubhe::world::{World, AdminCap};\n\n /// Not the right admin for this world\n const ENotAdmin: u64 = 0;\n const EWrongVersion: u64 = 1;\n const ENotUpgrade: u64 = 2;\n const VERSION: u64 = 1;\n\n public entry fun run(world: &mut World, admin_cap: &AdminCap) {\n assert!(world.admin() == object::id(admin_cap), ENotAdmin);\n assert!(world.version() < VERSION, ENotUpgrade);\n *dubhe::world::mut_version(world, admin_cap) = VERSION;\n }\n\n public fun assert_version(world: &World){\n assert!(world.version() == VERSION, EWrongVersion);\n }\n}\n`;\n\t\tformatAndWriteMove(\n\t\t\tcode,\n\t\t\t`${srcPrefix}/contracts/${config.name}/sources/script/migrate.move`,\n\t\t\t'formatAndWriteMove'\n\t\t);\n\t}\n}\n","import { DubheConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateDappKey(\n\tconfig: DubheConfig,\n\tsrcPrefix: string\n) {\n\tconsole.log('\\nšŸ”‘ Starting DappKey Generation...');\n\tconsole.log(\n\t\t` └─ Output path: ${srcPrefix}/contracts/${config.name}/sources/codegen/dapp_key.move`\n\t);\n\n\tlet code = `module ${config.name}::dapp_key {\n\\t/// Authorization token for the app.\n\\tpublic struct DappKey has drop {}\n\n\\tpublic(package) fun new(): DappKey {\n\\t\\tDappKey { }\n\\t}\n}\n`;\n\tawait formatAndWriteMove(\n\t\tcode,\n\t\t`${srcPrefix}/contracts/${config.name}/sources/codegen/dapp_key.move`,\n\t\t'formatAndWriteMove'\n\t);\n\tconsole.log('āœ… DappKey Generation Complete\\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 = [\n \"dubhe.config.js\",\n \"dubhe.config.mjs\",\n \"dubhe.config.ts\",\n \"dubhe.config.mts\",\n];\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(\n configPath: string | undefined,\n toFileURL?: boolean\n) {\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\"\n ? pathToFileURL(configPath).href\n : 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","\nexport class NotInsideProjectError extends Error {\nname = \"NotInsideProjectError\";\nmessage = \"You are not inside a Dubhe project\";\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","deployHookPrefix","code","fs","path","debug","formatAndWriteTypescript","formatTypescript","posixPath","path","existsSync","fs","deleteFolderRecursive","path","file","curPath","getStructAttrs","values","key","_","getStructTypes","values","_","type","getStructAttrsWithType","key","getStructAttrsQuery","existsSync","generateSystem","config","srcPrefix","systemName","code","formatAndWriteMove","generateToml","config","srcPrefix","frameworkId","code","formatAndWriteMove","capitalizeAndRemoveUnderscores","input","word","index","renderSetAttrsFunc","schemaName","fields","key","type","renderSetFunc","getStructAttrsWithType","fieldName","renderGetAllFunc","getStructTypes","getStructAttrsQuery","renderGetAttrsFunc","convertToSnakeCase","generateSchemaData","projectName","schemas","path","schema","item","code","enumNames","field","name","getStructAttrs","formatAndWriteMove","generateImport","generateSchemaStructure","schemaMoudle","value","storage_type","existsSync","generateDeployHook","config","srcPrefix","code","schemaName","formatAndWriteMove","generateDappKey","config","srcPrefix","code","formatAndWriteMove","matchFrameworkId","network","schemaGen","config","srcPrefix","frameworkId","path","existsSync","deleteFolderRecursive","generateToml","generateDeployHook","generateSystem","generateSchemaData","generateSchemaStructure","generateDappKey","findUp","path","esbuild","NotInsideProjectError","rmSync","pathToFileURL","os","configFiles","TEMP_CONFIG","loadConfig","configPath","resolveConfigPath","esbuild","toFileURL","getUserConfigPath","path","tsConfigPath","findUp","NotInsideProjectError"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@0xobelisk/sui-common",
3
- "version": "0.5.16",
3
+ "version": "0.5.18",
4
4
  "description": "Common low level logic shared between packages",
5
5
  "keywords": [
6
6
  "sui",
@@ -10,11 +10,11 @@
10
10
  ],
11
11
  "type": "module",
12
12
  "author": "team@obelisk.build",
13
- "homepage": "https://github.com/0xobelisk/obelisk-engine/tree/main/packages/sui-common#readme",
14
- "bugs": "https://github.com/0xobelisk/obelisk-engine/issues",
13
+ "homepage": "https://github.com/0xobelisk/dubhe/tree/main/packages/sui-common#readme",
14
+ "bugs": "https://github.com/0xobelisk/dubhe/issues",
15
15
  "repository": {
16
16
  "type": "git",
17
- "url": "https://github.com/0xobelisk/obelisk-engine.git"
17
+ "url": "https://github.com/0xobelisk/dubhe.git"
18
18
  },
19
19
  "license": "Apache-2.0",
20
20
  "publishConfig": {
@@ -58,6 +58,7 @@
58
58
  "zod-validation-error": "^1.3.0"
59
59
  },
60
60
  "devDependencies": {
61
+ "@types/debug": "^4.1.12",
61
62
  "@types/ejs": "^3.1.1",
62
63
  "@types/glob": "^7.2.0",
63
64
  "@types/node": "^18.15.11",
@@ -56,7 +56,7 @@ export type SchemaType = {
56
56
  structure: Record<string, string>;
57
57
  }
58
58
 
59
- export type ObeliskConfig = {
59
+ export type DubheConfig = {
60
60
  name: string;
61
61
  description: string;
62
62
  systems: string[];
@@ -8,12 +8,12 @@ import os from "os";
8
8
 
9
9
  // In order of preference files are checked
10
10
  const configFiles = [
11
- "obelisk.config.js",
12
- "obelisk.config.mjs",
13
- "obelisk.config.ts",
14
- "obelisk.config.mts",
11
+ "dubhe.config.js",
12
+ "dubhe.config.mjs",
13
+ "dubhe.config.ts",
14
+ "dubhe.config.mts",
15
15
  ];
16
- const TEMP_CONFIG = "obelisk.config.example.mjs";
16
+ const TEMP_CONFIG = "dubhe.config.example.mjs";
17
17
 
18
18
  export async function loadConfig(configPath?: string): Promise<unknown> {
19
19
  configPath = await resolveConfigPath(configPath);
@@ -33,7 +33,7 @@ export async function loadConfig(configPath?: string): Promise<unknown> {
33
33
  // Node.js caches dynamic imports, so without appending a cache breaking
34
34
  // param like `?update={Date.now()}` this import always returns the same config
35
35
  // if called multiple times in a single process, like the `dev-contracts` cli
36
- return (await import(configPath + `?update=${Date.now()}`)).obeliskConfig;
36
+ return (await import(configPath + `?update=${Date.now()}`)).dubheConfig;
37
37
  } finally {
38
38
  rmSync(TEMP_CONFIG, { force: true });
39
39
  }
@@ -1,5 +1,5 @@
1
1
 
2
2
  export class NotInsideProjectError extends Error {
3
3
  name = "NotInsideProjectError";
4
- message = "You are not inside a Obelisk project";
4
+ message = "You are not inside a Dubhe project";
5
5
  }
@@ -45,11 +45,9 @@ function isAddress(str: string): boolean {
45
45
  */
46
46
  // export function getStructTypes(values: SchemaType): string {
47
47
  export function getStructTypes(
48
- values: MoveType | Record<string, MoveType>
48
+ values: Record<string, string>
49
49
  ): string {
50
- return typeof values === 'string'
51
- ? values
52
- : `(${Object.entries(values).map(([_, type]) => `${type}`)})`;
50
+ return `(${Object.entries(values).map(([_, type]) => `${type}`)})`;
53
51
  }
54
52
 
55
53
  /**
@@ -65,14 +63,10 @@ export function getStructAttrsWithType(
65
63
 
66
64
  /**
67
65
  * @param values
68
- * @param prefixArgs
69
66
  * @return [ data.name, data.age ]
70
67
  */
71
68
  export function getStructAttrsQuery(
72
- values: MoveType | Record<string, MoveType>,
73
- prefixArgs: string
69
+ values: Record<string, string>,
74
70
  ): string[] {
75
- return typeof values === 'string'
76
- ? [`${prefixArgs}self.value`]
77
- : Object.entries(values).map(([key, _]) => `${prefixArgs}self.${key}`);
71
+ return Object.entries(values).map(([key, _]) => `self.${key}`);
78
72
  }
@@ -1,8 +1,8 @@
1
- import { ObeliskConfig } from '../../types';
1
+ import { DubheConfig } from '../../types';
2
2
  import { formatAndWriteMove } from '../formatAndWrite';
3
3
 
4
4
  export async function generateDappKey(
5
- config: ObeliskConfig,
5
+ config: DubheConfig,
6
6
  srcPrefix: string
7
7
  ) {
8
8
  console.log('\nšŸ”‘ Starting DappKey Generation...');
@@ -47,10 +47,10 @@ export function renderSetFunc(
47
47
 
48
48
  export function renderGetAllFunc(
49
49
  schemaName: string,
50
- fields: BaseType | Record<string, BaseType>
50
+ fields: Record<string, string>
51
51
  ): string {
52
52
  return `public fun get(self: &${schemaName}): ${getStructTypes(fields)} {
53
- (${getStructAttrsQuery(fields, '')})
53
+ (${getStructAttrsQuery(fields)})
54
54
  }`;
55
55
  }
56
56
 
@@ -200,11 +200,11 @@ export async function generateSchemaStructure(
200
200
  const schemaMoudle = `module ${projectName}::${schemaName}_schema {
201
201
  use std::ascii::String;
202
202
  use std::type_name;
203
- use obelisk::dapps_system;
204
- use obelisk::dapps_schema::Dapps;
205
- use obelisk::storage_value::{Self, StorageValue};
206
- use obelisk::storage_map::{Self, StorageMap};
207
- use obelisk::storage_double_map::{Self, StorageDoubleMap};
203
+ use dubhe::dapps_system;
204
+ use dubhe::dapps_schema::Dapps;
205
+ use dubhe::storage_value::{Self, StorageValue};
206
+ use dubhe::storage_map::{Self, StorageMap};
207
+ use dubhe::storage_double_map::{Self, StorageDoubleMap};
208
208
  use ${projectName}::dapp_key::DappKey;
209
209
  ${generateImport(projectName, schemaName, schema)}
210
210
 
@@ -1,9 +1,9 @@
1
- import { ObeliskConfig } from '../../types';
1
+ import { DubheConfig } from '../../types';
2
2
  import { formatAndWriteMove } from '../formatAndWrite';
3
3
  import { existsSync } from 'fs';
4
4
 
5
5
  export async function generateDeployHook(
6
- config: ObeliskConfig,
6
+ config: DubheConfig,
7
7
  srcPrefix: string
8
8
  ) {
9
9
  console.log('\nšŸ“ Starting Deploy Hook Generation...');
@@ -17,14 +17,14 @@ export async function generateDeployHook(
17
17
  )
18
18
  ) {
19
19
  let code = `module ${config.name}::deploy_hook {
20
- use obelisk::dapps_schema::Dapps;
21
- use obelisk::dapps_system;
20
+ use dubhe::dapps_schema::Dapps;
21
+ use dubhe::dapps_system;
22
22
  use ${config.name}::dapp_key::DappKey;
23
23
  use std::ascii;
24
24
  use sui::clock::Clock;
25
25
  use sui::transfer::public_share_object;
26
26
  #[test_only]
27
- use obelisk::dapps_schema;
27
+ use dubhe::dapps_schema;
28
28
  #[test_only]
29
29
  use sui::clock;
30
30
  #[test_only]
@@ -33,7 +33,7 @@ export async function generateDeployHook(
33
33
  use sui::test_scenario::Scenario;
34
34
 
35
35
  public entry fun run(dapps: &mut Dapps, clock: &Clock, ctx: &mut TxContext) {
36
- // Register the dapp to obelisk.
36
+ // Register the dapp to dubhe.
37
37
  dapps_system::register<DappKey>(
38
38
  dapps,
39
39
  ascii::string(b"${config.name}"),
@@ -84,14 +84,14 @@ export async function generateDeployHook(
84
84
  console.log('āœ… Deploy Hook Generation Complete\n');
85
85
  }
86
86
 
87
- export function generateMigrate(config: ObeliskConfig, srcPrefix: string) {
87
+ export function generateMigrate(config: DubheConfig, srcPrefix: string) {
88
88
  if (
89
89
  !existsSync(
90
90
  `${srcPrefix}/contracts/${config.name}/sources/script/migrate.move`
91
91
  )
92
92
  ) {
93
93
  let code = `module ${config.name}::migrate {
94
- use obelisk::world::{World, AdminCap};
94
+ use dubhe::world::{World, AdminCap};
95
95
 
96
96
  /// Not the right admin for this world
97
97
  const ENotAdmin: u64 = 0;
@@ -102,7 +102,7 @@ export function generateMigrate(config: ObeliskConfig, srcPrefix: string) {
102
102
  public entry fun run(world: &mut World, admin_cap: &AdminCap) {
103
103
  assert!(world.admin() == object::id(admin_cap), ENotAdmin);
104
104
  assert!(world.version() < VERSION, ENotUpgrade);
105
- *obelisk::world::mut_version(world, admin_cap) = VERSION;
105
+ *dubhe::world::mut_version(world, admin_cap) = VERSION;
106
106
  }
107
107
 
108
108
  public fun assert_version(world: &World){
@@ -1,8 +1,8 @@
1
- import { ObeliskConfig } from '../../types';
1
+ import { DubheConfig } from '../../types';
2
2
  import { formatAndWriteMove } from '../formatAndWrite';
3
3
  import { existsSync } from 'fs';
4
4
 
5
- export async function generateSystem(config: ObeliskConfig, srcPrefix: string) {
5
+ export async function generateSystem(config: DubheConfig, srcPrefix: string) {
6
6
  console.log('\nāš™ļø Starting System Generation...');
7
7
  config.systems.map(async systemName => {
8
8
  console.log(` ā”œā”€ Generating system: ${systemName}`);
@@ -1,8 +1,8 @@
1
- import { ObeliskConfig } from '../../types';
1
+ import { DubheConfig } from '../../types';
2
2
  import { formatAndWriteMove } from '../formatAndWrite';
3
3
 
4
4
  export async function generateToml(
5
- config: ObeliskConfig,
5
+ config: DubheConfig,
6
6
  srcPrefix: string,
7
7
  frameworkId: string
8
8
  ) {
@@ -17,12 +17,12 @@ version = "0.0.1"
17
17
  edition = "2024.beta"
18
18
 
19
19
  [dependencies]
20
- Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "mainnet-v1.31.1" }
21
- Obelisk = { git = "https://github.com/0xobelisk/obelisk-engine.git", subdir = "packages/obelisk-framework", rev = "main" }
20
+ Sui = { git = "https://github.com/MystenLabs/sui.git", subdir = "crates/sui-framework/packages/sui-framework", rev = "mainnet-v1.36.2" }
21
+ Dubhe = { git = "https://github.com/0xobelisk/dubhe.git", subdir = "packages/dubhe-framework", rev = "main" }
22
22
 
23
23
  [addresses]
24
24
  sui = "0x2"
25
- obelisk = "${frameworkId}"
25
+ dubhe = "${frameworkId}"
26
26
  ${config.name} = "0x0"
27
27
  `;
28
28
  await formatAndWriteMove(
@@ -1,4 +1,4 @@
1
- import { SchemaType, ObeliskConfig } from '../../types';
1
+ import { SchemaType, DubheConfig } from '../../types';
2
2
  import { rmdirSync, existsSync } from 'fs';
3
3
  import { deleteFolderRecursive } from './common';
4
4
  import { generateSystem } from './generateSystem';
@@ -12,16 +12,16 @@ function matchFrameworkId(
12
12
  ): string {
13
13
  switch (network) {
14
14
  case 'testnet':
15
- return '0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256';
15
+ return '0x1736475f476c5dec96f33c03c778843f572239d3a887d795eef66d2836484c28';
16
16
  case 'localnet':
17
- return '0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256';
17
+ return '0x1736475f476c5dec96f33c03c778843f572239d3a887d795eef66d2836484c28';
18
18
  default:
19
- return '0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256';
19
+ return '0x1736475f476c5dec96f33c03c778843f572239d3a887d795eef66d2836484c28';
20
20
  }
21
21
  }
22
22
 
23
23
  export async function schemaGen(
24
- config: ObeliskConfig,
24
+ config: DubheConfig,
25
25
  srcPrefix?: string,
26
26
  network?: 'mainnet' | 'testnet' | 'devnet' | 'localnet',
27
27
  frameworkId?: string
package/src/debug.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  import createDebug from "debug";
2
2
 
3
- export const debug = createDebug("obelisk:common");
4
- export const error = createDebug("obelisk:common");
3
+ export const debug = createDebug("dubhe:common");
4
+ export const error = createDebug("dubhe:common");
5
5
 
6
6
  // Pipe debug output to stdout instead of stderr
7
7
  debug.log = console.debug.bind(console);