Inkscape and OpenAudit

Post about projects that use Inkscape for web design.
ahull
Posts: 7
Joined: Sat Jun 07, 2008 2:34 am

Inkscape and OpenAudit

Postby ahull » Sat Jun 07, 2008 2:55 am

I am looking for a bit of inspiration (it is Friday afternoon, so I am probably not alone here).

As a developer of OpenAudit,(http://www.open-audit.org/) I added some code to this network auditing application that allows it to generate network diagrams from the data stored from the network audits performed by OpenAudit.

It (naturally) uses SVGs and Inkscape. I was looking for a bit of inspiration in this regard, since the diagrams are in my opinion a little bit bland (read mind boringly dull). The application uses the Tango icon set, and php, and I was wondering how best to give the diagrams a bit of Zing.

The idea would be to use the PHP backend to generate the SVG file, (which it currently does), and also if possible to add in backgrounds, links, web clouds, pretty pictures, text, flashy lights, bells and whistles of the sort that will impress "Boardoom" types.

Its a tall order, I know... Interesting Network Diagrams... in fact probably a contradiction in terms, but if anybody can do it, the Inkscape Forum can... (OK I think I went a little far with the motivational nonsense there).

All comments (including go away and get a life) welcome. :twisted:

User avatar
microUgly
Site Admin
Posts: 2985
Joined: Sat Jun 02, 2007 3:13 pm
Contact:

Re: Inkscape and OpenAudit

Postby microUgly » Sat Jun 07, 2008 9:03 am

Do you have examples of how these diagrams look now?

ahull
Posts: 7
Joined: Sat Jun 07, 2008 2:34 am

Re: Inkscape and OpenAudit

Postby ahull » Sun Jun 08, 2008 7:11 pm

I'll post this as source, so you can see the structure of the SVG generated by the PHP page.
I can also post the PHP if you like.

The basic idea is to select a list of machines (for example all machines on a particular subnet), click a link under the list and have the PHP generate a diagram form the list. Several diagrams can then be pasted together in Inkskape, but as I say, there is a distinct lack of glitz in the output.

Functional, but dull would be my description (and I wrote the code, so I wont be offending anyone with that remark).



Code: Select all

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Created with Inkscape (http://www.inkscape.org/) -->
<svg
   xmlns:dc="http://purl.org/dc/elements/1.1/"
   xmlns:cc="http://creativecommons.org/ns#"
   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
   xmlns:svg="http://www.w3.org/2000/svg"
   xmlns="http://www.w3.org/2000/svg"
   xmlns:xlink="http://www.w3.org/1999/xlink"
   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
   version="1.0"
   width="1052.3622"
   height="744.09448"
   id="svg2"
   sodipodi:version="0.32"
   inkscape:version="0.46+devel"
   sodipodi:docname="NetworkDiagramExample.svg"
   inkscape:output_extension="org.inkscape.output.svg.inkscape">
  <metadata
     id="metadata267">
    <rdf:RDF>
      <cc:Work
         rdf:about="">
        <dc:format>image/svg+xml</dc:format>
        <dc:type
           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
      </cc:Work>
    </rdf:RDF>
  </metadata>
  <sodipodi:namedview
     inkscape:window-height="977"
     inkscape:window-width="1280"
     inkscape:pageshadow="2"
     inkscape:pageopacity="0.0"
     guidetolerance="10.0"
     gridtolerance="10.0"
     objecttolerance="10.0"
     borderopacity="1.0"
     bordercolor="#666666"
     pagecolor="#ffffff"
     id="base"
     showgrid="false"
     inkscape:zoom="5.8484213"
     inkscape:cx="102.03253"
     inkscape:cy="711.69064"
     inkscape:window-x="-4"
     inkscape:window-y="-4"
     inkscape:current-layer="svg2" />
  <defs
     id="defs4">
    <inkscape:perspective
       sodipodi:type="inkscape:persp3d"
       inkscape:vp_x="0 : 372.04724 : 1"
       inkscape:vp_y="0 : 1000 : 0"
       inkscape:vp_z="1052.3622 : 372.04724 : 1"
       inkscape:persp3d-origin="526.18109 : 248.03149 : 1"
       id="perspective269" />
    <marker
       refX="0"
       refY="0"
       orient="auto"
       style="overflow:visible"
       id="DiamondS">
      <path
         d="M 0,-7.0710768 L -7.0710894,0 L 0,7.0710589 L 7.0710462,0 L 0,-7.0710768 z "
         transform="scale(0.2,0.2)"
         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none"
         id="path3361" />
    </marker>
  </defs>
  <a
     xlink:href="http://www.w3.org"
     id="a8"
     transform="translate(-20,-9)" />
  <image
     xlink:href="C:\Program Files\xampp\htdocs\openaudit\images\server.png"
     x="30.5"
     y="21.5"
     width="16"
     height="16"
     id="3" />
  <text
     x="30.5"
     y="21.5"
     style="font-size:5px;text-align:center;text-anchor:middle"
     id="text4"
     xml:space="preserve"><tspan
       x="38.5"
       y="43.5"
       id="tspan5">  MyServer</tspan></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text6"
     xml:space="preserve"><tspan
       x="38.5"
       y="47.099998"
       id="tspan7">ip: 192.168.051.001 </tspan></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text8"
     xml:space="preserve"><tspan
       x="38.5"
       y="49.5"
       id="tspan9">User: administrator </tspan></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text10"
     xml:space="preserve"><tspan
       x="38.5"
       y="51.900002"
       id="tspan11">Domain: domain.local </tspan></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text12"
     xml:space="preserve"><tspan
       x="38.5"
       y="54.299999"
       id="tspan13">Vendor: Dell Computer Corporation </tspan></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text14"
     xml:space="preserve"><tspan
       x="38.5"
       y="56.699997"
       id="tspan15">Model: PowerEdge 1800 </tspan></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text16"
     xml:space="preserve"><tspan
       x="38.5"
       y="59.099998"
       id="tspan17">Serial #: ABC1234J </tspan></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text18"
     xml:space="preserve"><tspan
       x="38.5"
       y="62.699997"
       id="tspan19">Memory: 1023 Mb  </tspan></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text20"
     xml:space="preserve"><tspan
       x="38.5"
       y="65.099998"
       id="tspan21" /></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text22"
     xml:space="preserve"><tspan
       x="38.5"
       y="67.5"
       id="tspan23" /></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text24"
     xml:space="preserve"><tspan
       x="38.5"
       y="69.900002"
       id="tspan25" /></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text26"
     xml:space="preserve"><tspan
       x="38.5"
       y="72.300003"
       id="tspan27" /></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text28"
     xml:space="preserve"><tspan
       x="38.5"
       y="74.699997"
       id="tspan29" /></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text30"
     xml:space="preserve"><tspan
       x="38.5"
       y="77.099998"
       id="tspan31" /></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text32"
     xml:space="preserve"><tspan
       x="38.5"
       y="79.5"
       id="tspan33" /></text>
  <text
     x="30.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text34"
     xml:space="preserve"><tspan
       x="38.5"
       y="81.900002"
       id="tspan35" /></text>
  <path
     id="path1"
     style="fill:none;stroke:#000000;stroke-width:0.30000001;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:0.9, 0.3;stroke-dashoffset:0;marker-start:url(#DiamondS);marker-mid:url(#DiamondS);marker-end:url(#DiamondS);display:inline"
     d="m 50.5,30.5 10,20" />
  <a
     xlink:href="http://www.w3.org"
     id="a45"
     transform="translate(-20,-9)" />
  <image
     xlink:href="C:\Program Files\xampp\htdocs\openaudit\images\computer.png"
     x="100.5"
     y="21.5"
     width="16"
     height="16"
     id="63" />
  <text
     x="100.5"
     y="21.5"
     style="font-size:5px;text-align:center;text-anchor:middle"
     id="text64"
     xml:space="preserve"><tspan
       x="108.5"
       y="43.5"
       id="tspan65">Workstation1</tspan></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text66"
     xml:space="preserve"><tspan
       x="108.5"
       y="47.099998"
       id="tspan67">ip: 192.168.051.020 </tspan></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text68"
     xml:space="preserve"><tspan
       x="108.5"
       y="49.5"
       id="tspan69">User: DOMAIN\reception </tspan></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text70"
     xml:space="preserve"><tspan
       x="108.5"
       y="51.900002"
       id="tspan71">Domain: domain.local </tspan></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text72"
     xml:space="preserve"><tspan
       x="108.5"
       y="54.299999"
       id="tspan73">Vendor: Dell Computer Corporation </tspan></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text74"
     xml:space="preserve"><tspan
       x="108.5"
       y="56.699997"
       id="tspan75">Model: OptiPlex 170L </tspan></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text76"
     xml:space="preserve"><tspan
       x="108.5"
       y="59.099998"
       id="tspan77">Serial #: 1234ABC </tspan></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text78"
     xml:space="preserve"><tspan
       x="108.5"
       y="62.699997"
       id="tspan79">Memory: 765 Mb  </tspan></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text80"
     xml:space="preserve"><tspan
       x="108.5"
       y="65.099998"
       id="tspan81" /></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text82"
     xml:space="preserve"><tspan
       x="108.5"
       y="67.5"
       id="tspan83" /></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text84"
     xml:space="preserve"><tspan
       x="108.5"
       y="69.900002"
       id="tspan85" /></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text86"
     xml:space="preserve"><tspan
       x="108.5"
       y="72.300003"
       id="tspan87" /></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text88"
     xml:space="preserve"><tspan
       x="108.5"
       y="74.699997"
       id="tspan89" /></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text90"
     xml:space="preserve"><tspan
       x="108.5"
       y="77.099998"
       id="tspan91" /></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text92"
     xml:space="preserve"><tspan
       x="108.5"
       y="79.5"
       id="tspan93" /></text>
  <text
     x="100.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text94"
     xml:space="preserve"><tspan
       x="108.5"
       y="81.900002"
       id="tspan95" /></text>
  <path
     id="path61"
     style="fill:none;stroke:#000000;stroke-width:0.30000001;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:0.9, 0.3;stroke-dashoffset:0;marker-start:url(#DiamondS);marker-mid:url(#DiamondS);marker-end:url(#DiamondS);display:inline"
     d="m 120.5,30.5 10,20" />
  <a
     xlink:href="http://www.w3.org"
     id="a82"
     transform="translate(-20,-9)" />
  <image
     xlink:href="C:\Program Files\xampp\htdocs\openaudit\images\computer.png"
     x="170.5"
     y="21.5"
     width="16"
     height="16"
     id="123" />
  <text
     x="170.5"
     y="21.5"
     style="font-size:5px;text-align:center;text-anchor:middle"
     id="text124"
     xml:space="preserve"><tspan
       x="178.5"
       y="43.5"
       id="tspan125">Workstation2</tspan></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text126"
     xml:space="preserve"><tspan
       x="178.5"
       y="47.099998"
       id="tspan127">ip: 192.168.051.023 </tspan></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text128"
     xml:space="preserve"><tspan
       x="178.5"
       y="49.5"
       id="tspan129">User: DOMAIN\PSmith </tspan></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text130"
     xml:space="preserve"><tspan
       x="178.5"
       y="51.900002"
       id="tspan131">Domain: domain.local </tspan></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text132"
     xml:space="preserve"><tspan
       x="178.5"
       y="54.299999"
       id="tspan133">Vendor: Dell Computer Corporation </tspan></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text134"
     xml:space="preserve"><tspan
       x="178.5"
       y="56.699997"
       id="tspan135">Model: OptiPlex 170L </tspan></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text136"
     xml:space="preserve"><tspan
       x="178.5"
       y="59.099998"
       id="tspan137">Serial #: 1231234 </tspan></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text138"
     xml:space="preserve"><tspan
       x="178.5"
       y="62.699997"
       id="tspan139">Memory: 758 Mb  </tspan></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text140"
     xml:space="preserve"><tspan
       x="178.5"
       y="65.099998"
       id="tspan141" /></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text142"
     xml:space="preserve"><tspan
       x="178.5"
       y="67.5"
       id="tspan143" /></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text144"
     xml:space="preserve"><tspan
       x="178.5"
       y="69.900002"
       id="tspan145" /></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text146"
     xml:space="preserve"><tspan
       x="178.5"
       y="72.300003"
       id="tspan147" /></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text148"
     xml:space="preserve"><tspan
       x="178.5"
       y="74.699997"
       id="tspan149" /></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text150"
     xml:space="preserve"><tspan
       x="178.5"
       y="77.099998"
       id="tspan151" /></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text152"
     xml:space="preserve"><tspan
       x="178.5"
       y="79.5"
       id="tspan153" /></text>
  <text
     x="170.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text154"
     xml:space="preserve"><tspan
       x="178.5"
       y="81.900002"
       id="tspan155" /></text>
  <path
     id="path121"
     style="fill:none;stroke:#000000;stroke-width:0.30000001;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:0.9, 0.3;stroke-dashoffset:0;marker-start:url(#DiamondS);marker-mid:url(#DiamondS);marker-end:url(#DiamondS);display:inline"
     d="m 190.5,30.5 10,20" />
  <a
     xlink:href="http://www.w3.org"
     id="a119"
     transform="translate(-20,-9)" />
  <image
     xlink:href="C:\Program Files\xampp\htdocs\openaudit\images\computer.png"
     x="240.5"
     y="21.5"
     width="16"
     height="16"
     id="183" />
  <text
     x="240.5"
     y="21.5"
     style="font-size:5px;text-align:center;text-anchor:middle"
     id="text184"
     xml:space="preserve"><tspan
       x="248.5"
       y="43.5"
       id="tspan185">Workstation3</tspan></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text186"
     xml:space="preserve"><tspan
       x="248.5"
       y="47.099998"
       id="tspan187">ip: 192.168.051.016 </tspan></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text188"
     xml:space="preserve"><tspan
       x="248.5"
       y="49.5"
       id="tspan189">User: DOMAIN\PFrench </tspan></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text190"
     xml:space="preserve"><tspan
       x="248.5"
       y="51.900002"
       id="tspan191">Domain: domain.local </tspan></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text192"
     xml:space="preserve"><tspan
       x="248.5"
       y="54.299999"
       id="tspan193">Vendor: Dell Computer Corporation </tspan></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text194"
     xml:space="preserve"><tspan
       x="248.5"
       y="56.699997"
       id="tspan195">Model: OptiPlex 170L </tspan></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text196"
     xml:space="preserve"><tspan
       x="248.5"
       y="59.099998"
       id="tspan197">Serial #: QWERTYJ </tspan></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text198"
     xml:space="preserve"><tspan
       x="248.5"
       y="62.699997"
       id="tspan199">Memory: 765 Mb  </tspan></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text200"
     xml:space="preserve"><tspan
       x="248.5"
       y="65.099998"
       id="tspan201" /></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text202"
     xml:space="preserve"><tspan
       x="248.5"
       y="67.5"
       id="tspan203" /></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text204"
     xml:space="preserve"><tspan
       x="248.5"
       y="69.900002"
       id="tspan205" /></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text206"
     xml:space="preserve"><tspan
       x="248.5"
       y="72.300003"
       id="tspan207" /></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text208"
     xml:space="preserve"><tspan
       x="248.5"
       y="74.699997"
       id="tspan209" /></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text210"
     xml:space="preserve"><tspan
       x="248.5"
       y="77.099998"
       id="tspan211" /></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text212"
     xml:space="preserve"><tspan
       x="248.5"
       y="79.5"
       id="tspan213" /></text>
  <text
     x="240.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text214"
     xml:space="preserve"><tspan
       x="248.5"
       y="81.900002"
       id="tspan215" /></text>
  <path
     id="path181"
     style="fill:none;stroke:#000000;stroke-width:0.30000001;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:0.9, 0.3;stroke-dashoffset:0;marker-start:url(#DiamondS);marker-mid:url(#DiamondS);marker-end:url(#DiamondS);display:inline"
     d="m 260.5,30.5 10,20" />
  <a
     xlink:href="http://www.w3.org"
     id="a156"
     transform="translate(-20,-9)" />
  <image
     xlink:href="C:\Program Files\xampp\htdocs\openaudit\images\computer.png"
     x="310.5"
     y="21.5"
     width="16"
     height="16"
     id="243" />
  <text
     x="310.5"
     y="21.5"
     style="font-size:5px;text-align:center;text-anchor:middle"
     id="text244"
     xml:space="preserve"><tspan
       x="318.5"
       y="43.5"
       id="tspan245">Workstation4</tspan></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text246"
     xml:space="preserve"><tspan
       x="318.5"
       y="47.099998"
       id="tspan247">ip: 192.168.051.018 </tspan></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text248"
     xml:space="preserve"><tspan
       x="318.5"
       y="49.5"
       id="tspan249">User: DOMAIN\WJones </tspan></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text250"
     xml:space="preserve"><tspan
       x="318.5"
       y="51.900002"
       id="tspan251">Domain: domain.local </tspan></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text252"
     xml:space="preserve"><tspan
       x="318.5"
       y="54.299999"
       id="tspan253">Vendor: Dell Computer Corporation </tspan></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text254"
     xml:space="preserve"><tspan
       x="318.5"
       y="56.699997"
       id="tspan255">Model: OptiPlex 170L </tspan></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text256"
     xml:space="preserve"><tspan
       x="318.5"
       y="59.099998"
       id="tspan257">Serial #: LALALA</tspan></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     xml:space="preserve"
     id="text3226"><tspan
       x="318.5"
       y="59.099998"
       id="tspan3228"> </tspan></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text258"
     xml:space="preserve"><tspan
       x="318.5"
       y="62.699997"
       id="tspan259">Memory: 765 Mb  </tspan></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text260"
     xml:space="preserve"><tspan
       x="318.5"
       y="65.099998"
       id="tspan261" /></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text262"
     xml:space="preserve"><tspan
       x="318.5"
       y="67.5"
       id="tspan263" /></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text264"
     xml:space="preserve"><tspan
       x="318.5"
       y="69.900002"
       id="tspan265" /></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text266"
     xml:space="preserve"><tspan
       x="318.5"
       y="72.300003"
       id="tspan267" /></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text268"
     xml:space="preserve"><tspan
       x="318.5"
       y="74.699997"
       id="tspan269" /></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text270"
     xml:space="preserve"><tspan
       x="318.5"
       y="77.099998"
       id="tspan271" /></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text272"
     xml:space="preserve"><tspan
       x="318.5"
       y="79.5"
       id="tspan273" /></text>
  <text
     x="310.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text274"
     xml:space="preserve"><tspan
       x="318.5"
       y="81.900002"
       id="tspan275" /></text>
  <path
     id="path241"
     style="fill:none;stroke:#000000;stroke-width:0.30000001;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:0.9, 0.3;stroke-dashoffset:0;marker-start:url(#DiamondS);marker-mid:url(#DiamondS);marker-end:url(#DiamondS);display:inline"
     d="m 330.5,30.5 10,20" />
  <a
     xlink:href="http://www.w3.org"
     id="a193"
     transform="translate(-20,-9)" />
  <image
     xlink:href="C:\Program Files\xampp\htdocs\openaudit\images\computer.png"
     x="380.5"
     y="21.5"
     width="16"
     height="16"
     id="303" />
  <text
     x="380.5"
     y="21.5"
     style="font-size:5px;text-align:center;text-anchor:middle"
     id="text304"
     xml:space="preserve"><tspan
       x="388.5"
       y="43.5"
       id="tspan305">Workstation5</tspan></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text306"
     xml:space="preserve"><tspan
       x="388.5"
       y="47.099998"
       id="tspan307">ip: 192.168.051.033 </tspan></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text308"
     xml:space="preserve"><tspan
       x="388.5"
       y="49.5"
       id="tspan309">User: DOMAIN\DDuck </tspan></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text310"
     xml:space="preserve"><tspan
       x="388.5"
       y="51.900002"
       id="tspan311">Domain: domain.local </tspan></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text312"
     xml:space="preserve"><tspan
       x="388.5"
       y="54.299999"
       id="tspan313">Vendor: Dell Computer Corporation </tspan></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text314"
     xml:space="preserve"><tspan
       x="388.5"
       y="56.699997"
       id="tspan315">Model: OptiPlex 170L </tspan></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text316"
     xml:space="preserve"><tspan
       x="388.5"
       y="59.099998"
       id="tspan317">Serial #: DEFG123 </tspan></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text318"
     xml:space="preserve"><tspan
       x="388.5"
       y="62.699997"
       id="tspan319">Memory: 765 Mb  </tspan></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text320"
     xml:space="preserve"><tspan
       x="388.5"
       y="65.099998"
       id="tspan321" /></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text322"
     xml:space="preserve"><tspan
       x="388.5"
       y="67.5"
       id="tspan323" /></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text324"
     xml:space="preserve"><tspan
       x="388.5"
       y="69.900002"
       id="tspan325" /></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text326"
     xml:space="preserve"><tspan
       x="388.5"
       y="72.300003"
       id="tspan327" /></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text328"
     xml:space="preserve"><tspan
       x="388.5"
       y="74.699997"
       id="tspan329" /></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text330"
     xml:space="preserve"><tspan
       x="388.5"
       y="77.099998"
       id="tspan331" /></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text332"
     xml:space="preserve"><tspan
       x="388.5"
       y="79.5"
       id="tspan333" /></text>
  <text
     x="380.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text334"
     xml:space="preserve"><tspan
       x="388.5"
       y="81.900002"
       id="tspan335" /></text>
  <path
     id="path301"
     style="fill:none;stroke:#000000;stroke-width:0.30000001;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:0.9, 0.3;stroke-dashoffset:0;marker-start:url(#DiamondS);marker-mid:url(#DiamondS);marker-end:url(#DiamondS);display:inline"
     d="m 400.5,30.5 10,20" />
  <a
     xlink:href="http://www.w3.org"
     id="a230"
     transform="translate(-20,-9)" />
  <image
     xlink:href="C:\Program Files\xampp\htdocs\openaudit\images\computer.png"
     x="450.5"
     y="21.5"
     width="16"
     height="16"
     id="363" />
  <text
     x="450.5"
     y="21.5"
     style="font-size:5px;text-align:center;text-anchor:middle"
     id="text364"
     xml:space="preserve"><tspan
       x="458.5"
       y="43.5"
       id="tspan365">Workstation6</tspan></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text366"
     xml:space="preserve"><tspan
       x="458.5"
       y="47.099998"
       id="tspan367">ip: 192.168.051.022 </tspan></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text368"
     xml:space="preserve"><tspan
       x="458.5"
       y="49.5"
       id="tspan369">User: prime\ssteele </tspan></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text370"
     xml:space="preserve"><tspan
       x="458.5"
       y="51.900002"
       id="tspan371">Domain: prime.local </tspan></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text372"
     xml:space="preserve"><tspan
       x="458.5"
       y="54.299999"
       id="tspan373">Vendor: Dell Computer Corporation </tspan></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text374"
     xml:space="preserve"><tspan
       x="458.5"
       y="56.699997"
       id="tspan375">Model: OptiPlex 170L </tspan></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text376"
     xml:space="preserve"><tspan
       x="458.5"
       y="59.099998"
       id="tspan377">Serial #: 6D2N91J </tspan></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:3px;text-align:center;text-anchor:middle"
     id="text378"
     xml:space="preserve"><tspan
       x="458.5"
       y="62.699997"
       id="tspan379">Memory: 765 Mb  </tspan></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text380"
     xml:space="preserve"><tspan
       x="458.5"
       y="65.099998"
       id="tspan381" /></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text382"
     xml:space="preserve"><tspan
       x="458.5"
       y="67.5"
       id="tspan383" /></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text384"
     xml:space="preserve"><tspan
       x="458.5"
       y="69.900002"
       id="tspan385" /></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text386"
     xml:space="preserve"><tspan
       x="458.5"
       y="72.300003"
       id="tspan387" /></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text388"
     xml:space="preserve"><tspan
       x="458.5"
       y="74.699997"
       id="tspan389" /></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text390"
     xml:space="preserve"><tspan
       x="458.5"
       y="77.099998"
       id="tspan391" /></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text392"
     xml:space="preserve"><tspan
       x="458.5"
       y="79.5"
       id="tspan393" /></text>
  <text
     x="450.5"
     y="21.5"
     style="font-size:2px;text-align:center;text-anchor:middle"
     id="text394"
     xml:space="preserve"><tspan
       x="458.5"
       y="81.900002"
       id="tspan395" /></text>
  <path
     id="path361"
     style="fill:none;stroke:#000000;stroke-width:0.30000001;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:0.9, 0.3;stroke-dashoffset:0;marker-start:url(#DiamondS);marker-mid:url(#DiamondS);marker-end:url(#DiamondS);display:inline"
     d="m 470.5,30.5 10,20" />
</svg>

ahull
Posts: 7
Joined: Sat Jun 07, 2008 2:34 am

Re: Inkscape and OpenAudit

Postby ahull » Sun Jun 08, 2008 7:13 pm

... and the PHP, bit of a mashup, could do with being broken down in to distinct functional blocks. :oops:

Its a bit difficult to read out of context, but all those includes set up access to database and include the configuration necessary to set things up.

The rest creates output based on the data returned from the selection made on the page which calls this one.

The result is a set of images, with text titles underneath. Each has a handle which can be used to link the images all together.

All of the parts of a machine (text and titles) are grouped, and the whole diagram is further grouped as one item to make cutting and pasting between diagrams easier.

Code: Select all

<?php

include_once("include_config.php");
include_once("include_functions.php");
include_once("include_lang.php");
include_once("include_inkscape_config.php");
// Set time limit to avoid broken pages, this may need to be a config var if this becomes an issue elsewhere.

//$time_start = microtime_float();


//MySQL-Connect
$db = mysql_connect($mysql_server,$mysql_user,$mysql_password) or die('Could not connect: ' . mysql_error());
mysql_select_db($mysql_database,$db);

//Some Config fcr Layout


//MySQL-Connect
$db = mysql_connect($mysql_server,$mysql_user,$mysql_password) or die('Could not connect: ' . mysql_error());
mysql_select_db($mysql_database,$db);

//Include the view-definition
if(isset($_REQUEST["view"]) AND $_REQUEST["view"]!=""){
    $include_filename = "list_viewdef_".$_REQUEST["view"].".php";
}else{
    $include_filename = "list_viewdef_all_systems.php";
}
if(is_file($include_filename)){
    include_once($include_filename);
    $viewdef_array=$query_array;
}else{
    die("FATAL: Could not find view $include_filename");
}

    //Executing the Qeuery
    $sql=urldecode($_REQUEST["sql"]);
    $result = mysql_query($sql, $db);
    if(!$result) {die( "<br>".__("Fatal Error").":<br><br>".$sql."<br><br>".mysql_error()."<br><br>" );};
    $this_page_count = mysql_num_rows($result);
   
$inkscape_x_offset = 0;
$inkscape_y_offset = 0;

$inkscape_current_object_id = 0 ;
header("Content-Type: application/vnd.inkscape");
header("Content-Disposition: inline; filename=\"Open-Audit_".$_REQUEST["view"]."_network_inkscape.svg\"");

//
// Setup the format of the .inkscape page. This is VERY crude, we should create functions to allow proper control of all elements on the page,
// and a setup page to allow contorl over this ... OOPS (AJH)
//

//Page def
$inkscape = '<?xml version="1.0" encoding="UTF-8" standalone="no"?>'.$inkscape_newline;

//
//
//

$inkscape=$inkscape.'<!-- Created with Inkscape (http://www.inkscape.org/) -->'.$inkscape_newline;
$inkscape=$inkscape.'<svg'.$inkscape_newline;
$inkscape=$inkscape.   'xmlns:svg="http://www.w3.org/2000/svg"'.$inkscape_newline;
$inkscape=$inkscape.'   xmlns="http://www.w3.org/2000/svg"'.$inkscape_newline;
$inkscape=$inkscape.'   xmlns:xlink="http://www.w3.org/1999/xlink"'.$inkscape_newline;
$inkscape=$inkscape.'   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"'.$inkscape_newline;
$inkscape=$inkscape.'   version="1.0"'.$inkscape_newline;
$inkscape=$inkscape.'   width="1052.3622"'.$inkscape_newline;
$inkscape=$inkscape.'   height="744.09448"'.$inkscape_newline;
$inkscape=$inkscape.'   id="svg2">'.$inkscape_newline;
$inkscape=$inkscape.'  <defs'.$inkscape_newline;
$inkscape=$inkscape.'     id="defs4">'.$inkscape_newline;
$inkscape=$inkscape.'    <marker'.$inkscape_newline;
$inkscape=$inkscape.'       refX="0"'.$inkscape_newline;
$inkscape=$inkscape.'       refY="0"'.$inkscape_newline;
$inkscape=$inkscape.'       orient="auto"'.$inkscape_newline;
$inkscape=$inkscape.'       style="overflow:visible"'.$inkscape_newline;
$inkscape=$inkscape.'       id="DiamondS">'.$inkscape_newline;
$inkscape=$inkscape.'      <path'.$inkscape_newline;
$inkscape=$inkscape.'         d="M 0,-7.0710768 L -7.0710894,0 L 0,7.0710589 L 7.0710462,0 L 0,-7.0710768 z "'.$inkscape_newline;
$inkscape=$inkscape.'         transform="scale(0.2,0.2)"'.$inkscape_newline;
$inkscape=$inkscape.'         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none"'.$inkscape_newline;
$inkscape=$inkscape.'         id="path3361" />'.$inkscape_newline;
$inkscape=$inkscape.'    </marker>'.$inkscape_newline;
$inkscape=$inkscape.'  </defs>'.$inkscape_newline;
// End of Page Def
//
// Add the first layer and Group Everything on this layer.
$inkscape= $inkscape.'  <g'.$inkscape_newline;
$inkscape= $inkscape.'     id="layer1">'.$inkscape_newline;
 //Next we need to create the image objects


//Table body. This section creates a list of network objects and distributes them across the page
// The exact number across each page depends on the page size and layout.
//

// First we start at the top left of the page,
//
$inkscape_current_object_x = $inkscape_object_start_x;
$inkscape_current_object_y = $inkscape_object_start_y;
// Set the first object ID.
$inkscape_current_object_id = $inkscape_object_start_id;
//
// Now we create our list from the list on the page that brought us here.
// This is why we need to expand the list using the Arrow keys, otherwise we only see the currnet page.
//
if ($myrow = mysql_fetch_array($result)){
    do{
        foreach($query_array["fields"] as $field){
            if($field["show"]!="n"){
            //
            $inkscape_current_obj_text[0]='';
            $inkscape_current_obj_text[1]='';
            $inkscape_current_obj_text[2]='';
            $inkscape_current_obj_text[3]='';
            $inkscape_current_obj_text[4]='';
            $inkscape_current_obj_text[5]='';
            $inkscape_current_obj_text[6]='';
            $inkscape_current_obj_text[8]='';
            $inkscape_current_obj_text[9]='';
            $inkscape_current_obj_text[10]='';
            $inkscape_current_obj_text[11]='';
            $inkscape_current_obj_text[12]='';
            $inkscape_current_obj_text[13]='';
            $inkscape_current_obj_text[14]='';
            $inkscape_current_obj_text[15]='';
            $inkscape_current_obj_text[16]='';
           // Add an additional 100ms to our time
           set_time_limit(100);
            //
            if (($field["head"]=="Hostname")or ($field["head"]=="Network Name")){

            if (!isset($inkscape_image_folder) ){
            $inkscape_image_folder = ".\\";
            } else{}
            //
            if ($field["head"]=="Hostname") {
            //

            $inkscape_image_icon = determine_inkscape_img($myrow["system_os_name"],$myrow[$field["name"]]);
            //
            $inkscape_this_image = $inkscape_image_folder.$inkscape_image_icon;
            //
            $inkscape_current_obj_text[0]="  ".$myrow[$field["name"]]."\n\n";
           // $inkscape_current_obj_text="  ".$myrow[$field["name"]]."\n\n"."ip: ".$myrow["net_ip_address"]."\n"."\n"."User: ".$myrow["net_user_name"]."\n"."Domain: ".$myrow["net_domain"]."\n"."Vendor: ".$myrow["system_vendor"]."\n"."Model: ".$myrow["system_model"]."\n"."Memory: ".$myrow["system_memory"]." Mb";
           
           if ($inkscape_show_system_net_ip_address ){
           $inkscape_current_obj_text[1]="ip: ".$myrow["net_ip_address"]."\n";
            } else {}
           
            if ($inkscape_show_system_net_user_name){
           $inkscape_current_obj_text[2]="User: ".$myrow["net_user_name"]."\n";
            } else {}
           
            if ($inkscape_show_system_net_domain ){
           $inkscape_current_obj_text[3]="Domain: ".$myrow["net_domain"]."\n";
            } else {}
           
            if ($inkscape_show_system_system_vendor ){
           $inkscape_current_obj_text[4]="Vendor: ".$myrow["system_vendor"]."\n";
            } else {}
           
            if ($inkscape_show_system_system_model ){
           $inkscape_current_obj_text[5]="Model: ".$myrow["system_model"]."\n";
            } else {}
           
            if ($inkscape_show_system_system_id_number ){
           $inkscape_current_obj_text[6]="Serial #: ".$myrow["system_id_number"]."\n";
            } else {}
           
            if ($inkscape_show_system_system_memory ){
           $inkscape_current_obj_text[7]="Memory: ".$myrow["system_memory"]." Mb \n";
            } else {}
           
           
            }
            else
            {
            //         
            $inkscape_image_icon = determine_inkscape_img($myrow["other_type"],$myrow["other_type"]);
            //
            $inkscape_this_image = $inkscape_image_folder.$inkscape_image_icon;
            //
            //."\n".$myrow["other_ip_address"]."\n".$myrow["other_description"];
            $inkscape_current_obj_text[0]=$myrow[$field["name"]]."\n\n";
            //
           
            if ($inkscape_show_other_network_name== "y"){
           $inkscape_current_obj_text[1]="Name: ".$myrow["other_network_name"]."\n";
            } else {}

            if ($inkscape_show_system_net_ip_address == "y"){
           $inkscape_current_obj_text[2]="ip: ".$myrow["other_ip_address"]."\n";
            } else {}
           
            if ($inkscape_show_other_mac_address== "y"){
           $inkscape_current_obj_text[3]="MAC: ".$myrow["other_mac_address"]."\n";
            } else {}
           
            if ($inkscape_show_other_description== "y"){
           $inkscape_current_obj_text[4]="Description: ".$myrow["other_description"]."\n";
            } else {}
           
            if ($inkscape_show_other_location== "y"){
           $inkscape_current_obj_text[5]="Location: ".$myrow["other_location"]."\n";
            } else {}
           
            if ($inkscape_show_other_serial== "y"){
           $inkscape_current_obj_text[6]="Serial: ".$myrow["other_serial"]."\n";
            } else {}
           
            if ($inkscape_show_other_model== "y"){
           $inkscape_current_obj_text[7]="Model: ".$myrow["other_model"]."\n";
            } else {}
           
            if ($inkscape_show_other_type== "y"){
           $inkscape_current_obj_text[8]="Type: ".$myrow["other_type"]."\n";
            } else {}
           
// If its a printer or print server, show the port and share info
           
            if ( ($myrow["other_type"] == "printer") or ($myrow["other_type"] == "print server")) {
           
                 if ($inkscape_show_other_p_port_name== "y"){
                $inkscape_current_obj_text[9]="Printer Port Name: ".$myrow["other_p_port_name"]."\n";
                    } else {}
           
                 if ($inkscape_show_other_p_share_name== "y"){
                $inkscape_current_obj_text[10]="Printer Share Name: ".$myrow["other_p_share_name"]."\n";
                    } else {}
                } else {}
             }
 // Nothing to do if it isn't a computer or a network object (yet AJH ;)) 
           
            $inkscape_current_image_object_id = $inkscape_current_object_id;
            $inkscape_current_image_object_id_offset = 2;           
            // Add the Grouping for our object
            $inkscape = $inkscape.'      <g'.$inkscape_newline;
            $inkscape=$inkscape.'       transform="translate(-20,-9)"'.$inkscape_newline;
            $inkscape=$inkscape.'       id="g'.(($inkscape_current_image_object_id *20)+$inkscape_current_image_object_id_offset ).'">'.$inkscape_newline;
            // Next Item
             $inkscape_current_image_object_id_offset =  $inkscape_current_image_object_id_offset + 1;
           
            // URL Link
            $inkscape=$inkscape.'          <a xlink:href="http://www.w3.org">'.$inkscape_newline;
            $inkscape=$inkscape.'    </a>'.$inkscape_newline;

            // Add the image

            $inkscape=$inkscape.'      <image'.$inkscape_newline;
 

            $inkscape=$inkscape.'         xlink:href="'.$inkscape_this_image .'"'.$inkscape_newline;
            $inkscape=$inkscape.'         x="'.$inkscape_current_object_x.'"'.$inkscape_newline;
            $inkscape=$inkscape.'         y="'.$inkscape_current_object_y.'"'.$inkscape_newline;
            $inkscape=$inkscape.'         width="'.$inkscape_obj_image_0_elem_width.'"'.$inkscape_newline;
            $inkscape=$inkscape.'         height="'.$inkscape_obj_image_0_elem_height.'"'.$inkscape_newline;
            $inkscape=$inkscape.'         id="'.(($inkscape_current_image_object_id *20)+$inkscape_current_image_object_id_offset).'" />'.$inkscape_newline;
           
           
            // Next Item
             $inkscape_current_image_object_id_offset =  $inkscape_current_image_object_id_offset + 1;
            //

            // Add the text boxes
            $text_line_offset=0;
           
            //
            //
            for ($textline = 0 ;$textline <= ($inkscape_show_maxfields-1); $textline += 1){
            //
            // Add the text lines, Start with the format
            $inkscape=$inkscape.'      <text'.$inkscape_newline;
            $inkscape=$inkscape.'         x="'.$inkscape_current_object_x.'"'.$inkscape_newline;
            $inkscape=$inkscape.'         y="'.$inkscape_current_object_y.'"'.$inkscape_newline;
            $inkscape=$inkscape.'         style="font-size:'.$inkscape_obj_text_font_height[$textline].'px;text-align:center;text-anchor:middle"'.$inkscape_newline;
            $inkscape=$inkscape.'         id="text'.(($inkscape_current_image_object_id *20)+$inkscape_current_image_object_id_offset).'"'.$inkscape_newline;
            // Next ID
             $inkscape_current_image_object_id_offset =  $inkscape_current_image_object_id_offset + 1;

            // Position
            $inkscape=$inkscape.'         xml:space="preserve"><tspan'.$inkscape_newline;
            // add in the next text height offset
            $text_line_offset = $text_line_offset + $inkscape_obj_text_pos_y_offset[$textline];
            $inkscape=$inkscape.'           x="'.($inkscape_current_object_x+$inkscape_obj_text_pos_x_offset[$textline]).'"'.$inkscape_newline;
            $inkscape=$inkscape.'           y="'.($inkscape_obj_image_0_elem_height+$inkscape_current_object_y+$text_line_offset).'"'.$inkscape_newline;
            // ... and the text.
            $inkscape=$inkscape.'           id="tspan'.(($inkscape_current_image_object_id *20)+$inkscape_current_image_object_id_offset).'">'.$inkscape_current_obj_text[$textline].'</tspan></text>'.$inkscape_newline;
            //
            $inkscape_current_image_object_id_offset =  $inkscape_current_image_object_id_offset + 1;
            // Next ID
            }

            // Close the grouping for this object
            $inkscape=$inkscape.'    </g>'.$inkscape_newline;
            $inkscape=$inkscape.'    <path'.$inkscape_newline;
            $inkscape=$inkscape.'       d="M '.$inkscape_current_object_x.','.$inkscape_current_object_y.' L '.($inkscape_current_object_x+$inkscape_obj_line_0_length_x).','.($inkscape_current_object_y+$inkscape_obj_line_0_length_y).'"'.$inkscape_newline;
            $inkscape=$inkscape.'       inkscape:connection-start="#g'.(($inkscape_current_image_object_id *20)+2).'"'.$inkscape_newline;
            // Next Item
             $inkscape_current_image_object_id_offset =  $inkscape_current_image_object_id_offset + 1;

            $inkscape=$inkscape.'       style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.30000001;stroke-linecap:round;stroke-linejoin:round;marker-start:url(#DiamondS);marker-mid:url(#DiamondS);marker-end:url(#DiamondS);stroke-miterlimit:4;stroke-dasharray:0.9, 0.3;stroke-dashoffset:0;stroke-opacity:1;display:inline"'.$inkscape_newline;
            $inkscape=$inkscape.'       id="path'.(($inkscape_current_image_object_id *20)+1).'" />'.$inkscape_newline;

       
       
            // move to next Object 
            $inkscape_current_object_id += 3;
            //   
           
            //$inkscape_current_object_id += 1;

            //$inkscape_current_object_id += 1;
           
                }                                                                       
            // $inkscape_current_object_id += 4.0;
            }
        }
        // Space out the objects

        //
        $inkscape_x_offset = (($inkscape_current_object_id / $inkscape_grouped_objects) % $inkscape_num_across_page ) ;
        if ($inkscape_x_offset == 0 )  {
        $inkscape_y_offset = $inkscape_y_offset + 1;
        }
       
        /*
        //        Test code block to output a few vars
      echo $inkscape_current_object_id.','  ;
      echo $inkscape_x_offset.','.$inkscape_y_offset;
        //
        */       
               

          $inkscape_current_object_x = $inkscape_object_start_x + ($inkscape_x_offset * $inkscape_object_spacing_x);
          $inkscape_current_object_y = $inkscape_object_start_y + ($inkscape_y_offset * $inkscape_object_spacing_y);
        //
        //  $inkscape_current_object_x += $inkscape_object_spacing_x;
        //  $inkscape_current_object_y += $inkscape_object_spacing_y;
        //
    }while ($myrow = mysql_fetch_array($result));

}

// Close Layer and Document

$inkscape = $inkscape.'      </g>'.$inkscape_newline;
$inkscape=$inkscape.'</svg>'.$inkscape_newline;
// Thats all folks
echo $inkscape;

?>

User avatar
microUgly
Site Admin
Posts: 2985
Joined: Sat Jun 02, 2007 3:13 pm
Contact:

Re: Inkscape and OpenAudit

Postby microUgly » Sun Jun 08, 2008 8:49 pm

You are perhaps helping us to help you with the information your provding. The harder you make it to help, the less likely you'll get help.

If are asking how to give your SVG pages a "bit of zing" then all we need to see is an example of what you pages look like now, not the raw SVG code or PHP. The SVG code you provided doesn't appear complete... there's a bunch of embeded images missing. Can you provide a complete SVG file that we can view quickly and easily?

ahull
Posts: 7
Joined: Sat Jun 07, 2008 2:34 am

Re: Inkscape and OpenAudit

Postby ahull » Sun Jun 08, 2008 10:32 pm

The two bits of code are there simply to give those who want to know, an idea of how the thing works.

Image

This is an example of the raw output, sorry for the delay and confusion. The above is a jpg, but the script outputs .svg and loads this directly in to Inkscape.

(On the web page, under the list is a button marked Create Inkscape Diagram, which when clicked creates the SVG file, and throws it back to the browser to be opened by whichever SVG editor is installed, in most cases this will obviously be Inkscape).

I want the diagram to be as close to complete as possible, so the user doesn't need to do much work on it in order to "impress the boardroom types".
Last edited by ahull on Mon Jun 09, 2008 7:10 pm, edited 3 times in total.

User avatar
microUgly
Site Admin
Posts: 2985
Joined: Sat Jun 02, 2007 3:13 pm
Contact:

Re: Inkscape and OpenAudit

Postby microUgly » Mon Jun 09, 2008 9:50 am

You can't upload images directly to this forum, but you can display them here - Where can I upload my images?

Sorry if I sounded a bit short in my previous post.

ahull
Posts: 7
Joined: Sat Jun 07, 2008 2:34 am

Re: Inkscape and OpenAudit

Postby ahull » Mon Jun 09, 2008 6:57 pm

Just stuck a .jpg in Photobucket for the time being, see the previous post. The above is the raw output from the web page, which can then be stiched together and worked on to produce a usable diagram.

The diagram pictures are generated from jpgs of the original Tango Icon set (although any images can be used). The Tango icons are also available as SVGs and I will eventually parse these into the diagram, rather than linking in the jpgs (so we can scale things).

As you can see, there is nothing particularly eye catching about the result, functional but boring would be my analysis. What I am looking for is something that makes the whole thing stand out.

I thought about some sort of 3d effect, possibly laying out the items on a perspective grid. The latest Inkscape version seems to lend itself quite well to this.

Other ideas include "fancy wiring" i.e. having the script link everything together with rounded coloured "wires", stretchable coloured links (perhaps even with RJ45 ends on them). "Network clouds", high-tec background watermarks, and various other probably impossible tweaks.

It is possible to do most of this stuff by hand, ... see http://www.open-audit.org/network_maps/map_wan.html but I would like to make the script do most of the hard work, and also produce the output as an SVG file, to keep the high quality. Something more like ...

Image

(Diagram created mainly by hand, with a mix of Tango Icons and other open source SVGs)

For those of you who would like a look at the Tango Icons, see... http://tango.freedesktop.org/Tango_Icon_Library

User avatar
microUgly
Site Admin
Posts: 2985
Joined: Sat Jun 02, 2007 3:13 pm
Contact:

Re: Inkscape and OpenAudit

Postby microUgly » Tue Jun 10, 2008 9:23 am

I don't think I could suggest any improvements. I honestly think it looks great. Very professional. I tend to think with stuff like this, you don't want bells and whistles. I think they can sometimes cheapen the diagram.

ahull
Posts: 7
Joined: Sat Jun 07, 2008 2:34 am

Re: Inkscape and OpenAudit

Postby ahull » Wed Jun 11, 2008 10:59 pm

Yes it does look good, the only trouble is this is the "hand made" version, I would like a few tips, for example, how can I create a "wire" which will scale well, and how can I create my own handles for the ends of the wire.

What about laying out items in a grid with automatic connection of all the items together with these "wires".

What would people like to see on their "ideal" network diagram, and how can I design this.

User avatar
microUgly
Site Admin
Posts: 2985
Joined: Sat Jun 02, 2007 3:13 pm
Contact:

Re: Inkscape and OpenAudit

Postby microUgly » Thu Jun 12, 2008 9:14 am

I'm not clear on what you're asking or what you don't know.

You're not using Inkscape are you? You're creating an SVG with PHP? So your questions about handles on wires is kinda confusing me. I assume a "wire" is the line between the images. As the question stands I would think the answer is that you just create an SVG object for the line, and then an object for each end of the line that will be the handles.

If your asking how do you create a diagram like you provided dynamically (using PHP), based on details provided by a user, you might be better off asking on a programming forum. Writing a PHP application that can intelligently layout a diagram would be quite a feat.

ahull
Posts: 7
Joined: Sat Jun 07, 2008 2:34 am

Re: Inkscape and OpenAudit

Postby ahull » Thu Jun 12, 2008 9:27 pm

Actually, what I do, is design something in Inkscape which I like the look of, then edit the SVG file with SciEdit to see how the XML is formatted. I then take the XML apart, and create PHP code to re-create similar XML.

For example if I wanted to add a drop shadow to each icon, or a blue fluffy cloud as a background, I would create a mock up of what I want in Inkscape, and then edit the resultant SVG file to see how it is done. I then code some php to create lots of similar XML using the contents of the database as my text, the Tongo icons for my pictures, a bit of hight school maths to place everything neatly on the page. Result lots of computers with fluffy backgrounds, drop shadows, and whatever else I require.

Where I require the inspiration is in creating just the right level of "bling" to make things look really slick without going overboard.

I'm looking for artistic inspiration rather than technical, so thats where I turn to you guys... ;)
Image

User avatar
microUgly
Site Admin
Posts: 2985
Joined: Sat Jun 02, 2007 3:13 pm
Contact:

Re: Inkscape and OpenAudit

Postby microUgly » Fri Jun 13, 2008 9:17 am

Ah, well, like I said, I like the original one you posted for it clean lines and simple design. I don't like the one you just posted because it's the opposite. Unless the different coloured lines have different meanings, I wouldn't use different colours.

Paoh
Posts: 1
Joined: Wed Mar 17, 2010 6:33 pm

Re: Inkscape and OpenAudit

Postby Paoh » Thu Mar 18, 2010 12:11 pm

ahull wrote:
(Diagram created mainly by hand, with a mix of Tango Icons and other open source SVGs)

For those of you who would like a look at the Tango Icons, see... http://tango.freedesktop.org/Tango_Icon_Library


Hi,

Let's refresh this old topic.
I tried my best to find your open source svg for Dell servers or 3Com switches. No way.
Does anyone have some source for these specific svg icons ?
If you have other sources for network, servers and other devices, your are welcome.

Now, here are resources i found to do network diagrams with Inkscape :
- Open Security Architecture (based on Tango)
http://www.opensecurityarchitecture.org ... on-library
- Quantum Bits (for Tango or others applications)
http://quantum-bits.org/?page_id=3
http://quantum-bits.org/?p=48
http://www.quantum-bits.org/?p=57

Thank you in advance.

Paoh.


Return to “Inkscape & the Web”