MBS FileMaker Plugin, version 9.4pr8


New in this prerelease of version 9.4 of the MBS FileMaker Plugin: Download at monkeybreadsoftware.de/filemaker/files/Prerelease/ or ask for being added to the dropbox shared folder.

Neues vom MBS Plugin 9.3


In diesem Artikel möchte ich ihnen die neuen Funktionen vorstellen, die wir ihnen mit der im Juli erschienen Version 9.3 des MBS FileMaker Plugin anbieten.

Neue Funktionen für einen besseren Umgang mit dem Plugin

Vielleicht haben sie sich schon einmal gefragt, wie oft sie eigentlich eine MBS FileMaker Plugin Funktion benutzen. Nun können sie es mit der Plugin.CallCounter Funktion einfach herausfinden. Diese Funktion zeigt ihnen, wie oft sie eine MBS FileMaker Plugin Funktion aufrufen. Der Aufruf dieser Funktion zählt auch als Pluginfunktionsaufruf mit.

Für eine bessere Fehleranalyse des MBS FileMaker Plugin gibt es nun die Plugin.InstallSignalHandlers Funktion. Mit dieser Funktion installieren sie einen Signal-Handler. Mit dieser Hilfe können Fehler einfacher erkannt und gefunden werden. Im Normalfall wird diese Funktion nur aufgerufen, wenn wir sie darum bitten mit uns gemeinsam auf die Suche nach dem Grund eines Absturzes unter Linux oder MacOS zu gehen.

Neue Funktionen für die Fehlersuche

Bei der Fehlersuche wird ihnen nun auch die Trace.SetErrorsOnly Funktion helfen. Wenn sie bei gleichzeitiger Nutzung unserer Trace Funktionen diese Funktion aufrufen, werden nur MBS Aufrufe mitgeschrieben, die einen Fehler melden. Das kann ihnen bei der Fehleranalyse hilfreiche Informationen liefern. Sie können auch während dem Laufen eines Scrips abfragen, ob diese Fehlermitschrift eingeschaltet ist. Dazu rufen sie dann die Trace.GetErrorsOnly Funktion auf. Mit Trace.SetWithTimes notieren sie zusätzlich den Zeitstempel eines Log Eintrages. Trace.GetWithTimes liefert zurück ob diese Funktion in einem Programm aufgerufen wurde.

Ihnen steht bei der Fehlersuche in Kommandozeilen Programmen die Shell.GetArguments Funktion zur Verfügung. Diese Funktion liefert uns eine Liste aller Argumente der Shell. Dadurch können wir überprüfen, ob ein Argument fehlt, das wir benötigen. (more)

FileMaker Marketplace started


The FileMaker Marketplace started today. A new way for Claris to present products surrounding their FileMaker software. Currently it is USA and English only. More countries and languages are said to follow later.

MBS FileMaker Plugin is listed with the three nice screenshots we made recently for it:

Check out the over 150 solutions, plugins and modules for FileMaker.

TagLib to read and write ID3v2 Tags in FileMaker


We now use Taglib for our FileMaker plugin to provide tag reading for audio files. Currently it supports both ID3v1 and ID3v2 for MP3 files, Ogg Vorbis comments and ID3 tags and Vorbis comments in FLAC, MPC, Speex, WavPack, TrueAudio, WAV, AIFF, MP4 and ASF files. 

Call Files.AudioTags to read tags and audio properties. You get back a JSON like this:

 

{

"AudioProperties": {

"length": 282,

"bitrate": 128,

"sampleRate": 44100,

"channels": 2

},

"Tags": {

"ARTIST": "John Doe",

"COMMENT": "test comment",

"TITLE": "Hello World"

}

 

}

 

Length is duration of the audio in seconds, bitrate the bits per second, sampleRate the rate in Hz and channels defines how many audio channels you have. The Tags provide the ID3v2 (or other) tags with values.

