forked from Rkallenkoot/PONIpar
-
Notifications
You must be signed in to change notification settings - Fork 0
/
example.php
86 lines (63 loc) · 2.77 KB
/
example.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<?php
declare(encoding='UTF-8');
// Require the PONIpar code.
require_once 'src/PONIpar.php';
// Create a new parser.
$parser = new PONIpar\Parser();
// This is how configuring the parser to read a file works. You can specify any
// stream wrapper supported by PHP here, but a plain and simple file name as
// well. This is simply a convenience method for opening a reading stream and
// passing it to useStream().
$parser->useFile('http://www.example.com/onix.xml');
// This is how configuring the parser to read from standard input works. It is
// simply a convenience method for passing 'php://stdin'' to useFile().
$parser->useStdIn();
// This is how to configure the parser to read from an already open stream
// works. We open a temporary stream for example purposes.
$parser->useStream(fopen('php://temp', 'r'));
// But for this example, we will be parsing from a string.
// Note that parsing from a string means that the whole string will have to be
// loaded in memory before parsing it. You should really take advantage of
// PONIpar’s streaming ability and pass a string only if there’s not a lot of
// data in it (less than 5 MB) and you don’t get it from a streamable source.
// The document we are going to parse.
// TODO: This should probably be a better example.
$doc = <<<ONIX
<ONIXMessage>
<Header />
<Product>
<ProductIdentifier>
<ProductIDType>03</ProductIDType>
<IDValue>0123456789012</IDValue>
</ProductIdentifier>
<ProductIdentifier>
<ProductIDType>01</ProductIDType>
<IDTypeName>example type</IDTypeName>
<IDValue>foobar</IDValue>
</ProductIdentifier>
</Product>
</ONIXMessage>
ONIX;
// This is how to specify a string for parsing. PONIpar will internally open a
// temporary stream (php://temp), write the string in it and rewind the file
// pointer to start reading from there.
$parser->useString($doc);
// Now we set a product handler. This handler will be called during the parsing
// process as soon as a single product has been parsed completely. You handle
// the product (write it to the database, convert it to something else or
// whatever) and then it will be removed from RAM again (unless you decide to
// store it somewhere, which you probably shouldn’t). That way, we can deal with
// a virtually unlimited number of products without having to worry about
// hitting memory limits.
$parser->setProductHandler(function ($product) {
// Retrieve the GTIN-13 for the product and print it.
$gtin13 = $product->getIdentifier(
PONIpar\ProductIdentifierProductSubitem::TYPE_GTIN13
);
echo "$gtin13\n";
});
// Finally, we instruct PONIpar to start reading the stream and parse the ONIX
// data. It will not stop during the process (at least not if there are no
// errors), but call our product handler once for each product.
$parser->parse();
?>