logo

Live Production Software Forums


Welcome Guest! To enable all features please Login or Register.

Notification

Icon
Error

Options
Go to last post Go to first unread
aidendoyle  
#1 Posted : Sunday, October 22, 2023 10:10:07 PM(UTC)
aidendoyle

Rank: Newbie

Groups: Registered
Joined: 10/22/2023(UTC)
Posts: 9
Ireland
Location: Longford

Thanks: 1 times
I am not to sure if I am getting this correct. But am I correct in saying you can change a title using a HTTP WEB API link

I see the example on vmix help site
http://127.0.0.1:8088/API/?Function=SetText&Input=877bb3e7-58bd-46a1-85ce-0d673aec6bf5&SelectedName=Headline&Value=Hello

But I am not to sure what is what in that in that link.

If i have a title number 5 with a name of test and a text area called text area with a value of test text. How would I use a link like above to change the test text to something else.

Thanks
doggy  
#2 Posted : Sunday, October 22, 2023 10:23:38 PM(UTC)
doggy

Rank: Advanced Member

Groups: Registered
Joined: 12/27/2012(UTC)
Posts: 5,085
Belgium
Location: Belgium

Thanks: 284 times
Was thanked: 920 time(s) in 759 post(s)
Originally Posted by: aidendoyle Go to Quoted Post
I am not to sure if I am getting this correct. But am I correct in saying you can change a title using a HTTP WEB API link

I see the example on vmix help site
http://127.0.0.1:8088/API/?Function=SetText&Input=877bb3e7-58bd-46a1-85ce-0d673aec6bf5&SelectedName=Headline&Value=Hello

But I am not to sure what is what in that in that link.

If i have a title number 5 with a name of test and a text area called text area with a value of test text. How would I use a link like above to change the test text to something else.

Thanks


Input refers to the name , index number or Key number of a specific input
SelectedName to the name of the text field (or SelectedIndex) to the index number of it)
Value is what you want to write in the textfield of the specific title

Check setting a SetText in shortcuts to see options or refer to the helpfiles

in your case it would be http://127.0.0.1:8088/API/?Function=SetText&Input=5&SelectedName=Text Area&Value=Test text
or http://127.0.0.1:8088/API/?Function=SetText&Input=test&SelectedName=Text Area&Value=Test text
aidendoyle  
#3 Posted : Sunday, October 29, 2023 4:10:15 AM(UTC)
aidendoyle

Rank: Newbie

Groups: Registered
Joined: 10/22/2023(UTC)
Posts: 9
Ireland
Location: Longford

Thanks: 1 times
That worked a treat, thanks so much. Is there a way of retrieving the value to show on a html page. So if i wanted to see what the the value of the input was that it gets displayed on a page.

just so no confusion.

here is my api output

<vmix>
<version>26.0.0.44</version>
<edition>HD</edition>
<inputs>
<input key="1bb755d3-d623-4304-b8b7-388c045710f4" number="1" type="GT" title="lower" shortTitle="lower" state="Running" position="0" duration="0" loop="False" selectedIndex="0">
lower
<text index="0" name="Message.Text">test</text>
</input>
<input key="d928aee1-ac9d-4f2d-9db3-0be9580dfe87" number="2" type="Video" title="_58_Should_We_Legalize_All_Drugs.mp4" shortTitle="_58_Should_We_Legalize_All_Drugs.mp4" state="Paused" position="1280" duration="3652638" loop="False" muted="False" volume="100" balance="0" solo="False" audiobusses="M" meterF1="0" meterF2="0" gainDb="0">_58_Should_We_Legalize_All_Drugs.mp4</input>
</inputs>
<overlays>
<overlay number="1"/>
<overlay number="2">1</overlay>
<overlay number="3"/>
<overlay number="4"/>
<overlay number="5"/>
<overlay number="6"/>
<overlay number="7"/>
<overlay number="8"/>
</overlays>
<preview>1</preview>
<active>2</active>
<fadeToBlack>False</fadeToBlack>
<transitions>
<transition number="1" effect="Fade" duration="500"/>
<transition number="2" effect="Merge" duration="1000"/>
<transition number="3" effect="Wipe" duration="1000"/>
<transition number="4" effect="CubeZoom" duration="1000"/>
</transitions>
<recording>False</recording>
<external>False</external>
<streaming>False</streaming>
<playList>False</playList>
<multiCorder>False</multiCorder>
<fullscreen>False</fullscreen>
<audio>
<master volume="100" muted="False" meterF1="0" meterF2="0" headphonesVolume="100"/>
<busA volume="100" muted="False" meterF1="0" meterF2="0"/>
<busB volume="100" muted="False" meterF1="0" meterF2="0"/>
<busC volume="100" muted="False" meterF1="0" meterF2="0"/>
<busD volume="100" muted="False" meterF1="0" meterF2="0"/>
</audio>
<dynamic>
<input1/>
<input2/>
<input3/>
<input4/>
<value1/>
<value2/>
<value3/>
<value4/>
</dynamic>
</vmix>