Use Files.SetAudioTags to write new tags into a file. You pass a JSON with new tags and we either update/add the tag with new text or remove it (NULL value).

 

Please try with next plugin prerelease and let us know whether this works for you. Please do not hesitate to contact us with questions.


MBS FileMaker Plugin, version 9.4pr7


New in this prerelease of version 9.4 of the MBS FileMaker Plugin: Download at monkeybreadsoftware.de/filemaker/files/Prerelease/ or ask for being added to the dropbox shared folder.

WIA Error Codes


If you use WIA classes in MBS Xojo Win Plugin or WIA functions in MBS FileMaker Plugin, you may run into some Windows specific error codes. They all start with hex 8021 and below is a list of Windows Image Acquisition (WIA) error codes.

See also blog articles:
Error CodeMeaningHex CodeDecimal
WIA_ERROR_BUSYThe device is busy. Close any apps that are using this device or wait for it to finish and then try again.80210006-2145320954
WIA_ERROR_COVER_OPENOne or more of the device’s cover is open.80210016-2145320938
WIA_ERROR_DEVICE_COMMUNICATIONCommunication with the WIA device failed. Make sure that the device is powered on and connected to the PC. If the problem persists, disconnect and reconnect the device.8021000A-2145320950
WIA_ERROR_DEVICE_LOCKEDThe device is locked. Close any apps that are using this device or wait for it to finish and then try again.8021000D-2145320947
WIA_ERROR_EXCEPTION_IN_DRIVERThe device driver threw an exception.8021000E-2145320946
WIA_ERROR_GENERAL_ERRORAn unknown error has occurred with the WIA device.80210001-2145320959
WIA_ERROR_INCORRECT_HARDWARE_ SETTINGThere is an incorrect setting on the WIA device.8021000C-2145320948
WIA_ERROR_INVALID_COMMANDThe device doesn't support this command.8021000B-2145320949
WIA_ERROR_INVALID_DRIVER_RESPONSEThe response from the driver is invalid.8021000F-2145320945
WIA_ERROR_ITEM_DELETEDThe WIA device was deleted. It's no longer available.80210009-2145320951
WIA_ERROR_LAMP_OFFThe scanner's lamp is off.80210017-2145320937
WIA_ERROR_MAXIMUM_PRINTER_ ENDORSER_COUNTERA scan job was interrupted because an Imprinter/Endorser item reached the maximum valid value for WIA_IPS_PRINTER_ENDORSER_COUNTER, and was reset to 0. This feature is available with Windows 8 and later versions of Windows.80210021-2145320927
WIA_ERROR_MULTI_FEEDA scan error occurred because of a multiple page feed condition. This feature is available with Windows 8 and later versions of Windows.80210020-2145320928
WIA_ERROR_OFFLINEThe device is offline. Make sure the device is powered on and connected to the PC.80210005-2145320955
WIA_ERROR_PAPER_EMPTYThere are no documents in the document feeder.80210003-2145320957
WIA_ERROR_PAPER_JAMPaper is jammed in the scanner's document feeder.80210002-2145320958
WIA_ERROR_PAPER_PROBLEMAn unspecified problem occurred with the scanner's document feeder.80210004-2145320956
WIA_ERROR_WARMING_UPThe device is warming up.80210007-2145320953
WIA_ERROR_USER_INTERVENTIONThere is a problem with the WIA device. Make sure that the device is turned on, online, and any cables are properly connected.80210008-2145320952
WIA_S_NO_DEVICE_AVAILABLENo scanner device was found. Make sure the device is online, connected to the PC, and has the correct driver installed on the PC.80210015-2145320939

MBS Workshop in der Schweiz


Am 19. November 2019 findet eine MBS Schulung in Meilen am Zürichsee statt. Wir treffen uns ab 9 Uhr im Restaurant Löwen in einem separaten Schulungsraum. Nutzen Sie die Chance die 5000 Funktionen des MBS FileMaker Plugins kennen zu lernen und neue Ideen für Ihre FileMaker Lösungen mit zu nehmen.

