Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement SecurityCapabilities in rbx_binary #361

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ Roblox Lua implementation of DOM APIs, allowing Instance reflection from inside
| Ref | `Model.PrimaryPart` | ✔ | ✔ | ✔ | ✔ |
| Region3 | N/A | ✔ | ✔ | ❌ | ❌ |
| Region3int16 | `Terrain.MaxExtents` | ✔ | ✔ | ❌ | ❌ |
| SecurityCapabilities | `Folder.SecurityCapabilities` | ✔ | ❌ | | |
| SecurityCapabilities | `Folder.SecurityCapabilities` | ✔ | ❌ | | |
| SharedString | N/A | ✔ | ✔ | ✔ | ✔ |
| String | `Instance.Name` | ✔ | ✔ | ✔ | ✔ |
| UDim | `UIListLayout.Padding` | ✔ | ✔ | ✔ | ✔ |
Expand Down
3 changes: 3 additions & 0 deletions rbx_binary/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
# rbx_binary Changelog

## Unreleased
* Added support for `SecurityCapabilities` values. ([#361])

[#361]: https://github.com/rojo-rbx/rbx-dom/pull/361

## 0.7.1 (2023-08-09)
* Added support for `UniqueId` values. ([#271])
Expand Down
29 changes: 27 additions & 2 deletions rbx_binary/src/deserializer/state.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@ use rbx_dom_weak::{
Attributes, Axes, BinaryString, BrickColor, CFrame, Color3, Color3uint8, ColorSequence,
ColorSequenceKeypoint, Content, CustomPhysicalProperties, Enum, Faces, Font, FontStyle,
FontWeight, MaterialColors, Matrix3, NumberRange, NumberSequence, NumberSequenceKeypoint,
PhysicalProperties, Ray, Rect, Ref, SharedString, Tags, UDim, UDim2, UniqueId, Variant,
VariantType, Vector2, Vector3, Vector3int16,
PhysicalProperties, Ray, Rect, Ref, SecurityCapabilities, SharedString, Tags, UDim, UDim2,
UniqueId, Variant, VariantType, Vector2, Vector3, Vector3int16,
},
InstanceBuilder, WeakDom,
};
Expand Down Expand Up @@ -1361,6 +1361,31 @@ impl<'a, R: Read> DeserializerState<'a, R> {
});
}
},
Type::SecurityCapabilities => match canonical_type {
VariantType::SecurityCapabilities => {
let mut values = vec![0; type_info.referents.len()];

chunk.read_interleaved_i64_array(values.as_mut_slice())?;

let values: Vec<SecurityCapabilities> = values
.into_iter()
.map(|value| SecurityCapabilities::from_bits(value as u64))
.collect();

for (referent, value) in type_info.referents.iter().zip(values) {
let instance = self.instances_by_ref.get_mut(referent).unwrap();
add_property(instance, &property, value.into())
}
}
invalid_type => {
return Err(InnerError::PropTypeMismatch {
type_name: type_info.type_name.clone(),
prop_name,
valid_type_names: "SecurityCapabilities",
actual_type_name: format!("{:?}", invalid_type),
});
}
},
}

Ok(())
Expand Down
13 changes: 13 additions & 0 deletions rbx_binary/src/serializer/state.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1186,6 +1186,19 @@ impl<'dom, W: Write> SerializerState<'dom, W> {

chunk.write_interleaved_bytes::<16>(&blobs)?;
}
Type::SecurityCapabilities => {
let mut capabilities = Vec::with_capacity(values.len());

for (i, rbx_value) in values {
if let Variant::SecurityCapabilities(value) = rbx_value.as_ref() {
capabilities.push(value.bits() as i64)
} else {
return type_mismatch(i, &rbx_value, "SecurityCapabilities");
}
}

chunk.write_interleaved_i64_array(capabilities.into_iter())?;
}
}

