Brancher inc/distant recuperer_url() sur une librairie récente
#3973
Open
opened 6 years ago by b_b
·
8 comments
No Branch/Tag Specified
1.8
1.9.1
1.9.2
2.0
2.1
3.0
3.1
3.2
4.0
4.1
4.2
boutons-danger
coquille_doc
debug_ecrire_fichier
dev-sortable
dev/autoloader
dev/hasard_fixe
dev/instituer_ergo
dev/issue_4626_menu_squelettes
dev/issue_5447_exporter_csv
dev_infos_image
fix/valider_url_distante
fix_issue_5454
fix_modifier_login
issue_4101
issue_4678
issue_4705
issue_4717
issue_4836
issue_4946
issue_5258
issue_5344
issue_5427_bis
issue_5483_find_script_jquery
issue_5487_info_maj
master
v1.8.3+b
v1.9.1+i
v1.9.2+f
v1.9.2+g
v1.9.2+h
v1.9.2+i
v1.9.2+j
v1.9.2+k
v1.9.2+m
v1.9.2+n
v1.9.2+o
v1.9.2+p
v2.0.0
v2.0.1
v2.0.10
v2.0.11
v2.0.12
v2.0.13
v2.0.14
v2.0.15
v2.0.16
v2.0.17
v2.0.18
v2.0.19
v2.0.2
v2.0.20
v2.0.21
v2.0.22
v2.0.23
v2.0.24
v2.0.25
v2.0.26
v2.0.3
v2.0.5
v2.0.6
v2.0.7
v2.0.8
v2.0.9
v2.1.0
v2.1.1
v2.1.10
v2.1.11
v2.1.12
v2.1.13
v2.1.14
v2.1.15
v2.1.16
v2.1.17
v2.1.18
v2.1.19
v2.1.2
v2.1.20
v2.1.21
v2.1.22
v2.1.23
v2.1.24
v2.1.25
v2.1.26
v2.1.27
v2.1.28
v2.1.29
v2.1.3
v2.1.30
v2.1.4
v2.1.5
v2.1.6
v2.1.7
v2.1.8
v2.1.9
v3.0.0
v3.0.0-alpha.1
v3.0.0-beta
v3.0.0-beta.2
v3.0.0-rc
v3.0.1
v3.0.10
v3.0.11
v3.0.12
v3.0.13
v3.0.14
v3.0.15
v3.0.16
v3.0.17
v3.0.18
v3.0.19
v3.0.2
v3.0.20
v3.0.21
v3.0.22
v3.0.23
v3.0.24
v3.0.25
v3.0.26
v3.0.27
v3.0.28
v3.0.3
v3.0.4
v3.0.5
v3.0.6
v3.0.7
v3.0.8
v3.0.9
v3.1.0
v3.1.0-alpha
v3.1.0-beta
v3.1.0-rc
v3.1.0-rc.2
v3.1.0-rc.3
v3.1.1
v3.1.10
v3.1.11
v3.1.12
v3.1.13
v3.1.14
v3.1.15
v3.1.2
v3.1.3
v3.1.4
v3.1.5
v3.1.6
v3.1.7
v3.1.8
v3.1.9
v3.2-alpha.1
v3.2.0
v3.2.0-alpha.1
v3.2.0-beta
v3.2.0-beta.2
v3.2.0-beta.3
v3.2.1
v3.2.10
v3.2.11
v3.2.12
v3.2.13
v3.2.14
v3.2.15
v3.2.16
v3.2.17
v3.2.2
v3.2.3
v3.2.4
v3.2.5
v3.2.6
v3.2.7
v3.2.8
v3.2.9
v4.0.0
v4.0.0-alpha
v4.0.0-beta
v4.0.1
v4.0.2
v4.0.3
v4.0.4
v4.0.5
v4.0.6
v4.0.7
v4.0.8
v4.0.9
v4.1.0
v4.1.0-alpha
v4.1.0-beta
v4.1.0-rc
v4.1.1
v4.1.2
v4.1.3
v4.1.4
v4.1.5
v4.1.6
v4.1.7
v4.2.0-alpha
v4.2.0-alpha2
Labels
Amélioration, nouvelle fonctionnalité APIs authentification base de données bug
Ca ne fonctionne pas code généré compilo css divers documentation doublon
Ce ticket est un doublon ergonomie espace privé filtres et balises formulaires Inscription installation invalide
Ticket invalide javascript langues LDAP plugin PostgreSQL refusé
Ignoré, c'est comme Ca... sécurité traduction
Apply labels
Clear labels
accessibilité
amélioration
Amélioration, nouvelle fonctionnalité APIs authentification base de données bug
Ca ne fonctionne pas code généré compilo css divers documentation doublon
Ce ticket est un doublon ergonomie espace privé filtres et balises formulaires Inscription installation invalide
Ticket invalide javascript langues LDAP plugin PostgreSQL refusé
Ignoré, c'est comme Ca... sécurité traduction
No Label
accessibilité
amélioration
APIs
authentification
base de données
bug
code généré
compilo
css
divers
documentation
doublon
ergonomie
espace privé
filtres et balises
formulaires
Inscription
installation
invalide
javascript
langues
LDAP
plugin
PostgreSQL
refusé
sécurité
traduction
Milestone
Set milestone
Clear milestone
No items
No Milestone
Projects
Clear projects
No project
Assignees
Assign users
Clear assignees
No Assignees
4 Participants
Notifications
Due Date
The due date is invalid or out of range. Please use the format 'yyyy-mm-dd'.
No due date set.
Dependencies
This issue currently doesn't have any dependencies.
Reference in new issue
There is no content yet.
Delete Branch '%!s(MISSING)'
Deleting a branch is permanent. It CANNOT be undone. Continue?
No
Yes
Comme le disait fil sur #3967 :
Peut-être qu'une lib comme https://www.phpcurlclass.com/ pourrait faire l'affaire ?
why not, du moment qu'on maintient l'api
recuperer_url
/recuperer_page
pour ne rien casser du code existant.(Je veux bien m'y coller)
Assigné à cedric
Statut changé à En cours
Super, il faudrait peut-être commencer par un travail de recensement des librairies disponibles pour ça ? (je peux m'y coller)
Bonjour,
Suite à un changement de machine pour nos SPIP (de WIMP vers LAMP (centos)) de nombreux flux RSS ne fonctionnaient plus, la cause : la fonction 'recuperer_url' !!!.
J'ai donc réécrit le corps de cette fonction avec la biblio PHP CURL a partir du code dans SPIP 3.2.0 (je sais que je suis en retard d'une version).
Je vous le livre comme je viens de le finir après un léger debug.
Normalement, ce code doit être compatible avec l'ancienne fonction, il donne en plus en sortie ['range'] qui permet de savoir si un partial content peut être délivré.
Il ne prend plus en compte les entrées ['refuser_gz'], ['version_http'] et ['boundary'] et l'entrée ['data'] doit être compatible avec celle de 'curl_setopt : CURLOPT_POSTFIELDS'.
Si des gens veulent la tester et l'améliorer : bienvenue.
Petit nota : SPIP laisse le fichier créer dans cette fonction (['file']) dans le tmp sans le détruire (version de base idem) : accumulation !
Merci c'est une bonne base de départ !
Comme on a du vieux code legacy qui traine partout il faudrait faire le support des boundary et data et/ou la remise en forme de cette dernière dans les cas exotiques.
Ou simplement deleguer au vieux code legacy quand on a ces 2 entrées là (du coup la majorité des appels passent bien par curl, et les cas un peu tordus par l'ancien code, mais au moins continuent de marcher)
Dans ton cas je pense que c'est juste le bug sur ssl/tls qui te bloquait, qu'on a corrigé dans la dernière release des 3.1/3/2
Merci pour la proposition Eric :) Si tu es motivé, tu peux proposer le patch au format diff ou directement sur https://git.spip.net/ après l'avoir affiné suite aux remarques de Cedric.
Bonjour,
Pour les datas, je pense que qu'il y a une compatibilité entre celles attendus par la fonction 'recuperer_url' et celles attendue par l'option 'CURLOPT_POSTFIELDS' :
Je n'ai pas trouver de littérature sur le formatage de data en mode chaine pour 'recuperer_url' et pas analyser comment les fonctions dans 'recuperer_url' l'attendait, mais les tableaux doivent être compatibles non ?. Plus besoin de fournir le boundary qui n'est utile que pour les tableaux.
Pour ce qui est de mettre dans le git SPIP, je vais voir comment ça marche...
Pour les datas, il faut faire de la conversion de format si besoin.
Je note ici pour mémoire et test de support d'un cas d'utilisation du format string pour poster du JSON vers une API qui attend un format json :
https://zone.spip.net/trac/spip-zone/browser/spip-zone/plugins/mailshot/trunk/lib/mailjet-api-php/mailjet-3.php#L116
Il me semble que Guzzle est relativement connu et utilisé pour ce genre de circonstance (et permettrait bien d’autres choses)
http://docs.guzzlephp.org/en/stable/
(et même du json http://docs.guzzlephp.org/en/stable/request-options.html#json)