Geplantes Programm:
  • Präsentation zum MBS Plugin mit einem Überblick über die Funktionalität.
  • Demonstration von neuen Funktionen in der Version 9.x.
  • Rundgang durch ausgewählte Beispiele
  • Zeit für Fragen
Bitte schicken Sie uns ihre Themenwünsche. Eventuell können wir gerne was zu Kartenleser, Barcodes, Webservices, MacOS Catalina oder Runtime Signieren/Notarisieren mit unterbringen.

Die Teilnahme kostet 150 CHF bzw. 135 Euro. Mittagessen im Restaurant inklusive.
Maximal 12 Teilnehmer. Anmeldung bei uns: Anmelden

Am gleichen Tag lädt die Medio-Ingeno AG zu einem FileMaker Event ein: FMnext XP III
Ab 17:30 Uhr gibt es im Gewölbekeller im Restaurant Löwen in Meilen ein buntes Programm mit Vorträgen zu FileMaker.

MBS FileMaker Plugin, version 9.4pr6


New in this prerelease of version 9.4 of the MBS FileMaker Plugin: Download at monkeybreadsoftware.de/filemaker/files/Prerelease/ or ask for being added to the dropbox shared folder.

FileMaker Magazin - MBS Artikel


Wir haben die Artikel zum MBS Plugin aus dem FileMaker Magazin gesammelt hier online gestellt: FileMaker Magazin Artikel.

Wir empfehlen allen FileMaker Anwender ein Abo vom Magazin und den Kauf der alten Ausgaben. Das FileMaker Magazin ist eine exzellente Quelle von Informationen, Anleitungen und Profitips.


MBS FileMaker Plugin, version 9.4pr5


New in this prerelease of version 9.4 of the MBS FileMaker Plugin: Download at monkeybreadsoftware.de/filemaker/files/Prerelease/ or ask for being added to the dropbox shared folder.

Using Apple's Global Service Exchange web service in FileMaker


Quite a few Apple shops use FileMaker and/or Xojo for their development of in-house tools. A common request is to use Apple's webservices to query warranty status. So today I want to show some scripts on how to do this with the newer REST API. First of course you have to ask Apple for a GSX login which may require some paperwork. Next you need to white list your static IP for their webservice and get the credentials.

 

You request a certificate from Apple, so you generate a private key. The tricky key is to copy the private key with the certificate into one pem file. This pem file is than used with our script. Also please download a standard cacert.pem file with root certificates.

 

Here is an example script to run a query, e.g. to get the authentication token:

# What to do, maybe passed as parameter

Set Variable [ $Query ; Value: "authenticate/token" ] 

Set Variable [ $JSON ; Value: "" ] 

# Some constants you may have

Set Variable [ $shipToCode ; Value: "XXXXXXXXXX" ] 

Set Variable [ $soldToCode ; Value: "XXXXXXXXXX" ] 

Set Variable [ $userIDCode ; Value: "xxxxxxxx@xxxxxxxx.com" ] 

Set Variable [ $ServerURL ; Value: "https://partner-connect-uat.apple.com/gsx/api/" ] 

Set Variable [ $PrivateKeyPassword ; Value: "xxx" ] 

# Where are key files stored?

If [ MBS("IsServer") ] 

# Folder on server with key files

Set Variable [ $path ; Value: "/Library/FileMaker Server/Data/GSX/" ] 

Else

# For local testing also on developer's computer

Set Variable [ $path ; Value: "/Users/admin/Documents/GSX/" ] 

End If

# Query

Set Variable [ $curl ; Value: MBS("CURL.New") ] 

# ----------------------------------------------------------------------------------------

# Build final URL from Server and whatever query you need

Set Variable [ $r ; Value: MBS("CURL.SetOptionURL";$curl; $ServerURL & $Query) ] 

# We pass PEM file with private key and certificate together

