@0xobelisk/sui-common 0.5.14 → 0.5.15

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,12 +1,15 @@
1
- import y from"prettier";import I from"prettier-plugin-move-js";async function S(e,t){let r;t&&(r=await y.resolveConfig(t));try{return y.format(e,{plugins:[I],parser:"move-parse",printWidth:120,semi:!0,tabWidth:2,useTabs:!1,bracketSpacing:!0,...r})}catch(o){let i;return o instanceof Error?i=o.message:i=o,console.log(`Error during output formatting: ${i}`),e}}async function h(e){return y.format(e,{parser:"typescript"})}import $ from"node:fs/promises";import A from"node:path";import v from"debug";var f=v("obelisk:common"),U=v("obelisk:common");f.log=console.debug.bind(console);U.log=console.error.bind(console);var g=f.extend("codegen"),B=f.extend("codegen");g.log=console.debug.bind(console);B.log=console.error.bind(console);async function a(e,t,r){let o=await S(e),s=` // Copyright (c) Obelisk Labs, Inc.
1
+ import y from"prettier";import I from"prettier-plugin-move-js";async function h(e,t){let r;t&&(r=await y.resolveConfig(t));try{return y.format(e,{plugins:[I],parser:"move-parse",printWidth:120,semi:!0,tabWidth:2,useTabs:!1,bracketSpacing:!0,...r})}catch(o){let n;return o instanceof Error?n=o.message:n=o,console.log(`Error during output formatting: ${n}`),e}}async function S(e){return y.format(e,{parser:"typescript"})}import $ from"node:fs/promises";import A from"node:path";import v from"debug";var f=v("obelisk:common"),U=v("obelisk:common");f.log=console.debug.bind(console);U.log=console.error.bind(console);var g=f.extend("codegen"),B=f.extend("codegen");g.log=console.debug.bind(console);B.log=console.error.bind(console);async function c(e,t,r){let o=await h(e),n=` // 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
- `+o;(t.includes("deploy_hook")||t.includes(".toml")||t.includes("system"))&&(s=o),await $.mkdir(A.dirname(t),{recursive:!0}),await $.writeFile(t,s),g(`${r}: ${t}`)}async function ue(e,t,r){let o=await h(e);await $.mkdir(A.dirname(t),{recursive:!0}),await $.writeFile(t,o),g(`${r}: ${t}`)}function le(e){return e.replace(/\\/g,"/")}import{existsSync as k}from"fs";import d from"fs";function _(e){d.existsSync(e)&&(d.readdirSync(e).forEach(t=>{let r=`${e}/${t}`;d.lstatSync(r).isDirectory()?_(r):d.unlinkSync(r)}),d.rmdirSync(e))}function T(e){return Object.entries(e).map(([t,r])=>`${t}`).join(",")}function M(e){return typeof e=="string"?e:`(${Object.entries(e).map(([t,r])=>`${r}`)})`}function l(e){return Object.entries(e).map(([t,r])=>`${t}: ${r}`)}function C(e,t){return typeof e=="string"?[`${t}self.value`]:Object.entries(e).map(([r,o])=>`${t}self.${r}`)}import{existsSync as K}from"fs";async function D(e,t){e.systems.map(async r=>{if(!K(`${t}/contracts/${e.name}/sources/system/${r}.move`)){let o=`module ${e.name}::${r}_system {
6
+
7
+ `,s=`#[allow(lint(share_owned))]
8
+
9
+ `,i=n+o;t.includes(".toml")||t.includes("system")?i=o:t.includes("deploy_hook")&&(i=s+o),await $.mkdir(A.dirname(t),{recursive:!0}),await $.writeFile(t,i),g(`${r}: ${t}`)}async function ue(e,t,r){let o=await S(e);await $.mkdir(A.dirname(t),{recursive:!0}),await $.writeFile(t,o),g(`${r}: ${t}`)}function de(e){return e.replace(/\\/g,"/")}import{existsSync as k}from"fs";import l from"fs";function _(e){l.existsSync(e)&&(l.readdirSync(e).forEach(t=>{let r=`${e}/${t}`;l.lstatSync(r).isDirectory()?_(r):l.unlinkSync(r)}),l.rmdirSync(e))}function T(e){return Object.entries(e).map(([t,r])=>`${t}`).join(",")}function M(e){return typeof e=="string"?e:`(${Object.entries(e).map(([t,r])=>`${r}`)})`}function d(e){return Object.entries(e).map(([t,r])=>`${t}: ${r}`)}function C(e,t){return typeof e=="string"?[`${t}self.value`]:Object.entries(e).map(([r,o])=>`${t}self.${r}`)}import{existsSync as K}from"fs";async function j(e,t){e.systems.map(async r=>{if(!K(`${t}/contracts/${e.name}/sources/system/${r}.move`)){let o=`module ${e.name}::${r}_system {
7
10
 
8
11
  }
9
- `;await a(o,`${t}/contracts/${e.name}/sources/system/${r}.move`,"formatAndWriteMove")}})}async function j(e,t){let r=`[package]
12
+ `;await c(o,`${t}/contracts/${e.name}/sources/system/${r}.move`,"formatAndWriteMove")}})}async function D(e,t){let r=`[package]
10
13
  name = "${e.name}"
11
14
  version = "0.0.1"
12
15
  edition = "2024.beta"
@@ -19,91 +22,89 @@ Obelisk = { git = "https://github.com/0xobelisk/obelisk-engine.git", subdir = "p
19
22
  sui = "0x2"
20
23
  obelisk = "0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256"
21
24
  ${e.name} = "0x0"
22
- `;await a(r,`${t}/contracts/${e.name}/Move.toml`,"formatAndWriteMove")}function m(e){return e.split("_").map((t,r)=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function L(e,t){return Object.entries(t).map(([r,o])=>`public(package) fun set_${r}(self: &mut ${e}, ${r}: ${o}) {
25
+ `;await c(r,`${t}/contracts/${e.name}/Move.toml`,"formatAndWriteMove")}function m(e){return e.split("_").map((t,r)=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function L(e,t){return Object.entries(t).map(([r,o])=>`public(package) fun set_${r}(self: &mut ${e}, ${r}: ${o}) {
23
26
  self.${r} = ${r};
24
27
  }`).join(`
25
- `)}function V(e,t){return`public(package) fun set(self: &mut ${e}, ${l(t)}) {
28
+ `)}function V(e,t){return`public(package) fun set(self: &mut ${e}, ${d(t)}) {
26
29
  ${Object.entries(t).map(([r])=>`self.${r} = ${r};`).join(`
27
30
  `)}
28
- }`}function N(e,t){return`public fun get(self: &${e}): ${M(t)} {
31
+ }`}function z(e,t){return`public fun get(self: &${e}): ${M(t)} {
29
32
  (${C(t,"")})
30
- }`}function z(e,t){return Object.entries(t).map(([r,o])=>`public fun get_${r}(self: &${e}): ${o} {
33
+ }`}function N(e,t){return Object.entries(t).map(([r,o])=>`public fun get_${r}(self: &${e}): ${o} {
31
34
  self.${r}
32
35
  }`).join(`
33
- `)}function u(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}async function O(e,t,r){for(let o in t){let i=t[o];if(i.data)for(let s of i.data){let c="",p=i.data.filter(n=>Array.isArray(n.fields)).map(n=>n.name);Array.isArray(s.fields)?c=`module ${e}::${o}_${u(s.name)} {
36
+ `)}function u(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}async function O(e,t,r){for(let o in t){let n=t[o];if(n.data)for(let s of n.data){let i="",p=n.data.filter(a=>Array.isArray(a.fields)).map(a=>a.name);Array.isArray(s.fields)?i=`module ${e}::${o}_${u(s.name)} {
34
37
  public enum ${s.name} has copy, drop , store {
35
38
  ${s.fields}
36
39
  }
37
40
 
38
- ${s.fields.map(n=>`public fun new_${u(n)}(): ${s.name} {
39
- ${s.name}::${n}
40
- }`).join("")}`:c=`module ${e}::${o}_${u(s.name)} {
41
+ ${s.fields.map(a=>`public fun new_${u(a)}(): ${s.name} {
42
+ ${s.name}::${a}
43
+ }`).join("")}`:i=`module ${e}::${o}_${u(s.name)} {
41
44
  use std::ascii::String;
42
- ${p.map(n=>`use ${e}::${o}_${u(n)}::${n};`).join(`
45
+ ${p.map(a=>`use ${e}::${o}_${u(a)}::${a};`).join(`
43
46
  `)}
44
47
 
45
48
  public struct ${s.name} has copy, drop , store {
46
- ${l(s.fields)}
49
+ ${d(s.fields)}
47
50
  }
48
51
 
49
- public fun new(${l(s.fields)}): ${s.name} {
52
+ public fun new(${d(s.fields)}): ${s.name} {
50
53
  ${s.name} {
51
54
  ${T(s.fields)}
52
55
  }
53
56
  }
54
57
 
55
- ${N(s.name,s.fields)}
56
58
  ${z(s.name,s.fields)}
59
+ ${N(s.name,s.fields)}
57
60
  ${L(s.name,s.fields)}
58
61
  ${V(s.name,s.fields)}
59
- }`,await a(c,`${r}/contracts/${e}/sources/codegen/schemas/${o}_${u(s.name)}.move`,"formatAndWriteMove")}}}function G(e,t,r){return r.data?r.data.map(o=>`use ${e}::${t}_${u(o.name)}::${o.name};`).join(`
60
- `):""}async function W(e,t,r){for(let o in t){console.log(`Schema: ${o}`);let i=t[o],s=`module ${e}::${o}_schema {
62
+ }`,await c(i,`${r}/contracts/${e}/sources/codegen/schemas/${o}_${u(s.name)}.move`,"formatAndWriteMove")}}}function G(e,t,r){return r.data?r.data.map(o=>`use ${e}::${t}_${u(o.name)}::${o.name};`).join(`
63
+ `):""}async function W(e,t,r){for(let o in t){console.log(`Schema: ${o}`);let n=t[o],s=`module ${e}::${o}_schema {
61
64
  use std::ascii::String;
62
65
  use std::type_name;
63
- use sui::transfer::{public_share_object};
64
66
  use obelisk::dapps_system;
65
67
  use obelisk::dapps_schema::Dapps;
66
68
  use obelisk::storage_value::{Self, StorageValue};
67
69
  use obelisk::storage_map::{Self, StorageMap};
68
70
  use obelisk::storage_double_map::{Self, StorageDoubleMap};
69
71
  use ${e}::dapp_key::DappKey;
70
- ${G(e,o,i)}
72
+ ${G(e,o,n)}
71
73
 
72
74
  public struct ${m(o)} has key, store {
73
75
  id: UID,
74
- ${l(i.structure)}
76
+ ${d(n.structure)}
75
77
  }
76
78
 
77
- ${Object.entries(i.structure).map(([c,p])=>`public fun borrow_${c}(self: &${m(o)}) : &${p} {
78
- &self.${c}
79
+ ${Object.entries(n.structure).map(([i,p])=>`public fun borrow_${i}(self: &${m(o)}) : &${p} {
80
+ &self.${i}
79
81
  }
80
82
 
81
- public(package) fun borrow_mut_${c}(self: &mut ${m(o)}): &mut ${p} {
82
- &mut self.${c}
83
+ public(package) fun borrow_mut_${i}(self: &mut ${m(o)}): &mut ${p} {
84
+ &mut self.${i}
83
85
  }
84
86
  `).join("")}
85
87
 
86
- public entry fun register(dapps: &mut Dapps, ctx: &mut TxContext) {
88
+ public fun register(dapps: &mut Dapps, ctx: &mut TxContext): ${m(o)} {
87
89
  let package_id = dapps_system::current_package_id<DappKey>();
88
90
  assert!(dapps.borrow_metadata().contains_key(package_id), 0);
89
91
  assert!(dapps.borrow_admin().get(package_id) == ctx.sender(), 0);
90
92
  let schema = type_name::get<${m(o)}>().into_string();
91
93
  assert!(!dapps.borrow_schemas().get(package_id).contains(&schema), 0);
92
-
93
- public_share_object(${m(o)} {
94
- id: object::new(ctx),
95
- ${Object.entries(i.structure).map(([c,p])=>{let n="";return p.includes("StorageValue")?n="storage_value::new()":p.includes("StorageMap")?n="storage_map::new()":p.includes("StorageDoubleMap")&&(n="storage_double_map::new()"),`${c}: ${n},`}).join(" ")}
96
- });
97
-
98
94
  dapps_system::add_schema<${m(o)}>(dapps, package_id, ctx);
95
+ ${m(o)} {
96
+ id: object::new(ctx),
97
+ ${Object.entries(n.structure).map(([i,p])=>{let a="";return p.includes("StorageValue")?a="storage_value::new()":p.includes("StorageMap")?a="storage_map::new()":p.includes("StorageDoubleMap")&&(a="storage_double_map::new()"),`${i}: ${a},`}).join(" ")}
98
+ }
99
99
  }
100
100
 
101
- }`;await a(s,`${r}/contracts/${e}/sources/codegen/schemas/${o}.move`,"formatAndWriteMove")}}import{existsSync as H}from"fs";async function R(e,t){if(!H(`${t}/contracts/${e.name}/sources/script/deploy_hook.move`)){let r=`module ${e.name}::deploy_hook {
101
+ }`;await c(s,`${r}/contracts/${e}/sources/codegen/schemas/${o}.move`,"formatAndWriteMove")}}import{existsSync as H}from"fs";async function R(e,t){if(!H(`${t}/contracts/${e.name}/sources/script/deploy_hook.move`)){let r=`module ${e.name}::deploy_hook {
102
102
  use obelisk::dapps_schema::Dapps;
103
103
  use obelisk::dapps_system;
104
104
  use ${e.name}::dapp_key::DappKey;
105
105
  use std::ascii;
106
106
  use sui::clock::Clock;
107
+ use sui::transfer::public_share_object;
107
108
  #[test_only]
108
109
  use obelisk::dapps_schema;
109
110
  #[test_only]
@@ -122,11 +123,14 @@ ${e.name} = "0x0"
122
123
  clock,
123
124
  ctx
124
125
  );
125
- ${Object.keys(e.schemas).map(o=>`${e.name}::${o}_schema::register(dapps, ctx);`).join(`
126
+ ${Object.keys(e.schemas).map(o=>`let ${o} = ${e.name}::${o}_schema::register(dapps, ctx);`).join(`
126
127
  `)}
127
-
128
128
  // Logic that needs to be automated once the contract is deployed
129
129
 
130
+
131
+ // Share the dapp object with the public
132
+ ${Object.keys(e.schemas).map(o=>`public_share_object(${o});`).join(`
133
+ `)}
130
134
  }
131
135
 
132
136
  #[test_only]
@@ -146,7 +150,7 @@ ${e.name} = "0x0"
146
150
  (scenario, dapps)
147
151
  }
148
152
  }
149
- `;await a(r,`${t}/contracts/${e.name}/sources/script/deploy_hook.move`,"formatAndWriteMove")}}async function E(e,t){let r=`module ${e.name}::dapp_key {
153
+ `;await c(r,`${t}/contracts/${e.name}/sources/script/deploy_hook.move`,"formatAndWriteMove")}}async function E(e,t){let r=`module ${e.name}::dapp_key {
150
154
  /// Authorization token for the app.
151
155
  public struct DappKey has drop {}
152
156
 
@@ -154,5 +158,5 @@ ${e.name} = "0x0"
154
158
  DappKey { }
155
159
  }
156
160
  }
157
- `;await a(r,`${t}/contracts/${e.name}/sources/codegen/dapp_key.move`,"formatAndWriteMove")}async function Be(e,t){let r="";t===void 0?r=process.cwd():r=t,k(`${r}/contracts/${e.name}`)&&_(`${r}/contracts/${e.name}/sources/codegen`),k(`${r}/contracts/${e.name}/Move.toml`)||await j(e,r),k(`${r}/contracts/${e.name}/sources/script/deploy_hook.move`)||await R(e,r),await D(e,r),await O(e.name,e.schemas,r),await W(e.name,e.schemas,r),await E(e,r)}import{findUp as Q}from"find-up";import x from"path";import X from"esbuild";var b=class extends Error{name="NotInsideProjectError";message="You are not inside a Obelisk project"};import{rmSync as Y}from"fs";import{pathToFileURL as Z}from"url";import q from"os";var J=["obelisk.config.js","obelisk.config.mjs","obelisk.config.ts","obelisk.config.mts"],w="obelisk.config.example.mjs";async function Ye(e){e=await F(e);try{return await X.build({entryPoints:[e],format:"esm",outfile:w,platform:"node",bundle:!0,packages:"external"}),e=await F(w,!0),(await import(e+`?update=${Date.now()}`)).obeliskConfig}finally{Y(w,{force:!0})}}async function F(e,t){return e===void 0?e=await P():x.isAbsolute(e)||(e=x.join(process.cwd(),e),e=x.normalize(e)),t&&q.platform()==="win32"?Z(e).href:e}async function P(){let e=await Q(J);if(e===void 0)throw new b;return e}export{a as formatAndWriteMove,ue as formatAndWriteTypescript,S as formatMove,h as formatTypescript,Ye as loadConfig,le as posixPath,F as resolveConfigPath,Be as worldgen};
161
+ `;await c(r,`${t}/contracts/${e.name}/sources/codegen/dapp_key.move`,"formatAndWriteMove")}async function Be(e,t){let r="";t===void 0?r=process.cwd():r=t,k(`${r}/contracts/${e.name}`)&&_(`${r}/contracts/${e.name}/sources/codegen`),k(`${r}/contracts/${e.name}/Move.toml`)||await D(e,r),k(`${r}/contracts/${e.name}/sources/script/deploy_hook.move`)||await R(e,r),await j(e,r),await O(e.name,e.schemas,r),await W(e.name,e.schemas,r),await E(e,r)}import{findUp as Q}from"find-up";import x from"path";import X from"esbuild";var b=class extends Error{name="NotInsideProjectError";message="You are not inside a Obelisk project"};import{rmSync as Y}from"fs";import{pathToFileURL as Z}from"url";import q from"os";var J=["obelisk.config.js","obelisk.config.mjs","obelisk.config.ts","obelisk.config.mts"],w="obelisk.config.example.mjs";async function Ye(e){e=await F(e);try{return await X.build({entryPoints:[e],format:"esm",outfile:w,platform:"node",bundle:!0,packages:"external"}),e=await F(w,!0),(await import(e+`?update=${Date.now()}`)).obeliskConfig}finally{Y(w,{force:!0})}}async function F(e,t){return e===void 0?e=await P():x.isAbsolute(e)||(e=x.join(process.cwd(),e),e=x.normalize(e)),t&&q.platform()==="win32"?Z(e).href:e}async function P(){let e=await Q(J);if(e===void 0)throw new b;return e}export{c as formatAndWriteMove,ue as formatAndWriteTypescript,h as formatMove,S as formatTypescript,Ye as loadConfig,de as posixPath,F as resolveConfigPath,Be as worldgen};
158
162
  //# 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/worldgen.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 prefix =\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 let code = prefix + formattedOutput\n\n if (fullOutputPath.includes(\"deploy_hook\") || fullOutputPath.includes(\".toml\") || fullOutputPath.includes(\"system\")) {\n code = 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\nexport async function worldgen(config: ObeliskConfig, srcPrefix?: string) {\n let path = \"\";\n if (srcPrefix === undefined) {\n path = process.cwd();\n } else {\n path = srcPrefix;\n }\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 await generateSystem(config, path);\n await generateSchemaData(config.name, config.schemas, path);\n await generateSchemaStructure(config.name, config.schemas, path);\n await generateDappKey(config, path);\n}\n","import { BaseType, SchemaType, BaseValueType, 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(\n values: Record<string, string> | string,\n): string {\n return Object.entries(values).map(([key, _]) => `${key}`).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(\n values: MoveType | Record<string, MoveType>\n): string {\n return typeof values === \"string\"\n ? values\n : `(${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 values: Record<string, string>\n): string[] {\n return 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 values: MoveType | Record<string, MoveType>,\n prefixArgs: string\n): string[] {\n return typeof values === \"string\"\n ? [`${prefixArgs}self.value`]\n : Object.entries(values).map(\n ([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 config.systems.map(async (systemName) => {\n if (\n !existsSync(\n `${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`\n )\n ) {\n let code = `module ${config.name}::${systemName}_system {\n\n}\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`,\n \"formatAndWriteMove\"\n );\n }\n });\n}\n","import { ObeliskConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateToml(config: ObeliskConfig, srcPrefix: string) {\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 = \"0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256\"\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}\n","import {\n BaseType, SchemaType,\n} from \"../../types\";\nimport { formatAndWriteMove } from \"../formatAndWrite\";\nimport {\n getStructAttrsWithType,\n getStructAttrs,\n getStructTypes, getStructAttrsQuery,\n} from \"./common\";\n\nfunction 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 ).join(\"\\n\");\n}\n\nexport function renderSetFunc(\n schemaName: string,\n fields: Record<string, string>\n): 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(\n schemaName: string,\n fields: BaseType | Record<string, BaseType>\n): 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 ).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(projectName: string, schemas: Record<string, SchemaType>, path: string) {\n for (const schemaName in schemas) {\n const schema = schemas[schemaName];\n if (schema.data) {\n for (const item of schema.data) {\n let code = \"\";\n\n const enumNames = schema.data\n .filter(item => Array.isArray(item.fields))\n .map(item => item.name);\n\n if (Array.isArray(item.fields)) {\n code = `module ${projectName}::${schemaName}_${convertToSnakeCase(item.name)} {\n public enum ${item.name} has copy, drop , store {\n ${item.fields}\n }\n \n ${item.fields.map((field: string) => {\n return `public fun new_${convertToSnakeCase(field)}(): ${item.name} {\n ${item.name}::${field}\n }`\n }).join(\"\")\n }`\n } else {\n code = `module ${projectName}::${schemaName}_${convertToSnakeCase(item.name)} {\n use std::ascii::String;\n ${enumNames.map(name => `use ${projectName}::${schemaName}_${convertToSnakeCase(name)}::${name};`).join('\\n')}\n\n public struct ${item.name} has copy, drop , store {\n ${getStructAttrsWithType(item.fields)}\n }\n \n public fun new(${getStructAttrsWithType(item.fields)}): ${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 }\n\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}_${convertToSnakeCase(item.name)}.move`,\n \"formatAndWriteMove\"\n );\n }\n }\n }\n}\n\nfunction generateImport(projectName: string, schemaName: string, schema: SchemaType) {\n if (schema.data) {\n return schema.data.map(item => {\n return `use ${projectName}::${schemaName}_${convertToSnakeCase(item.name)}::${item.name};`\n }).join('\\n');\n } else {\n return \"\"\n }\n}\n\nexport async function generateSchemaStructure(projectName: string, schemas: Record<string, SchemaType>, path: string) {\n for (const schemaName in schemas) {\n console.log(`Schema: ${schemaName}`);\n const schema = schemas[schemaName];\n const schemaMoudle = `module ${projectName}::${schemaName}_schema {\n use std::ascii::String;\n use std::type_name;\n use sui::transfer::{public_share_object};\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(schemaName)} has key, store {\n id: UID,\n ${getStructAttrsWithType(schema.structure)}\n } \n \n ${Object.entries(schema.structure).map(([key, value]) => {\n return `public fun borrow_${key}(self: &${capitalizeAndRemoveUnderscores(schemaName)}) : &${value} {\n &self.${key}\n }\n \n public(package) fun borrow_mut_${key}(self: &mut ${capitalizeAndRemoveUnderscores(schemaName)}): &mut ${value} {\n &mut self.${key}\n }\n `\n }).join('')} \n \n public entry fun register(dapps: &mut Dapps, ctx: &mut TxContext) {\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(schemaName)}>().into_string();\n assert!(!dapps.borrow_schemas().get(package_id).contains(&schema), 0);\n \n public_share_object(${capitalizeAndRemoveUnderscores(schemaName)} {\n id: object::new(ctx),\n ${Object.entries(schema.structure).map(([key, value]) => {\n let storage_type = \"\"\n if (value.includes(\"StorageValue\")) {\n storage_type = `storage_value::new()`\n } else if (value.includes(\"StorageMap\")) {\n storage_type = `storage_map::new()`\n } else if (value.includes(\"StorageDoubleMap\")) {\n storage_type = `storage_double_map::new()`\n }\n return `${key}: ${storage_type},`\n }).join(' ')\n }\n });\n \n dapps_system::add_schema<${capitalizeAndRemoveUnderscores(schemaName)}>(dapps, package_id, ctx);\n }\n \n }`;\n await formatAndWriteMove(\n schemaMoudle,\n `${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}.move`,\n \"formatAndWriteMove\"\n );\n }\n}","import { ObeliskConfig } from \"../../types\";\nimport { formatAndWriteMove } from \"../formatAndWrite\";\nimport { existsSync } from \"fs\";\n\nexport async function generateDeployHook(config: ObeliskConfig, srcPrefix: string) {\n if (\n !existsSync(\n `${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`\n )\n ) {\n let 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 #[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).map(schemaName => {\n return `${config.name}::${schemaName}_schema::register(dapps, ctx);`\n }).join(\"\\n\")}\n \n // Logic that needs to be automated once the contract is deployed\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 await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`,\n \"formatAndWriteMove\"\n );\n }\n}\n\nexport function generateMigrate(config: ObeliskConfig, srcPrefix: string) {\n if (\n !existsSync(\n `${srcPrefix}/contracts/${config.name}/sources/script/migrate.move`\n )\n ) {\n let 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 formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/script/migrate.move`,\n \"formatAndWriteMove\"\n );\n }\n}\n\n","import { ObeliskConfig } from \"../../types\";\nimport { formatAndWriteMove } from \"../formatAndWrite\";\n\nexport async function generateDappKey(config: ObeliskConfig, srcPrefix: string) {\n let code = `module ${config.name}::dapp_key {\n /// Authorization token for the app.\n public struct DappKey has drop {}\n\n public(package) fun new(): DappKey {\n DappKey { }\n }\n}\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/codegen/dapp_key.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 = [\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","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","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","worldgen","config","srcPrefix","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/worldgen.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\nexport async function worldgen(config: ObeliskConfig, srcPrefix?: string) {\n let path = \"\";\n if (srcPrefix === undefined) {\n path = process.cwd();\n } else {\n path = srcPrefix;\n }\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 await generateSystem(config, path);\n await generateSchemaData(config.name, config.schemas, path);\n await generateSchemaStructure(config.name, config.schemas, path);\n await generateDappKey(config, path);\n}\n","import { BaseType, SchemaType, BaseValueType, 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(\n values: Record<string, string> | string,\n): string {\n return Object.entries(values).map(([key, _]) => `${key}`).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(\n values: MoveType | Record<string, MoveType>\n): string {\n return typeof values === \"string\"\n ? values\n : `(${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 values: Record<string, string>\n): string[] {\n return 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 values: MoveType | Record<string, MoveType>,\n prefixArgs: string\n): string[] {\n return typeof values === \"string\"\n ? [`${prefixArgs}self.value`]\n : Object.entries(values).map(\n ([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 config.systems.map(async (systemName) => {\n if (\n !existsSync(\n `${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`\n )\n ) {\n let code = `module ${config.name}::${systemName}_system {\n\n}\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/system/${systemName}.move`,\n \"formatAndWriteMove\"\n );\n }\n });\n}\n","import { ObeliskConfig } from '../../types';\nimport { formatAndWriteMove } from '../formatAndWrite';\n\nexport async function generateToml(config: ObeliskConfig, srcPrefix: string) {\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 = \"0x3dc2d6239eed38c9798444afbf4bada0998ec98edc365713864405fe64203256\"\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}\n","import {\n BaseType, SchemaType,\n} from \"../../types\";\nimport { formatAndWriteMove } from \"../formatAndWrite\";\nimport {\n getStructAttrsWithType,\n getStructAttrs,\n getStructTypes, getStructAttrsQuery,\n} from \"./common\";\n\nfunction 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 ).join(\"\\n\");\n}\n\nexport function renderSetFunc(\n schemaName: string,\n fields: Record<string, string>\n): 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(\n schemaName: string,\n fields: BaseType | Record<string, BaseType>\n): 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 ).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(projectName: string, schemas: Record<string, SchemaType>, path: string) {\n for (const schemaName in schemas) {\n const schema = schemas[schemaName];\n if (schema.data) {\n for (const item of schema.data) {\n let code = \"\";\n\n const enumNames = schema.data\n .filter(item => Array.isArray(item.fields))\n .map(item => item.name);\n\n if (Array.isArray(item.fields)) {\n code = `module ${projectName}::${schemaName}_${convertToSnakeCase(item.name)} {\n public enum ${item.name} has copy, drop , store {\n ${item.fields}\n }\n \n ${item.fields.map((field: string) => {\n return `public fun new_${convertToSnakeCase(field)}(): ${item.name} {\n ${item.name}::${field}\n }`\n }).join(\"\")\n }`\n } else {\n code = `module ${projectName}::${schemaName}_${convertToSnakeCase(item.name)} {\n use std::ascii::String;\n ${enumNames.map(name => `use ${projectName}::${schemaName}_${convertToSnakeCase(name)}::${name};`).join('\\n')}\n\n public struct ${item.name} has copy, drop , store {\n ${getStructAttrsWithType(item.fields)}\n }\n \n public fun new(${getStructAttrsWithType(item.fields)}): ${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 }\n\n await formatAndWriteMove(\n code,\n `${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}_${convertToSnakeCase(item.name)}.move`,\n \"formatAndWriteMove\"\n );\n }\n }\n }\n}\n\nfunction generateImport(projectName: string, schemaName: string, schema: SchemaType) {\n if (schema.data) {\n return schema.data.map(item => {\n return `use ${projectName}::${schemaName}_${convertToSnakeCase(item.name)}::${item.name};`\n }).join('\\n');\n } else {\n return \"\"\n }\n}\n\nexport async function generateSchemaStructure(projectName: string, schemas: Record<string, SchemaType>, path: string) {\n for (const schemaName in schemas) {\n console.log(`Schema: ${schemaName}`);\n const schema = schemas[schemaName];\n const 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(schemaName)} has key, store {\n id: UID,\n ${getStructAttrsWithType(schema.structure)}\n } \n \n ${Object.entries(schema.structure).map(([key, value]) => {\n return `public fun borrow_${key}(self: &${capitalizeAndRemoveUnderscores(schemaName)}) : &${value} {\n &self.${key}\n }\n \n public(package) fun borrow_mut_${key}(self: &mut ${capitalizeAndRemoveUnderscores(schemaName)}): &mut ${value} {\n &mut self.${key}\n }\n `\n }).join('')} \n \n public fun register(dapps: &mut Dapps, ctx: &mut TxContext): ${capitalizeAndRemoveUnderscores(schemaName)} {\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(schemaName)}>().into_string();\n assert!(!dapps.borrow_schemas().get(package_id).contains(&schema), 0);\n dapps_system::add_schema<${capitalizeAndRemoveUnderscores(schemaName)}>(dapps, package_id, ctx);\n ${capitalizeAndRemoveUnderscores(schemaName)} {\n id: object::new(ctx),\n ${Object.entries(schema.structure).map(([key, value]) => {\n let storage_type = \"\"\n if (value.includes(\"StorageValue\")) {\n storage_type = `storage_value::new()`\n } else if (value.includes(\"StorageMap\")) {\n storage_type = `storage_map::new()`\n } else if (value.includes(\"StorageDoubleMap\")) {\n storage_type = `storage_double_map::new()`\n }\n return `${key}: ${storage_type},`\n }).join(' ')\n }\n }\n }\n \n }`;\n await formatAndWriteMove(\n schemaMoudle,\n `${path}/contracts/${projectName}/sources/codegen/schemas/${schemaName}.move`,\n \"formatAndWriteMove\"\n );\n }\n}","import { ObeliskConfig } from \"../../types\";\nimport { formatAndWriteMove } from \"../formatAndWrite\";\nimport { existsSync } from \"fs\";\n\nexport async function generateDeployHook(config: ObeliskConfig, srcPrefix: string) {\n if (\n !existsSync(\n `${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`\n )\n ) {\n let 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).map(schemaName => {\n return `let ${schemaName} = ${config.name}::${schemaName}_schema::register(dapps, ctx);`\n }).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).map(schemaName => {\n return `public_share_object(${schemaName});`\n }).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 await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/script/deploy_hook.move`,\n \"formatAndWriteMove\"\n );\n }\n}\n\nexport function generateMigrate(config: ObeliskConfig, srcPrefix: string) {\n if (\n !existsSync(\n `${srcPrefix}/contracts/${config.name}/sources/script/migrate.move`\n )\n ) {\n let 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 formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/script/migrate.move`,\n \"formatAndWriteMove\"\n );\n }\n}\n\n","import { ObeliskConfig } from \"../../types\";\nimport { formatAndWriteMove } from \"../formatAndWrite\";\n\nexport async function generateDappKey(config: ObeliskConfig, srcPrefix: string) {\n let code = `module ${config.name}::dapp_key {\n /// Authorization token for the app.\n public struct DappKey has drop {}\n\n public(package) fun new(): DappKey {\n DappKey { }\n }\n}\n`;\n await formatAndWriteMove(\n code,\n `${srcPrefix}/contracts/${config.name}/sources/codegen/dapp_key.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 = [\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","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","worldgen","config","srcPrefix","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.14",
3
+ "version": "0.5.15",
4
4
  "description": "Common low level logic shared between packages",
5
5
  "keywords": [
6
6
  "sui",
@@ -9,18 +9,25 @@ export async function formatAndWriteMove(
9
9
  logPrefix?: string
10
10
  ): Promise<void> {
11
11
  const formattedOutput = await formatMove(output);
12
- let prefix =
12
+ let schemaPrefix =
13
13
  ` // Copyright (c) Obelisk Labs, Inc.
14
14
  // SPDX-License-Identifier: MIT
15
15
  #[allow(unused_use)]
16
16
 
17
17
  /* Autogenerated file. Do not edit manually. */
18
+
19
+ `
20
+
21
+ let deployHookPrefix = `#[allow(lint(share_owned))]
22
+
18
23
  `
19
24
 
20
- let code = prefix + formattedOutput
25
+ let code = schemaPrefix + formattedOutput
21
26
 
22
- if (fullOutputPath.includes("deploy_hook") || fullOutputPath.includes(".toml") || fullOutputPath.includes("system")) {
27
+ if (fullOutputPath.includes(".toml") || fullOutputPath.includes("system")) {
23
28
  code = formattedOutput
29
+ } else if (fullOutputPath.includes("deploy_hook")) {
30
+ code = deployHookPrefix + formattedOutput
24
31
  }
25
32
 
26
33
  await fs.mkdir(path.dirname(fullOutputPath), { recursive: true });
@@ -143,7 +143,6 @@ export async function generateSchemaStructure(projectName: string, schemas: Reco
143
143
  const schemaMoudle = `module ${projectName}::${schemaName}_schema {
144
144
  use std::ascii::String;
145
145
  use std::type_name;
146
- use sui::transfer::{public_share_object};
147
146
  use obelisk::dapps_system;
148
147
  use obelisk::dapps_schema::Dapps;
149
148
  use obelisk::storage_value::{Self, StorageValue};
@@ -168,14 +167,14 @@ export async function generateSchemaStructure(projectName: string, schemas: Reco
168
167
  `
169
168
  }).join('')}
170
169
 
171
- public entry fun register(dapps: &mut Dapps, ctx: &mut TxContext) {
170
+ public fun register(dapps: &mut Dapps, ctx: &mut TxContext): ${capitalizeAndRemoveUnderscores(schemaName)} {
172
171
  let package_id = dapps_system::current_package_id<DappKey>();
173
172
  assert!(dapps.borrow_metadata().contains_key(package_id), 0);
174
173
  assert!(dapps.borrow_admin().get(package_id) == ctx.sender(), 0);
175
174
  let schema = type_name::get<${capitalizeAndRemoveUnderscores(schemaName)}>().into_string();
176
175
  assert!(!dapps.borrow_schemas().get(package_id).contains(&schema), 0);
177
-
178
- public_share_object(${capitalizeAndRemoveUnderscores(schemaName)} {
176
+ dapps_system::add_schema<${capitalizeAndRemoveUnderscores(schemaName)}>(dapps, package_id, ctx);
177
+ ${capitalizeAndRemoveUnderscores(schemaName)} {
179
178
  id: object::new(ctx),
180
179
  ${Object.entries(schema.structure).map(([key, value]) => {
181
180
  let storage_type = ""
@@ -189,9 +188,7 @@ export async function generateSchemaStructure(projectName: string, schemas: Reco
189
188
  return `${key}: ${storage_type},`
190
189
  }).join(' ')
191
190
  }
192
- });
193
-
194
- dapps_system::add_schema<${capitalizeAndRemoveUnderscores(schemaName)}>(dapps, package_id, ctx);
191
+ }
195
192
  }
196
193
 
197
194
  }`;
@@ -14,6 +14,7 @@ export async function generateDeployHook(config: ObeliskConfig, srcPrefix: strin
14
14
  use ${config.name}::dapp_key::DappKey;
15
15
  use std::ascii;
16
16
  use sui::clock::Clock;
17
+ use sui::transfer::public_share_object;
17
18
  #[test_only]
18
19
  use obelisk::dapps_schema;
19
20
  #[test_only]
@@ -33,11 +34,15 @@ export async function generateDeployHook(config: ObeliskConfig, srcPrefix: strin
33
34
  ctx
34
35
  );
35
36
  ${Object.keys(config.schemas).map(schemaName => {
36
- return `${config.name}::${schemaName}_schema::register(dapps, ctx);`
37
+ return `let ${schemaName} = ${config.name}::${schemaName}_schema::register(dapps, ctx);`
37
38
  }).join("\n")}
38
-
39
39
  // Logic that needs to be automated once the contract is deployed
40
40
 
41
+
42
+ // Share the dapp object with the public
43
+ ${Object.keys(config.schemas).map(schemaName => {
44
+ return `public_share_object(${schemaName});`
45
+ }).join("\n")}
41
46
  }
42
47
 
43
48
  #[test_only]