I noticed that the sending request UDP broadcast on linux is not possible with PureBasic.
the "SendNetworkData" function allows you to include the "permission" to create the socket which is a requirement under Linux when sending the broadcast.
Here's an example to test the topic:
PureBasic example (not working because no permission):
Code: Select all
OpenConsole()
If InitNetwork() = 0
PrintN("Error => Can't initialize the network !")
Goto killsoft
EndIf
ExamineIPAddresses()
Myip = NextIPAddress()
If Not Myip
Goto killsoft
EndIf
Myipstr$ = IPString(myip)
Broadcast$ =StringField(IPString(Myip),1,".")+"."+StringField(IPString(Myip),2,".")+"."+StringField(IPString(Myip),3,".")+".255"
PrintN("Your IP : "+ Myipstr$)
PrintN("Your Broadcast : "+Broadcast$)
*Header = AllocateMemory(70)
connection.i = OpenNetworkConnection(Broadcast$, 50000,#PB_Network_UDP)
If connection <> 0
PrintN("OpenNetworkConnection OK !")
ret.i = SendNetworkData(connection, *Header,70)
While ret = -1
ret = SendNetworkData(connection, *Header,70)
PrintN("SendNetworkData return -1 ... retry !")
Delay(1000)
Wend
If ret = 70
PrintN("Header Sent Correct !")
Else
PrintN("Header long error (Not 70) !"); => "+ret)
EndIf
CloseNetworkConnection(connection)
Else
PrintN(" --- ERROR --- OpenNetworkConnection Faild!")
EndIf
killsoft :
Input()
Another example purebusic (I can not compile under Linux, but it can include the famous permision)#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <time.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>
int main(int argc, char *argv[])
{
char *dstIP = "192.168.0.255"; /manuel Change !/
char *localIP = "192.168.0.250"; /manuel Change !/
int BroadcastPort = 5000;
int sock; /* Socket */
/-------------------------------Permission Broadcast------------------------------------/
struct sockaddr_in broadcastAddr; /* Broadcast address */
int broadcastPermission; /* Socket opt to set permission to broadcast */
unsigned int localIPLen; /* Length of string to broadcast */
/---------------------------------------------------------------------------------------/
/* Create socket for sending/receiving datagrams */
if ((sock = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP)) < 0)
perror("socket() failed");
/* Set socket to allow broadcast */
broadcastPermission = 1;
if (setsockopt(sock, SOL_SOCKET, SO_BROADCAST, (void *) &broadcastPermission,
sizeof(broadcastPermission)) < 0)
perror("setsockopt() failed");
/* Construct local address structure */
memset(&broadcastAddr, 0, sizeof(broadcastAddr)); /* Zero out structure */
broadcastAddr.sin_family = AF_INET; /* Internet address family */
broadcastAddr.sin_addr.s_addr = inet_addr(dstIP); /* Broadcast IP address */
broadcastAddr.sin_port = htons(BroadcastPort); /* Broadcast port */
localIPLen = strlen(localIP); /* Find length of localIP */
int j;
for (j=0; j<1; j++) //doesnt mean anything so far, not important
{
/* Broadcast localIP in datagram to clients */
if (sendto(sock, localIP, localIPLen, 0, (struct sockaddr *)
&broadcastAddr, sizeof(broadcastAddr)) != localIPLen)
perror("sendto() sent a different number of bytes than expected");
}
}
Code: Select all
Procedure.l SendUDPBroadcastL (port, message.s)
Protected sock,one,bytes,remote.sockaddr_in
sock = SOCKET_(#AF_INET,#SOCK_DGRAM,#IPPROTO_IP)
If ( sock = -1) : ProcedureReturn 1 : EndIf
one = 1
If (setsockopt_(sock,#SOL_SOCKET,#SO_BROADCAST,@one,SizeOf(one)) = -1)
ProcedureReturn 1
EndIf
remote\sin_family = #AF_INET
remote\sin_port = htons_(port)
remote\sin_addr = #INADDR_BROADCAST
if (sendto_(sock,message,Len(message),0,@remote,SizeOf(remote)) = -1)
ProcedureReturn 1
EndIf
closesocket_(sock)
ProcedureReturn 0
EndProcedure