Set Variable [ $r ; Value: MBS("CURL.SetOptionSSLCertType"; $curl; "PEM") ] 

Set Variable [ $r ; Value: MBS("CURL.SetOptionKeyPassword"; $curl; $PrivateKeyPassword) ] 

Set Variable [ $r ; Value: MBS("CURL.SetOptionSSLCert"; $curl; $pfad & "cert.pem") ] 

# The usual CURL cacert.pem with valid root certificates

Set Variable [ $r ; Value: MBS("CURL.SetOptionCAINFO"; $curl; $pfad & "cacert.pem") ] 

# We want TLS 1.2

Set Variable [ $r ; Value: MBS("CURL.SetOptionSSLVersion"; $curl; 6) ] 

# Wait maximum 10 seconds for answers

Set Variable [ $r ; Value: MBS("CURL.SetOptionTimeOut"; $curl; 10) ] 

# Headers include shop ID, language and JSON as content type

Set Variable [ $r ; Value: MBS("CURL.SetOptionHTTPHeader"; $curl; "X-Apple-SoldTo: " & $soldToCode; "X-Apple-ShipTo: " & $shipToCode;  "X-Operator-User-ID: " & $userIDCode; "Accept-Language: en_US"; "Content-Type: application/json"; "Accept: application/json") ] 

# For POST, you can add JSON here

If [ Length ( $JSON ) > 0 ] 

Set Variable [ $r ; Value: MBS("CURL.SetOptionPostFields"; $curl; $JSON; "UTF-8") ] 

End If

# Run Transfer

Set Variable [ $r ; Value: MBS("CURL.Perform"; $curl) ] 

# Check results.

Set Variable [ $httpResponse ; Value: MBS( "CURL.GetResponseCode"; $curl ) ] 

Set Variable [ $result ; Value: MBS("CURL.GetResultAsText"; $curl; "UTF8") ] 

Set Variable [ $debug ; Value: MBS("CURL.GetDebugAsText"; $curl; "UTF8") ] 

If [ $r = "OK" and $httpResponse = 200 ] 

# OK

Else

# Handle error

End If

Set Variable [ $r ; Value: MBS("CURL.Cleanup"; $curl) ] 

 

The script is quite universal as it can be used with different URLs to do various operations. When you pass some JSON, the request becomes a POST request and the JSON is sent. The JSON can be copied from Apple's website and a lot of requests work very nice via MBS Plugin. For example a request with URL "diagnostics/suites?deviceId=" followed by the Device ID (e.g. iPhone's serial number), can query the available diagnostics suites.

We hope you have no problems to implement GSX REST Service into your solution with this help. 


FileMaker Stammtisch SaarLorLux


Im Saarland trifft sich der FileMaker Stammtisch SaarLorLux:

Der FileMaker-Stammtisch findet nächste Woche am Mittwoch, den 11.09.2019, ab 18 Uhr wie gewohnt im Schulungsraum bei ÖkoFEN in Überherrn statt.

Themen:
• Neues in FileMaker Version 18
• Terminplanung Beispiele: Termine erstellen aus abstrakten Terminvorgaben, Bsp. Terminkalender Arztpraxis, Bsp. ToDos Steuerberatungskanzlei

siehe meetup.com/de-DE/FileMaker-Stammtisch-SaarLorLux/


Falls sonst noch Bedarf an Schulung, vor Ort Entwicklung oder FileMaker/Xojo Hilfe besteht, bitte wegen Terminfindung bald bei uns melden.

PS: Für die MBS Plugin Schulungen bei der Denkform und in Hamburg gibt es noch freie Plätze.

Sechs Wochen bis zur FileMaker Konferenz 2019 in Hamburg


Vom 16. bis 19. Oktober 2019 findet die zehnte deutschsprachige FileMaker Konferenz in Hamburg, Deutschland statt. FileMaker Anwender und Entwickler sind herzlich eingeladen sich anzumelden.

Anmeldungen für Konferenz und MBS Schulung sind noch möglich!

