3 // This program is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU General Public License
5 // as published by the Free Software Foundation; either version 2
6 // of the License, or (at your option) any later version.
11 //INCLUDES, DO ANY ACTIONS, THEN GET OUR DATA
12 require_once("../globals.php");
13 require_once("$srcdir/registry.inc");
15 use OpenEMR\Common\Acl\AclExtended
;
16 use OpenEMR\Common\Csrf\CsrfUtils
;
17 use OpenEMR\Core\Header
;
19 if (!empty($_GET['method']) && ($_GET['method'] == "enable")) {
20 if (!CsrfUtils
::verifyCsrfToken($_GET["csrf_token_form"])) {
21 CsrfUtils
::csrfNotVerified();
23 updateRegistered($_GET['id'], "state=1");
24 } elseif (!empty($_GET['method']) && ($_GET['method'] == "disable")) {
25 if (!CsrfUtils
::verifyCsrfToken($_GET["csrf_token_form"])) {
26 CsrfUtils
::csrfNotVerified();
28 updateRegistered($_GET['id'], "state=0");
29 } elseif (!empty($_GET['method']) && ($_GET['method'] == "install_db")) {
30 if (!CsrfUtils
::verifyCsrfToken($_GET["csrf_token_form"])) {
31 CsrfUtils
::csrfNotVerified();
33 $dir = getRegistryEntry($_GET['id'], "directory");
34 if (installSQL("$srcdir/../interface/forms/{$dir['directory']}")) {
35 updateRegistered($_GET['id'], "sql_run=1");
37 $err = xl('ERROR: could not open table.sql, broken form?');
39 } elseif (!empty($_GET['method']) && ($_GET['method'] == "register")) {
40 if (!CsrfUtils
::verifyCsrfToken($_GET["csrf_token_form"])) {
41 CsrfUtils
::csrfNotVerified();
43 registerForm($_GET['name']) or $err = xl('error while registering form!');
46 $bigdata = getRegistered("%") or $bigdata = false;
48 //START OUT OUR PAGE....
53 <?php Header
::setupHeader(); ?
>
55 <body
class="body_top">
57 <div
class="container-fluid">
61 <h2
class="title"><?php
echo xlt('Forms Administration');?
></h2
>
66 <div
class="col-12 mt-3">
69 if (!CsrfUtils
::verifyCsrfToken($_POST["csrf_token_form"])) {
70 CsrfUtils
::csrfNotVerified();
72 foreach ($_POST as $key => $val) {
73 if (preg_match('/nickname_(\d+)/', $key, $matches)) {
74 sqlQuery("update registry set nickname = ? where id = ?", array($val, $matches[1]));
75 } elseif (preg_match('/category_(\d+)/', $key, $matches)) {
76 sqlQuery("update registry set category = ? where id = ?", array($val, $matches[1]));
77 } elseif (preg_match('/priority_(\d+)/', $key, $matches)) {
78 sqlQuery("update registry set priority = ? where id = ?", array($val, $matches[1]));
79 } elseif (preg_match('/aco_spec_(\d+)/', $key, $matches)) {
80 sqlQuery("update registry set aco_spec = ? where id = ?", array($val, $matches[1]));
86 <?php
//ERROR REPORTING
88 echo "<span class='font-weight-bold text-danger'>" . text($err) . "</span>\n";
92 <?php
//REGISTERED SECTION ?>
93 <span
class="font-weight-bold"><?php
echo xlt('Registered');?
></span
>
94 <form method
="post" action
='./forms_admin.php'>
95 <span
class="font-italic">
96 <?php
echo xlt('click here to update priority, category, nickname and access control settings'); ?
>
98 <input type
="hidden" name
="csrf_token_form" value
="<?php echo attr(CsrfUtils::collectCsrfToken()); ?>" />
99 <input
class="btn btn-primary" type
='submit' name
='update' value
='<?php echo xla('Save
'); ?>'>
101 <div
class="table-responsive mt-3">
102 <table
class="table table-striped">
105 <th colspan
="5"></th
>
106 <th
><?php
echo xlt('Priority'); ?
> </th
>
107 <th
><?php
echo xlt('Category'); ?
> </th
>
108 <th
><?php
echo xlt('Nickname'); ?
> </th
>
109 <th
><?php
echo xlt('Access Control'); ?
></th
>
113 if ($bigdata != false) {
114 foreach ($bigdata as $registry) {
115 $priority_category = sqlQuery(
116 "select priority, category, nickname, aco_spec from registry where id = ?",
117 array($registry['id'])
122 <span
class='text'><?php
echo text($registry['id']); ?
></span
>
125 <span
class='font-weight-bold'><?php
echo text(xl_form_title($registry['name'])); ?
></span
>
128 if ($registry['sql_run'] == 0) {
129 echo "<td><span class='text'>" . xlt('registered') . "</span>";
130 } elseif ($registry['state'] == "0") {
131 echo "<td><a class='link_submit text-danger' href='./forms_admin.php?id=" . attr_url($registry['id']) . "&method=enable&csrf_token_form=" . attr_url(CsrfUtils
::collectCsrfToken()) . "'>" . xlt('disabled') . "</a>";
133 echo "<td><a class='link_submit text-success' href='./forms_admin.php?id=" . attr_url($registry['id']) . "&method=disable&csrf_token_form=" . attr_url(CsrfUtils
::collectCsrfToken()) . "'>" . xlt('enabled') . "</a>";
138 <span
class='text'><?php
139 if ($registry['unpackaged']) {
140 echo xlt('PHP extracted');
142 echo xlt('PHP compressed');
149 if ($registry['sql_run']) {
150 echo "<span class='text'>" . xlt('DB installed') . "</span>";
152 echo "<a class='link_submit' href='./forms_admin.php?id=" . attr_url($registry['id']) . "&method=install_db&csrf_token_form=" . attr_url(CsrfUtils
::collectCsrfToken()) . "'>" . xlt('install DB') . "</a>";
157 echo "<td><input type='text' class='form-control' size='4' name='priority_" . attr($registry['id']) . "' value='" . attr($priority_category['priority']) . "'></td>";
158 echo "<td><input type='text' class='form-control' size='10' name='category_" . attr($registry['id']) . "' value='" . attr($priority_category['category']) . "'></td>";
159 echo "<td><input type='text' class='form-control' size='10' name='nickname_" . attr($registry['id']) . "' value='" . attr($priority_category['nickname']) . "'></td>";
161 echo "<select name='aco_spec_" . attr($registry['id']) . "' class='form-control'>";
162 echo "<option value=''></option>";
163 echo AclExtended
::genAcoHtmlOptions($priority_category['aco_spec']);
176 <?php
//UNREGISTERED SECTION ?>
177 <span
class="font-weight-bold"><?php
echo xlt('Unregistered'); ?
></span
>
178 <div
class="table-responsive mt-3">
179 <table
class="table table-striped">
181 $dpath = "$srcdir/../interface/forms/";
182 $dp = opendir($dpath);
184 for ($i = 0; false != ($fname = readdir($dp)); $i++
) {
186 $fname != "." && $fname != ".." && $fname != "CVS" && $fname != "LBF" &&
187 (is_dir($dpath . $fname) ||
stristr($fname, ".tar.gz") ||
188 stristr($fname, ".tar") ||
stristr($fname, ".zip") ||
189 stristr($fname, ".gz"))
195 // ballards 11/05/2005 fixed bug in removing registered form from the list
196 if ($bigdata != false) {
197 foreach ($bigdata as $registry) {
198 $key = array_search($registry['directory'], $inDir) ; /* returns integer or FALSE */
203 foreach ($inDir as $fname) {
204 if (stristr($fname, ".tar.gz") ||
stristr($fname, ".tar") ||
stristr($fname, ".zip") ||
stristr($fname, ".gz")) {
205 $phpState = "PHP compressed";
207 $phpState = "PHP extracted";
213 $form_title_file = @file
($GLOBALS['srcdir'] . "/../interface/forms/$fname/info.txt");
214 if ($form_title_file) {
215 $form_title = $form_title_file[0];
217 $form_title = $fname;
220 <span
class="font-weight-bold"><?php
echo text(xl_form_title($form_title)); ?
></span
>
224 if ($phpState == "PHP extracted") {
225 echo '<a class="link_submit" href="./forms_admin.php?name=' . attr_url($fname) . '&method=register&csrf_token_form=' . attr_url(CsrfUtils
::collectCsrfToken()) . '">' . xlt('register') . '</a>';
227 echo '<span class="text">' . xlt('n/a') . '</span>';
232 <span
class="text"><?php
echo xlt($phpState); ?
></span
>
235 <span
class="text"><?php
echo xlt('n/a'); ?
></span
>