lune-packaging/docs/typedefs/Roblox.luau

169 lines
4.5 KiB
Lua
Raw Normal View History

-- TODO: Autogenerate this somehow ...
2023-03-24 10:10:11 +00:00
export type Instance = {}
--[=[
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
local fs = require("@lune/fs")
2023-03-24 10:10:11 +00:00
local roblox = require("@lune/roblox")
-- Reading a place file
local placeFile = fs.readFile("myPlaceFile.rbxl")
local game = roblox.deserializePlace(placeFile)
2023-03-24 10:10:11 +00: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
-- Writing a place file
local newPlaceFile = roblox.serializePlace(game)
fs.writeFile("myPlaceFile.rbxl", newPlaceFile)
2023-03-24 10:10:11 +00:00
```
]=]
return {
2023-03-24 10:10:11 +00:00
--[=[
2023-03-24 17:48:42 +00:00
@within Roblox
@must_use
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
local fs = require("@lune/fs")
2023-03-24 10:10:11 +00:00
local roblox = require("@lune/roblox")
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
@param contents The contents of the place to read
2023-03-24 10:10:11 +00:00
]=]
deserializePlace = function(contents: string): Instance
return nil :: any
end,
2023-03-24 10:10:11 +00:00
--[=[
2023-03-24 17:48:42 +00:00
@within Roblox
@must_use
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
local fs = require("@lune/fs")
2023-03-24 10:10:11 +00:00
local roblox = require("@lune/roblox")
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
@param contents The contents of the model to read
2023-03-24 10:10:11 +00:00
]=]
deserializeModel = function(contents: string): { Instance }
return nil :: any
end,
2023-03-24 10:10:11 +00:00
--[=[
2023-03-24 17:48:42 +00:00
@within Roblox
@must_use
Serializes a place from a DataModel instance.
2023-03-24 17:48:42 +00: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
local fs = require("@lune/fs")
2023-03-24 10:10:11 +00:00
local roblox = require("@lune/roblox")
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
@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
]=]
serializePlace = function(dataModel: 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 17:48:42 +00: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
local fs = require("@lune/fs")
2023-03-24 10:10:11 +00:00
local roblox = require("@lune/roblox")
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
@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
]=]
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
]=]
getAuthCookie = function(raw: boolean?): string?
return nil :: any
end,
2023-03-24 10:10:11 +00:00
}