Die Veranstalter vom Verein FM Konferenz erwarten auch 2019 rund 180 Entwickler, Anwender, IT-Fachleute und Entscheidungsträger aus Wirtschaft, Bildung und Verwaltung. Rund um über 25 Fachvorträge und Workshops wird es viel Zeit zum Vernetzen in den gemeinsamen Pausen und beim Abendprogramm geben.

Dieses Jahr gibt es wieder eine MBS Plugin Workshop, diesmal am 16. Oktober 2019 von ca. 9 bis 17 Uhr.
Anmeldung bei Monkeybread Software.

FileMaker Runtimes and hardened MacOS runtime


For Mac applications, there are two runtime modes they can use. The older one left for compatibility to older applications and the newer with enhanced security features. The hardened runtime checks code signatures and kills the application if unsigned code is detected. This makes hacking the application more difficult and provides better security.

The hardened runtime is required to notarize the application, which itself is required for application distribution to the upcoming MacOS 10.15 Catalina release to avoid annoying gate keeper dialogs. Some of those show already in MacOS 10.14.6, so we notarize our plugin downloads already.

See also Hardened Runtime Entitlements, Code Signing Services and Notarizing Your App Before Distribution on Apple website. (more)

Barcodes supported by MBS Plugins


MBS Plugin supports generating over 80 barcode types, so we made a new graphics to show a few common barcodes:

Wether you need to make UPC or EAN in various versions, QR Code in normal or micro size, we cover them all.

Available with Barcode functions in our MBS FileMaker Plugin and in BarcodeGeneratorMBS class in our MBS Xojo Barcode Plugin.

Archives

Sep 2019
Aug 2019
Jul 2019
Jun 2019
May 2019
Apr 2019
Mar 2019
Feb 2019
Jan 2019
Dec 2018
Nov 2018
Oct 2018
Sep 2018
Aug 2018
Jul 2018
Jun 2018
May 2018
Apr 2018
Mar 2018
Feb 2018
Jan 2018
Dec 2017
Nov 2017
Oct 2017
Sep 2017
Aug 2017
Jul 2017
Jun 2017
May 2017
Apr 2017
Mar 2017
Feb 2017
Jan 2017
Dec 2016
Nov 2016
Oct 2016
Sep 2016
Aug 2016
Jul 2016
Jun 2016
May 2016
Apr 2016
Mar 2016
Feb 2016
Jan 2016
Dec 2015
Nov 2015
Oct 2015
Sep 2015
Aug 2015
Jul 2015
Jun 2015
May 2015
Apr 2015
Mar 2015
Feb 2015
Jan 2015
Dec 2014
Nov 2014
Oct 2014
Sep 2014
Aug 2014
Jul 2014
Jun 2014
May 2014
Apr 2014
Mar 2014
Feb 2014
Jan 2014
Dec 2013
Nov 2013
Oct 2013
Sep 2013
Aug 2013
Jul 2013
Jun 2013
May 2013
Apr 2013
Mar 2013
Feb 2013
Jan 2013
Dec 2012
Nov 2012
Oct 2012
Sep 2012
Aug 2012
Jul 2012
Jun 2012
May 2012
Apr 2012
Mar 2012
Feb 2012
Jan 2012
Dec 2011
Nov 2011
Oct 2011
Sep 2011
Aug 2011
Jul 2011
Jun 2011
May 2011
Apr 2011
Mar 2011
Feb 2011
Jan 2011
Dec 2010
Nov 2010
Oct 2010
Sep 2010
Aug 2010
Jul 2010
Jun 2010
May 2010
Apr 2010
Mar 2010
Feb 2010
Jan 2010
Dec 2009
Nov 2009
Oct 2009
Sep 2009
Aug 2009
Jul 2009
Apr 2009
Mar 2009
Feb 2009
Dec 2008
Nov 2008
Oct 2008
Aug 2008
May 2008
Apr 2008
Mar 2008
Feb 2008