2023-05-20 17:11:57 +01:00
|
|
|
type InstanceProperties = {
|
|
|
|
Parent: Instance?,
|
|
|
|
ClassName: string,
|
|
|
|
Name: string,
|
2023-05-20 18:49:37 +01:00
|
|
|
-- FIXME: This breaks intellisense, but we need some way to access
|
|
|
|
-- instance properties without casting the entire instance to any...
|
2023-05-20 18:25:32 +01:00
|
|
|
-- [string]: any,
|
2023-05-20 17:11:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
type InstanceMetatable = {
|
|
|
|
Clone: (self: Instance) -> Instance,
|
|
|
|
Destroy: (self: Instance) -> (),
|
|
|
|
ClearAllChildren: (self: Instance) -> (),
|
|
|
|
|
|
|
|
GetChildren: (self: Instance) -> { Instance },
|
|
|
|
GetDescendants: (self: Instance) -> { Instance },
|
|
|
|
GetFullName: (self: Instance) -> string,
|
|
|
|
|
|
|
|
FindFirstAncestor: (self: Instance, name: string) -> Instance?,
|
|
|
|
FindFirstAncestorOfClass: (self: Instance, className: string) -> Instance?,
|
|
|
|
FindFirstAncestorWhichIsA: (self: Instance, className: string) -> Instance?,
|
|
|
|
FindFirstChild: (self: Instance, name: string, recursive: boolean?) -> Instance?,
|
|
|
|
FindFirstChildOfClass: (self: Instance, className: string, recursive: boolean?) -> Instance?,
|
|
|
|
FindFirstChildWhichIsA: (self: Instance, className: string, recursive: boolean?) -> Instance?,
|
|
|
|
|
|
|
|
IsA: (self: Instance, className: string) -> boolean,
|
|
|
|
IsAncestorOf: (self: Instance, descendant: Instance) -> boolean,
|
|
|
|
IsDescendantOf: (self: Instance, ancestor: Instance) -> boolean,
|
|
|
|
|
|
|
|
GetAttribute: (self: Instance, name: string) -> any,
|
|
|
|
GetAttributes: (self: Instance) -> { [string]: any },
|
|
|
|
SetAttribute: (self: Instance, name: string, value: any) -> (),
|
|
|
|
|
|
|
|
GetTags: (self: Instance) -> { string },
|
|
|
|
HasTag: (self: Instance, name: string) -> boolean,
|
|
|
|
AddTag: (self: Instance, name: string) -> (),
|
|
|
|
RemoveTag: (self: Instance, name: string) -> (),
|
|
|
|
}
|
|
|
|
|
|
|
|
export type Instance = typeof(setmetatable(
|
|
|
|
(nil :: any) :: InstanceProperties,
|
|
|
|
(nil :: any) :: { __index: InstanceMetatable }
|
|
|
|
))
|
|
|
|
|
2023-05-20 18:25:32 +01:00
|
|
|
export type DataModelProperties = {}
|
|
|
|
export type DataModelMetatable = {
|
2023-05-20 17:11:57 +01:00
|
|
|
GetService: (self: DataModel, name: string) -> Instance,
|
|
|
|
FindService: (self: DataModel, name: string) -> Instance?,
|
|
|
|
}
|
|
|
|
|
2023-05-20 18:25:32 +01:00
|
|
|
export type DataModel =
|
|
|
|
Instance
|
|
|
|
& typeof(setmetatable(
|
|
|
|
(nil :: any) :: DataModelProperties,
|
|
|
|
(nil :: any) :: { __index: DataModelMetatable }
|
|
|
|
))
|
2023-03-24 10:10:11 +00:00
|
|
|
|
|
|
|
--[=[
|
2023-03-24 17:48:42 +00:00
|
|
|
@class Roblox
|
2023-03-24 10:10:11 +00:00
|
|
|
|
|
|
|
Built-in library for manipulating Roblox place & model files
|
|
|
|
|
|
|
|
### Example usage
|
|
|
|
|
|
|
|
```lua
|
2023-05-20 13:23:51 +01:00
|
|
|
local fs = require("@lune/fs")
|
2023-03-24 10:10:11 +00:00
|
|
|
local roblox = require("@lune/roblox")
|
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
-- Reading a place file
|
|
|
|
local placeFile = fs.readFile("myPlaceFile.rbxl")
|
|
|
|
local game = roblox.deserializePlace(placeFile)
|
2023-03-24 10:10:11 +00:00
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
-- Manipulating and reading instances - just like in Roblox!
|
|
|
|
local workspace = game:GetService("Workspace")
|
2023-03-24 10:10:11 +00:00
|
|
|
for _, child in workspace:GetChildren() do
|
|
|
|
print("Found child " .. child.Name .. " of class " .. child.ClassName)
|
|
|
|
end
|
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
-- Writing a place file
|
|
|
|
local newPlaceFile = roblox.serializePlace(game)
|
|
|
|
fs.writeFile("myPlaceFile.rbxl", newPlaceFile)
|
2023-03-24 10:10:11 +00:00
|
|
|
```
|
|
|
|
]=]
|
2023-05-14 21:01:44 +01:00
|
|
|
return {
|
2023-03-24 10:10:11 +00:00
|
|
|
--[=[
|
2023-03-24 17:48:42 +00:00
|
|
|
@within Roblox
|
|
|
|
@must_use
|
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
Deserializes a place into a DataModel instance.
|
|
|
|
|
|
|
|
This function accepts a string of contents, *not* a file path.
|
|
|
|
If reading a place file from a file path is desired, `fs.readFile`
|
|
|
|
can be used and the resulting string may be passed to this function.
|
2023-03-24 10:10:11 +00:00
|
|
|
|
|
|
|
### Example usage
|
|
|
|
|
|
|
|
```lua
|
2023-05-20 13:23:51 +01:00
|
|
|
local fs = require("@lune/fs")
|
2023-03-24 10:10:11 +00:00
|
|
|
local roblox = require("@lune/roblox")
|
2023-05-20 13:23:51 +01:00
|
|
|
|
|
|
|
local placeFile = fs.readFile("filePath.rbxl")
|
|
|
|
local game = roblox.deserializePlace(placeFile)
|
2023-03-24 10:10:11 +00:00
|
|
|
```
|
2023-03-24 17:48:42 +00:00
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
@param contents The contents of the place to read
|
2023-03-24 10:10:11 +00:00
|
|
|
]=]
|
2023-05-20 17:11:57 +01:00
|
|
|
deserializePlace = function(contents: string): DataModel
|
2023-05-14 21:01:44 +01:00
|
|
|
return nil :: any
|
|
|
|
end,
|
2023-03-24 10:10:11 +00:00
|
|
|
--[=[
|
2023-03-24 17:48:42 +00:00
|
|
|
@within Roblox
|
|
|
|
@must_use
|
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
Deserializes a model into an array of instances.
|
|
|
|
|
|
|
|
This function accepts a string of contents, *not* a file path.
|
|
|
|
If reading a model file from a file path is desired, `fs.readFile`
|
|
|
|
can be used and the resulting string may be passed to this function.
|
2023-03-24 10:10:11 +00:00
|
|
|
|
|
|
|
### Example usage
|
|
|
|
|
|
|
|
```lua
|
2023-05-20 13:23:51 +01:00
|
|
|
local fs = require("@lune/fs")
|
2023-03-24 10:10:11 +00:00
|
|
|
local roblox = require("@lune/roblox")
|
2023-05-20 13:23:51 +01:00
|
|
|
|
|
|
|
local modelFile = fs.readFile("filePath.rbxm")
|
|
|
|
local instances = roblox.deserializeModel(modelFile)
|
2023-03-24 10:10:11 +00:00
|
|
|
```
|
2023-03-24 17:48:42 +00:00
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
@param contents The contents of the model to read
|
2023-03-24 10:10:11 +00:00
|
|
|
]=]
|
2023-05-20 13:23:51 +01:00
|
|
|
deserializeModel = function(contents: string): { Instance }
|
2023-05-14 21:01:44 +01:00
|
|
|
return nil :: any
|
|
|
|
end,
|
2023-03-24 10:10:11 +00:00
|
|
|
--[=[
|
2023-03-24 17:48:42 +00:00
|
|
|
@within Roblox
|
2023-05-20 13:23:51 +01:00
|
|
|
@must_use
|
|
|
|
|
|
|
|
Serializes a place from a DataModel instance.
|
2023-03-24 17:48:42 +00:00
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
This string can then be written to a file, or sent over the network.
|
2023-03-24 10:10:11 +00:00
|
|
|
|
|
|
|
### Example usage
|
|
|
|
|
|
|
|
```lua
|
2023-05-20 13:23:51 +01:00
|
|
|
local fs = require("@lune/fs")
|
2023-03-24 10:10:11 +00:00
|
|
|
local roblox = require("@lune/roblox")
|
2023-05-20 13:23:51 +01:00
|
|
|
|
|
|
|
local placeFile = roblox.serializePlace(game)
|
|
|
|
fs.writeFile("filePath.rbxl", placeFile)
|
2023-03-24 10:10:11 +00:00
|
|
|
```
|
2023-03-24 17:48:42 +00:00
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
@param dataModel The DataModel for the place to serialize
|
|
|
|
@param xml If the place should be serialized as xml or not. Defaults to `false`, meaning the place gets serialized using the binary format and not xml.
|
2023-03-24 10:10:11 +00:00
|
|
|
]=]
|
2023-05-20 17:11:57 +01:00
|
|
|
serializePlace = function(dataModel: DataModel, xml: boolean?): string
|
2023-05-20 13:23:51 +01:00
|
|
|
return nil :: any
|
|
|
|
end,
|
2023-03-24 10:10:11 +00:00
|
|
|
--[=[
|
2023-03-24 17:48:42 +00:00
|
|
|
@within Roblox
|
2023-05-20 13:23:51 +01:00
|
|
|
@must_use
|
2023-03-24 17:48:42 +00:00
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
Serializes one or more instances as a model.
|
|
|
|
|
|
|
|
This string can then be written to a file, or sent over the network.
|
2023-03-24 10:10:11 +00:00
|
|
|
|
|
|
|
### Example usage
|
|
|
|
|
|
|
|
```lua
|
2023-05-20 13:23:51 +01:00
|
|
|
local fs = require("@lune/fs")
|
2023-03-24 10:10:11 +00:00
|
|
|
local roblox = require("@lune/roblox")
|
2023-05-20 13:23:51 +01:00
|
|
|
|
|
|
|
local modelFile = roblox.serializeModel({ instance1, instance2, ... })
|
|
|
|
fs.writeFile("filePath.rbxm", modelFile)
|
2023-03-24 10:10:11 +00:00
|
|
|
```
|
2023-03-24 17:48:42 +00:00
|
|
|
|
2023-05-20 13:23:51 +01:00
|
|
|
@param instances The array of instances to serialize
|
|
|
|
@param xml If the model should be serialized as xml or not. Defaults to `false`, meaning the model gets serialized using the binary format and not xml.
|
2023-03-24 10:10:11 +00:00
|
|
|
]=]
|
2023-05-20 13:23:51 +01:00
|
|
|
serializeModel = function(instances: { Instance }, xml: boolean?): string
|
|
|
|
return nil :: any
|
|
|
|
end,
|
2023-03-24 10:10:11 +00:00
|
|
|
--[=[
|
2023-03-24 17:48:42 +00:00
|
|
|
@within Roblox
|
|
|
|
@must_use
|
|
|
|
|
2023-03-24 10:10:11 +00:00
|
|
|
Gets the current auth cookie, for usage with Roblox web APIs.
|
|
|
|
|
2023-03-24 17:48:42 +00:00
|
|
|
Note that this auth cookie is formatted for use as a "Cookie" header,
|
|
|
|
and that it contains restrictions so that it may only be used for
|
|
|
|
official Roblox endpoints. To get the raw cookie value without any
|
|
|
|
additional formatting, you can pass `true` as the first and only parameter.
|
|
|
|
|
2023-03-24 10:10:11 +00:00
|
|
|
### Example usage
|
|
|
|
|
|
|
|
```lua
|
|
|
|
local roblox = require("@lune/roblox")
|
|
|
|
local net = require("@lune/net")
|
|
|
|
|
|
|
|
local cookie = roblox.getAuthCookie()
|
|
|
|
assert(cookie ~= nil, "Failed to get roblox auth cookie")
|
|
|
|
|
|
|
|
local myPrivatePlaceId = 1234567890
|
|
|
|
|
|
|
|
local response = net.request({
|
|
|
|
url = "https://assetdelivery.roblox.com/v2/assetId/" .. tostring(myPrivatePlaceId),
|
|
|
|
headers = {
|
|
|
|
Cookie = cookie,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
local responseTable = net.jsonDecode(response.body)
|
|
|
|
local responseLocation = responseTable.locations[1].location
|
|
|
|
print("Download link to place: " .. responseLocation)
|
|
|
|
```
|
2023-03-24 17:48:42 +00:00
|
|
|
|
|
|
|
@param raw If the cookie should be returned as a pure value or not. Defaults to false
|
2023-03-24 10:10:11 +00:00
|
|
|
]=]
|
2023-05-14 21:01:44 +01:00
|
|
|
getAuthCookie = function(raw: boolean?): string?
|
|
|
|
return nil :: any
|
|
|
|
end,
|
2023-05-20 18:49:37 +01:00
|
|
|
-- TODO: Make typedefs for all of the datatypes as well...
|
|
|
|
Instance = (nil :: any) :: {
|
|
|
|
new: ((className: "DataModel") -> DataModel) & ((className: string) -> Instance),
|
|
|
|
},
|
2023-03-24 10:10:11 +00:00
|
|
|
}
|