on line 7 <text index="0" name="Message.Text">test</text> How would I retreve the value via the api and show on a html page
doggy  
#4 Posted : Sunday, October 29, 2023 5:01:34 AM(UTC)
doggy

Rank: Advanced Member

Groups: Registered
Joined: 12/27/2012(UTC)
Posts: 5,085
Belgium
Location: Belgium

Thanks: 284 times
Was thanked: 920 time(s) in 759 post(s)
Originally Posted by: aidendoyle Go to Quoted Post
That worked a treat, thanks so much. Is there a way of retrieving the value to show on a html page. So if i wanted to see what the the value of the input was that it gets displayed on a page.

on line 7 <text index="0" name="Message.Text">test</text> How would I retreve the value via the api and show on a html page


You can retrieve the info using a script
Have a look at the "scripting for dummies"post , plenty of examples there.
How to show this info on a html page is not part of this forum

Btw might be better to show API XML example with a more suited input content!
aidendoyle  
#5 Posted : Sunday, October 29, 2023 6:26:50 AM(UTC)
aidendoyle

Rank: Newbie

Groups: Registered
Joined: 10/22/2023(UTC)
Posts: 9
Ireland
Location: Longford

Thanks: 1 times
its all good i figured it out if any one is interested here is the code

<script>
// Variables to store the previous and current API values for each input
let previousApiValue1 = "";
let currentApiValue1 = "";
let previousApiValue2 = "";
let currentApiValue2 = "";
let previousApiValue3 = "";
let currentApiValue3 = "";
let previousApiValue4 = "";
let currentApiValue4 = "";

// Function to retrieve and display the data
function fetchData() {
// Define the API URL
const apiUrl = "http://00.00.00.0:8088/API/";

// Define the desired shortTitles for each input
const shortTitle1 = "Caller 1"; // Replace with the desired shortTitle for input 1
const shortTitle2 = "Caller 2"; // Replace with the desired shortTitle for input 2
const shortTitle3 = "Caller 3"; // Replace with the desired shortTitle for input 3
const shortTitle4 = "Caller 4"; // Replace with the desired shortTitle for input 4

// Fetch the XML data from the API
fetch(apiUrl)
.then(response => response.text())
.then(data => {
// Parse the XML data
const parser = new DOMParser();
const xmlDoc = parser.parseFromString(data, "text/xml");

// Extract the desired value based on shortTitle for input 1
const inputElement1 = xmlDoc.querySelector(`input[shortTitle="${shortTitle1}"]`);
if (inputElement1) {
const textElement1 = inputElement1.querySelector('text[name="Message"]');
if (textElement1) {
currentApiValue1 = textElement1.textContent;

// Update the input field for input 1 if the API value has changed
if (currentApiValue1 !== previousApiValue1) {
const textInput1 = document.getElementById("textInput1");
textInput1.value = currentApiValue1;
previousApiValue1 = currentApiValue1;
}
}
}

// Extract the desired value based on shortTitle for input 2
const inputElement2 = xmlDoc.querySelector(`input[shortTitle="${shortTitle2}"]`);
if (inputElement2) {
const textElement2 = inputElement2.querySelector('text[name="Message"]');
if (textElement2) {
currentApiValue2 = textElement2.textContent;

// Update the input field for input 2 if the API value has changed
if (currentApiValue2 !== previousApiValue2) {
const textInput2 = document.getElementById("textInput2");
textInput2.value = currentApiValue2;
previousApiValue2 = currentApiValue2;
}
}
}
// Extract the desired value based on shortTitle for input 3
const inputElement3 = xmlDoc.querySelector(`input[shortTitle="${shortTitle3}"]`);
if (inputElement3) {
const textElement3 = inputElement3.querySelector('text[name="Message"]');
if (textElement3) {
currentApiValue3 = textElement3.textContent;

// Update the input field for input 3 if the API value has changed
if (currentApiValue3 !== previousApiValue3) {
const textInput3 = document.getElementById("textInput3");
textInput3.value = currentApiValue3;
previousApiValue3 = currentApiValue3;
}
}
}
// Extract the desired value based on shortTitle for input 4
const inputElement4 = xmlDoc.querySelector(`input[shortTitle="${shortTitle4}"]`);
if (inputElement4) {
const textElement4 = inputElement4.querySelector('text[name="Message"]');
if (textElement4) {
currentApiValue4 = textElement4.textContent;

// Update the input field for input 4 if the API value has changed
if (currentApiValue4 !== previousApiValue4) {
const textInput4 = document.getElementById("textInput4");
textInput4.value = currentApiValue4;
previousApiValue4 = currentApiValue4;
}
}
}
})
.catch(error => {
console.error("Error fetching data:", error);
});
}