chunk.dump(&mut self.output)?;
Expand Down
1 change: 1 addition & 0 deletions rbx_binary/src/tests/models.rs
Original file line number Diff line number Diff line change
Expand Up @@ -64,4 +64,5 @@ binary_tests! {
gui_inset_and_font_migration,
folder_with_cframe_attributes,
folder_with_font_attribute,
number_values_with_security_capabilities,
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
---
source: rbx_binary/src/tests/util.rs
expression: decoded_viewed
---
- referent: referent-0
name: Hmmm
class: NumberValue
properties:
Attributes:
Attributes: {}
Capabilities:
SecurityCapabilities: 0
DefinesCapabilities:
Bool: false
SourceAssetId:
Int64: -1
Tags:
Tags: []
Value:
Float64: 2.71828182846
children: []
- referent: referent-1
name: WhereIs
class: NumberValue
properties:
Attributes:
Attributes: {}
Capabilities:
SecurityCapabilities: 2882400000
DefinesCapabilities:
Bool: false
SourceAssetId:
Int64: -1
Tags:
Tags: []
Value:
Float64: 2.71828182846
children: []

Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
---
source: rbx_binary/src/tests/util.rs
expression: text_roundtrip
---
num_types: 1
num_instances: 2
chunks:
- Inst:
type_id: 0
type_name: NumberValue
object_format: 0
referents:
- 0
- 1
- Prop:
type_id: 0
prop_name: AttributesSerialize
prop_type: String
values:
- ""
- ""
- Prop:
type_id: 0
prop_name: Capabilities
prop_type: SecurityCapabilities
values:
- 0
- 2882400000
- Prop:
type_id: 0
prop_name: DefinesCapabilities
prop_type: Bool
values:
- false
- false
- Prop:
type_id: 0
prop_name: Name
prop_type: String
values:
- Hmmm
- WhereIs
- Prop:
type_id: 0
prop_name: SourceAssetId
prop_type: Int64
values:
- -1
- -1
- Prop:
type_id: 0
prop_name: Tags
prop_type: String
values:
- ""
- ""
- Prop:
type_id: 0
prop_name: Value
prop_type: Float64
values:
- 2.71828182846
- 2.71828182846
- Prnt:
version: 0
links:
- - 0
- -1
- - 1
- -1
- End

Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
---
source: rbx_binary/src/tests/util.rs
expression: text_decoded
---
num_types: 1
num_instances: 2
chunks:
- Meta:
entries:
- - ExplicitAutoJoints
- "true"
- Inst:
type_id: 0
type_name: NumberValue
object_format: 0
referents:
- 0
- 1
- Prop:
type_id: 0
prop_name: AttributesSerialize
prop_type: String
values:
- ""
- ""
- Prop:
type_id: 0
prop_name: Capabilities
prop_type: SecurityCapabilities
values:
- 0
- 2882400000
- Prop:
type_id: 0
prop_name: DefinesCapabilities
prop_type: Bool
values:
- false
- false
- Prop:
type_id: 0
prop_name: Name
prop_type: String
values:
- Hmmm
- WhereIs
- Prop:
type_id: 0
prop_name: SourceAssetId
prop_type: Int64
values:
- -1
- -1
- Prop:
type_id: 0
prop_name: Tags
prop_type: String
values:
- ""
- ""
- Prop:
type_id: 0
prop_name: Value
prop_type: Float64
values:
- 2.71828182846
- 2.71828182846
- Prnt:
version: 0
links:
- - 0
- -1
- - 1
- -1
- End

17 changes: 15 additions & 2 deletions rbx_binary/src/text_deserializer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@ use std::{collections::HashMap, convert::TryInto, fmt::Write, io::Read};
use rbx_dom_weak::types::{
Axes, BrickColor, CFrame, Color3, Color3uint8, ColorSequence, ColorSequenceKeypoint,
CustomPhysicalProperties, Enum, Faces, Font, FontStyle, FontWeight, Matrix3, NumberRange,
NumberSequence, NumberSequenceKeypoint, PhysicalProperties, Ray, Rect, SharedString, UDim,
UDim2, UniqueId, Vector2, Vector3, Vector3int16,
NumberSequence, NumberSequenceKeypoint, PhysicalProperties, Ray, Rect, SecurityCapabilities,
SharedString, UDim, UDim2, UniqueId, Vector2, Vector3, Vector3int16,
};
use serde::{ser::SerializeSeq, Serialize, Serializer};

Expand Down Expand Up @@ -224,6 +224,7 @@ pub enum DecodedValues {
OptionalCFrame(Vec<Option<CFrame>>),
UniqueId(Vec<UniqueId>),
Font(Vec<Font>),
SecurityCapabilities(Vec<SecurityCapabilities>),
}

impl DecodedValues {
Expand Down Expand Up @@ -712,6 +713,18 @@ impl DecodedValues {

Some(DecodedValues::UniqueId(values))
}
Type::SecurityCapabilities => {
let mut values = vec![0; prop_count];

reader.read_interleaved_i64_array(&mut values).unwrap();

let values = values
.into_iter()
.map(|value| SecurityCapabilities::from_bits(value as u64))
.collect();

Some(DecodedValues::SecurityCapabilities(values))
}
}
}
}
Expand Down
4 changes: 4 additions & 0 deletions rbx_binary/src/types.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ pub enum Type {
OptionalCFrame = 0x1E,
UniqueId = 0x1F,
Font = 0x20,
SecurityCapabilities = 0x21,
}

impl Type {
Expand Down Expand Up @@ -81,6 +82,7 @@ impl Type {
VariantType::OptionalCFrame => Type::OptionalCFrame,
VariantType::UniqueId => Type::UniqueId,
VariantType::Font => Type::Font,
VariantType::SecurityCapabilities => Type::SecurityCapabilities,
_ => return None,
})
}
Expand Down Expand Up @@ -118,6 +120,7 @@ impl Type {
Type::OptionalCFrame => VariantType::OptionalCFrame,
Type::UniqueId => VariantType::UniqueId,
Type::Font => VariantType::Font,
Type::SecurityCapabilities => VariantType::SecurityCapabilities,
})
}
}
Expand Down Expand Up @@ -158,6 +161,7 @@ impl TryFrom<u8> for Type {
0x1E => OptionalCFrame,
0x1F => UniqueId,
0x20 => Font,
0x21 => SecurityCapabilities,
_ => return Err(InvalidTypeError(value)),
})
}
Expand Down