Hallo erstmal, ich bin neu hier. Hab gestern zum ersten Mal myBB unter
schnaeppchenforum.com installiert und bin immer mehr davon begeistert.
Was mir zu meinem (Affiliate-)Glück noch fehlt, wäre ein Plugin, was von Usern eingegebe Links überprüft bzw. umwandelt.
Jeder eingegebene Link nach draußen soll also nach gewissen Regeln umgewandelt werden.
Was das soll? Ich bin z.B. Amazon-Partner und möchte alle nach Amazon gehenden Links mit meiner Partner-Id (reflink) versehen.
Ich freue mich über jede Antwort.
Dazu müsstest du die Funktion mycode_parse_url in der inc/class_parser.php anpassen.
Danke für den Hinweis, werde ich mir heute Abend mal anschauen...
Wie mache ich denn ein plugin daraus, damit
a) mehr Leute etwas davon haben?
b) ich bei einer neuen Version nicht wieder patchen muss?
Das mit den Reflinks habe ich inzwischen geregelt, aber ein neues Problem:
Links, die eckige Klammern enthalten werden von mybb nicht richtig erkannt/umgesetzt.
http://schnaeppchenforum.com/videospiele...t-253.html
Wenn man die Klammern durch %5B bzw. %5D ersetzt, klappt es, aber das kann man ja keinem User zumuten...
Ich hab auch schon eine Ersetz-Methode gebastelt, weiß aber (noch) nicht, an welcher Stelle die [url][/url] geparset werden. Wenn mir da einer helfen könnte...
Sorry, hab's selbst gefunden:
Zitat:function cache_mycode()
...
$standard_mycode['url_simple']['regex'] = "#\[url\]([a-z]+?://)([^\r\n\"\[<]+?)\[/url\]#sei";
$standard_mycode['url_simple']['replacement'] = "\$this->mycode_parse_url(\"$1$2\")";
$standard_mycode['url_simple2']['regex'] = "#\[url\]([^\r\n\"\[<]+?)\[/url\]#ei";
$standard_mycode['url_simple2']['replacement'] = "\$this->mycode_parse_url(\"$1\")";
$standard_mycode['url_complex']['regex'] = "#\[url=([a-z]+?://)([^\r\n\"\[<]+?)\](.+?)\[/url\]#esi";
$standard_mycode['url_complex']['replacement'] = "\$this->mycode_parse_url(\"$1$2\", \"$3\")";
$standard_mycode['url_complex2']['regex'] = "#\[url=([^\r\n\"\[<&\(\)]+?)\](.+?)\[/url\]#esi";
$standard_mycode['url_complex2']['replacement'] = "\$this->mycode_parse_url(\"$1\", \"$2\")";
Aber so einfach ist es leider nicht, wie ich zuerst hoffte. [xx] wird ja als BBCode erkannt...
Hat hier keiner eine Idee? Das Problem dürfte ich doch nicht alleine haben, oder?
Habe den Workaround dort auch mal erwähnt...
In dem RegEx-Teil
Zitat:([^\r\n\"\[<]+?)
der den Teil der URL parset, der nach http:// folgt, kann doch eigentlich kein BB-Code enthalten sein, höchstens umschliessend...
Also sollte
Zitat:([^\r\n\"<]+?)
doch schon eine Lösung darstellen??? Wer kennt sich hier gut mit RegEx aus?