// Call the fetchData function initially
fetchData();

// Set up an interval to call fetchData every 1 second (1000 milliseconds)
setInterval(fetchData, 1000);

// Add input event listeners to detect user input for each input
const textInput1 = document.getElementById("textInput1");
textInput1.addEventListener("input", function () {
const userInputValue = textInput1.value;

// Update the current API value for input 1 to reflect the user's input
currentApiValue1 = userInputValue;
});

const textInput2 = document.getElementById("textInput2");
textInput2.addEventListener("input", function () {
const userInputValue = textInput2.value;

// Update the current API value for input 2 to reflect the user's input
currentApiValue2 = userInputValue;
});

// Add input event listeners to detect user input for each input
const textInput3 = document.getElementById("textInput3");
textInput3.addEventListener("input", function () {
const userInputValue = textInput3.value;

// Update the current API value for input 3 to reflect the user's input
currentApiValue3 = userInputValue;
});

// Add input event listeners to detect user input for each input
const textInput4 = document.getElementById("textInput4");
textInput4.addEventListener("input", function () {
const userInputValue = textInput4.value;

// Update the current API value for input 3 to reflect the user's input
currentApiValue4 = userInputValue;
});
</script>
aidendoyle  
#6 Posted : Sunday, October 29, 2023 7:59:57 AM(UTC)
aidendoyle

Rank: Newbie

Groups: Registered
Joined: 10/22/2023(UTC)
Posts: 9
Ireland
Location: Longford

Thanks: 1 times
I have setup a form using html and javascript that can send and show api data. But this is only possible if I set allow access to api without login is checked in the web controller settings. Obviously this is a bad thing to keep on as anyone can access the api. How do I go about setting up a login page where i can enter the credentials to access.
User is suspended until 7/1/2029 2:52:17 AM(UTC) najafysmm  
#7 Posted : Sunday, December 3, 2023 10:32:05 PM(UTC)
najafysmm

Rank: Newbie

Groups: Registered
Joined: 11/28/2023(UTC)
Posts: 9
United Arab Emirates
Location: Abudabi

Thanks: 1 times
Originally Posted by: aidendoyle Go to Quoted Post
I have setup a form using html and javascript that can send and show api data. But this is only possible if I set allow access to api without login is checked in the web controller settings. Obviously this is a bad thing to keep on as anyone can access the api. How do I go about setting up a login page where i can enter the credentials to access.


recently i used this text for api then got errors

UserPostedImage

UserPostedImage

UserPostedImage

UserPostedImage

UserPostedImage


tnx

Character | URL encoded representation |
|---|---|
| ESC | %3Cesc%3E |
| Enter | %0A |
| Backspace | %08 |
| Tab | %09 |
| Space | %20 |
| " | %22 |
| ' | %27 |
| | %5C |
| / | %2F |
| : | %3A |
| ; | %3B |
| ? | %3F |
| @ | %40 |
| = | %3D |
| + | %2B |
| - | %2D |
| _ | %5F |
| . | %2E |
| < | %3C |
| > | %3E |
You can use this table to URL encode any other ESC characters that you need to use in your Vmix web API requests.

i also used these table for encoding url but no results & malfunctioned again
doggy  
#8 Posted : Monday, December 4, 2023 12:41:04 AM(UTC)
doggy

Rank: Advanced Member

Groups: Registered
Joined: 12/27/2012(UTC)
Posts: 5,085
Belgium
Location: Belgium

Thanks: 284 times
Was thanked: 920 time(s) in 759 post(s)
Originally Posted by: najafysmm Go to Quoted Post
Originally Posted by: aidendoyle Go to Quoted Post
I have setup a form using html and javascript that can send and show api data. But this is only possible if I set allow access to api without login is checked in the web controller settings. Obviously this is a bad thing to keep on as anyone can access the api. How do I go about setting up a login page where i can enter the credentials to access.


recently i used this text for api then got errors

UserPostedImage

UserPostedImage

UserPostedImage



DO you realize many cant even read/understand what is on the screenshots ?
Users browsing this topic
Guest
Forum Jump  
You cannot post new topics in this forum.
You cannot reply to topics in this forum.
You cannot delete your posts in this forum.
You cannot edit your posts in this forum.
You cannot create polls in this forum.
You cannot vote in polls in this forum.