diff --git a/dockerManager/container.py b/dockerManager/container.py index 42359b092..e5aff5f0c 100644 --- a/dockerManager/container.py +++ b/dockerManager/container.py @@ -786,29 +786,31 @@ class ContainerManager(multi.Thread): names = [] for image in imageList: - name = image.attrs['RepoTags'][0].split(":")[0] - if "/" in name: - name2 = "" - for item in name.split("/"): - name2 += ":" + item - else: - name2 = name + try: + name = image.attrs['RepoTags'][0].split(":")[0] + if "/" in name: + name2 = "" + for item in name.split("/"): + name2 += ":" + item + else: + name2 = name + + tags = [] + for tag in image.tags: + getTag = tag.split(":") + if len(getTag) == 2: + tags.append(getTag[1]) + print tags + if name in names: + images[name]['tags'].extend(tags) + else: + names.append(name) + images[name] = {"name": name, + "name2": name2, + "tags": tags} + except: + continue - tags = [] - for tag in image.tags: - getTag = tag.split(":") - if len(getTag) == 2: - tags.append(getTag[1]) - print tags - if name in names: - images[name]['tags'].extend(tags) - else: - names.append(name) - images[name] = {"name": name, - "name2": name2, - "tags": tags} - print "======" - print images return render(request, 'dockerManager/images.html', {"images": images, "test": ''}) except BaseException, msg: diff --git a/install/lscp.tar.gz b/install/lscp.tar.gz index 0b8d7ca9c..705445bfc 100644 Binary files a/install/lscp.tar.gz and b/install/lscp.tar.gz differ diff --git a/install/lscp/GPL.txt b/install/lscp/GPL.txt new file mode 100644 index 000000000..94a9ed024 --- /dev/null +++ b/install/lscp/GPL.txt @@ -0,0 +1,674 @@ + GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU General Public License is a free, copyleft license for +software and other kinds of works. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +the GNU General Public License is intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. We, the Free Software Foundation, use the +GNU General Public License for most of our software; it applies also to +any other work released this way by its authors. You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + To protect your rights, we need to prevent others from denying you +these rights or asking you to surrender the rights. Therefore, you have +certain responsibilities if you distribute copies of the software, or if +you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must pass on to the recipients the same +freedoms that you received. You must make sure that they, too, receive +or can get the source code. And you must show them these terms so they +know their rights. + + Developers that use the GNU GPL protect your rights with two steps: +(1) assert copyright on the software, and (2) offer you this License +giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains +that there is no warranty for this free software. For both users' and +authors' sake, the GPL requires that modified versions be marked as +changed, so that their problems will not be attributed erroneously to +authors of previous versions. + + Some devices are designed to deny users access to install or run +modified versions of the software inside them, although the manufacturer +can do so. This is fundamentally incompatible with the aim of +protecting users' freedom to change the software. The systematic +pattern of such abuse occurs in the area of products for individuals to +use, which is precisely where it is most unacceptable. Therefore, we +have designed this version of the GPL to prohibit the practice for those +products. If such problems arise substantially in other domains, we +stand ready to extend this provision to those domains in future versions +of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. +States should not allow patents to restrict development and use of +software on general-purpose computers, but in those that do, we wish to +avoid the special danger that patents applied to a free program could +make it effectively proprietary. To prevent this, the GPL assures that +patents cannot be used to render the program non-free. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Use with the GNU Affero General Public License. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU Affero General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the special requirements of the GNU Affero General Public License, +section 13, concerning interaction through a network will apply to the +combination as such. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short +notice like this when it starts in an interactive mode: + + Copyright (C) + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, your program's commands +might be different; for a GUI interface, you would use an "about box". + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU GPL, see +. + + The GNU General Public License does not permit incorporating your program +into proprietary programs. If your program is a subroutine library, you +may consider it more useful to permit linking proprietary applications with +the library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. But first, please read +. diff --git a/install/lscp/VERSION b/install/lscp/VERSION new file mode 100644 index 000000000..6e8bf73aa --- /dev/null +++ b/install/lscp/VERSION @@ -0,0 +1 @@ +0.1.0 diff --git a/install/lscp/bin/lscpd b/install/lscp/bin/lscpd new file mode 100755 index 000000000..25d04dab4 Binary files /dev/null and b/install/lscp/bin/lscpd differ diff --git a/install/lscp/bin/lscpdctrl b/install/lscp/bin/lscpdctrl new file mode 100755 index 000000000..1c5c1a889 --- /dev/null +++ b/install/lscp/bin/lscpdctrl @@ -0,0 +1,259 @@ +#!/bin/sh + +# resolve links - $0 may be a softlink +PROG="$0" +PIDFILE=/tmp/lscpd/lscpd.pid +GRACEFUL_PIDFILE=/tmp/lscpd/lscpd.pid + +#if [ -d "/usr/local/cpanel" ]; then +# WSWATCH=1 +#fi + +EXECUTABLE=lscpd +DESC="lscpd" +BASE_DIR=`dirname "$PROG"` +cd "$BASE_DIR" +BASE_DIR=`pwd` +RESTART_LOG="$BASE_DIR/../logs/lsrestart.log" +if [ ! -x "$BASE_DIR"/"$EXECUTABLE" ]; then + echo "[ERROR] Cannot find $BASE_DIR/$EXECUTABLE" + exit 1 +fi +SYS_NAME=`uname -s` +if [ "x$SYS_NAME" = "xFreeBSD" ] || [ "x$SYS_NAME" = "xDarwin" ] ; then + PS_CMD="ps -ax" +else + PS_CMD="ps -ef" +fi + +test_running() +{ +RUNNING=0 +if [ -f $PIDFILE ] ; then + FPID=`cat $PIDFILE` + if [ "x$FPID" != "x" ]; then + kill -0 $FPID 2>/dev/null + if [ $? -eq 0 ] ; then + RUNNING=1 + PID=$FPID + fi + fi +fi +RESTARTING=0 +if [ -f "$BASE_DIR"/"../admin/tmp/.restart" ]; then + RESTARTING=1 +fi +} + +ret=0 + +killwatch() +{ + WATCH_PROCS=`$PS_CMD | grep wswatch.sh | grep -v grep | wc -l` + if [ $WATCH_PROCS -gt 0 ]; then + killall wswatch.sh + fi +} + + +start() +{ + if [ -f "get_trial_key.sh" ]; then + ./get_trial_key.sh + fi + killwatch + if [ -f "$PIDFILE" ]; then + PID=`cat $PIDFILE` + else + PID="" + fi + + ./$EXECUTABLE + ret=$? + + + if [ $ret -eq 0 ]; then + NEW_PID=`cat $PIDFILE` + if [ "x$NEW_PID" = "x$PID" ] || [ "x$NEW_PID" = "x" ]; then + sleep 1 + NEW_PID=`cat $PIDFILE` + fi + echo "[OK] $DESC: pid=$NEW_PID." + test_running + if [ "x$WSWATCH" = "x1" ]; then + ./wswatch.sh & + fi + else + echo "[ERROR] Failed to start $DESC!" + fi +} + + +stop() +{ + killwatch + kill -USR2 $PID + kill $PID + ret=$? + if [ $ret -eq 0 ]; then +# if [ -f $PIDFILE ]; then +# sleep 1 +# fi + echo "[OK] $DESC: stopped." + else + echo "[ERROR] can not kill $DESC" + fi +} + + +do_restart() +{ + if [ $RUNNING -eq 1 ]; then + kill -USR1 $PID + ret=$? + if [ $ret -ne 0 ]; then + echo "[ERROR] cannot gracefully restart $DESC" + else + echo "[OK] Send SIGUSR1 to $PID" + fi + else + start + fi +} + +log7080() +{ + if [ "x$SYS_NAME" = "xLinux" ]; then + echo "checking port 7080 usage with netstat" >> $RESTART_LOG + netstat -anp | grep 7080 >> $RESTART_LOG + echo "checking port 7080 usage with lsof" >> $RESTART_LOG + lsof -i TCP:7080 >> $RESTART_LOG + fi +} + +restart() +{ + SPID=$PID + TRY=1 + if [ $RUNNING -eq 1 ]; then + do_restart + if [ $RESTARTING -eq 1 ]; then + exit 0 + fi + sleep 2 + test_running + else + if [ $RESTARTING -eq 1 ]; then + if [ -f $GRACEFUL_PIDFILE ]; then + GPID=`cat $GRACEFUL_PIDFILE` + if [ "x$GPID" != 'x' ]; then + if [ $GPID -ne 0 ] && [ $GPID -ne 1 ]; then + killall -9 $EXECUTABLE + fi + fi + fi + fi + start + sleep 2 + test_running + fi + while [ $TRY -lt 15 ] && [ "x$PID" = "x$SPID" ]; do + TRY=`expr $TRY + 1` + sleep 1 + test_running + done + + if [ $RUNNING -eq 0 ]; then + + echo "LSWS does not restart properly, check port 7080" >> $RESTART_LOG + #log7080 + killall -9 $EXECUTABLE + sleep 1 + echo "check port 7080 after kill all $EXECUTABLE processes " >> $RESTART_LOG + #log7080 + start + fi + +} + +reload() +{ + restart + +# kill -HUP $PID +# ret=$? +# if [ $ret -eq 0 ]; then +# echo "[OK] $DESC: configuration reloaded" +# else +# echo "[ERROR] Can't send SIGHUP to $DESC" +# fi +} + +help() { + echo $"Usage: $PROG {start|stop|restart|reload|condrestrt|try-restart|status|help}" + cat <> $RESTART_LOG +echo "$1, LSWS running: $RUNNING" >> $RESTART_LOG + +case "$1" in + start|restart) + restart + ;; + condrestart|try-restart) + if [ $RUNNING -eq 1 ]; then + restart + fi + ;; + status) + if [ $RUNNING -eq 1 ]; then + echo "$DESC is running with PID $PID." + else + echo "[ERROR] $DESC is not running." + fi + ;; + stop) + if [ $RUNNING -eq 0 ]; then + sleep 1 + test_running + fi + if [ $RUNNING -eq 1 ]; then + stop + else + echo "[ERROR] $DESC is not running." + ret=1 + fi + ;; + stophttpd) + if [ $RUNNING -eq 1 ]; then + kill $PID + fi + ;; + reload) + if [ $RUNNING -eq 1 ]; then + reload + else + echo "[ERROR] $DESC is not running." + ret=2 + fi + ;; + *) + help + ret=3 + ;; +esac +exit $ret \ No newline at end of file diff --git a/install/lscp/conf/mime.properties b/install/lscp/conf/mime.properties new file mode 100644 index 000000000..0b2781ed3 --- /dev/null +++ b/install/lscp/conf/mime.properties @@ -0,0 +1,160 @@ +default = application/octet-stream +3gp = video/3gpp +3g2 = video/3gpp2 +ai, eps = application/postscript +aif, aifc, aiff = audio/x-aiff +asc = text/plain +asf = video/asf +asx = video/x-ms-asf +au = audio/basic +avi = video/x-msvideo +bcpio = application/x-bcpio +bmp = image/bmp +bin = application/octet-stream +bz, bz2 = application/x-bzip +cdf = application/x-netcdf +class = application/java-vm +cpio = application/x-cpio +cpt = application/mac-compactpro +crt = application/x-x509-ca-cert +csh = application/x-csh +css = text/css +dcr,dir, dxr = application/x-director +dms = application/octet-stream +doc = application/msword +dtd = application/xml-dtd +dvi = application/x-dvi +eot = application/vnd.ms-fontobject +etx = text/x-setext +exe = application/x-executable +ez = application/andrew-inset +flv = video/x-flv +gif = image/gif +gtar = application/x-gtar +gz, gzip = application/gzip +hdf = application/x-hdf +hqx = application/mac-binhex40 +htc = text/x-component +html, htm = text/html +ice = x-conference/x-cooltalk +ico = image/x-icon +ief = image/ief +iges, igs = model/iges +iso = application/x-cd-image +java = text/plain +jar = application/java-archive +jnlp = application/x-java-jnlp-file +jpeg, jpe, jpg = image/jpeg +js = application/x-javascript +js2 = application/javascript +js3 = text/javascript +json = application/json +jsp = text/plain +kar = audio/midi +latex = application/x-latex +lha, lzh = application/octet-stream +man = application/x-troff-man +mdb = application/vnd.ms-access +me = application/x-troff-me +mesh = model/mesh +mid, midi = audio/midi +mif = application/vnd.mif +movie = video/x-sgi-movie +mov = video/quicktime +mp2, mp3, mpga = audio/mpeg +mpeg, mpe, mpg = video/mpeg +mp4 = video/mp4 +mpp = application/vnd.ms-project +ms = application/x-troff-ms +msh = model/mesh +nc = application/x-netcdf +oda = application/oda +odb = application/vnd.oasis.opendocument.database +odc = application/vnd.oasis.opendocument.chart +odf = application/vnd.oasis.opendocument.formula +odg = application/vnd.oasis.opendocument.graphics +odi = application/vnd.oasis.opendocument.image +odp = application/vnd.oasis.opendocument.presentation +ods = application/vnd.oasis.opendocument.spreadsheet +odt = application/vnd.oasis.opendocument.text +ogg = audio/ogg +otf = application/x-font-woff +pbm = image/x-portable-bitmap +pdb = chemical/x-pdb +pdf = application/pdf +pgm = image/x-portable-graymap +pgn = application/x-chess-pgn +pls = audio/x-scpls +png = image/png +pnm = image/x-portable-anymap +ppm = image/x-portable-pixmap +ppt = application/vnd.ms-powerpoint +ps = application/postscript +qt,qtvr = video/quicktime +ra = audio/x-realaudio +ram, rm = audio/x-pn-realaudio +rar = application/x-rar-compressed +ras = image/x-cmu-raster +rgb = image/x-rgb +roff, t, tr = application/x-troff +rss = application/rss+xml +rsd = application/rsd+xml +rtf = application/rtf +rtx = text/richtext +ser = application/java-serialized-object +sgml, sgm = text/sgml +sh = application/x-sh +shar = application/x-shar +shtml = application/x-httpd-shtml +silo = model/mesh +sit = application/x-stuffit +skd, skm, skp, skt = application/x-koan +smi,smil = application/smil +snd = audio/basic +spl = application/x-futuresplash +sql = text/x-sql +src = application/x-wais-source +sv4cpio = application/x-sv4cpio +sv4crc = application/x-sv4crc +svg, svgz = image/svg+xml +swf = application/x-shockwave-flash +tar = application/x-tar +tcl = application/x-tcl +tex = application/x-tex +texi, texinfo = application/x-texinfo +tgz = application/x-gtar +tiff, tif = image/tiff +tsv = text/tab-separated-values +ttf, ttc = application/x-font-ttf +txt = text/plain +ustar = application/x-ustar +vcd = application/x-cdlink +vrml = model/vrml +vxml = application/voicexml+xml +wav = audio/vnd.wave +wax = audio/x-ms-wax +wbmp = image/vnd.wap.wbmp +webp = image/webp +wma = audio/x-ms-wma +wml = text/vnd.wap.wml +wmlc = application/vnd.wap.wmlc +wmls = text/vnd.wap.wmlscript +wmlsc = application/vnd.wap.wmlscriptc +woff = application/font-woff +woff2 = font/woff2 +woff_o1 = application/x-font-woff +wtls-ca-certificate = application/vnd.wap.wtls-ca-certificate +wri = application/vnd.ms-write +wrl = model/vrml +xbm = image/x-xbitmap +xhtml, xht = application/xhtml+xml +xls = application/vnd.ms-excel +xml, xsd, xsl = application/xml +xml2 = text/xml +xslt = application/xslt+xml +xpm = image/x-xpixmap +xwd = image/x-xwindowdump +xyz = chemical/x-pdb +zip = application/zip +z = application/compress + diff --git a/install/lscp/conf/php.ini b/install/lscp/conf/php.ini new file mode 100644 index 000000000..34c8317bc --- /dev/null +++ b/install/lscp/conf/php.ini @@ -0,0 +1,4 @@ +[PHP] +post_max_size = 80M +upload_max_filesize = 20M + diff --git a/install/lscp/fcgi-bin/lsperld.fpl b/install/lscp/fcgi-bin/lsperld.fpl new file mode 100755 index 000000000..35a760a1b --- /dev/null +++ b/install/lscp/fcgi-bin/lsperld.fpl @@ -0,0 +1,149 @@ +#!/usr/bin/perl + +use FCGI; +#use strict; + +our %Cache; +use Symbol qw(delete_package); + +*CORE::GLOBAL::exit = \&my_exit; + +sub my_exit { +# warn "exit() was called"; +} + + + + +sub valid_package_name { + my($string) = @_; + $string =~ s/([^A-Za-z0-9\/])/sprintf('_%2x',unpack('C',$1))/eg; + # second pass only for words starting with a digit + $string =~ s|/(\d)|sprintf('/_%2x',unpack('C',$1))|eg; + + # Dress it up as a real package name + $string =~ s|/|::|g; + return 'LSPerld' . $string; +} + +sub execute_file { + my($__filename, $__delete) = @_; + my $__package; + my $__mtime; + my $__path; + my $__name; + return 404 if ( ! -r $__filename || -z _ ); + $__mtime = -M _; + if(defined $Cache{$__filename}[3] + && + $Cache{$__filename}[3] <= $__mtime) + { + # we have compiled this subroutine already, + # it has not been updated on disk, nothing left to do + #print STDERR "already compiled $package->handler\n"; + $__path = $Cache{$__filename}[0]; + $__name = $Cache{$__filename}[1]; + $__package = $Cache{$__filename}[2]; + chdir( $__path ); + } + else { + $__filename =~ /^(\/.*?)\/*([^\/]+)$/; + $__path = $1; + $__name = $2; + chdir( $__path ); + + local *FH; + open FH, $__filename or die "open '$__filename' $!"; + local($/) = undef; + my $__sub = ; + close FH; + + $__package = valid_package_name($__filename); + #wrap the code into a subroutine inside our unique package + my $__eval = qq{package $__package; use subs qw(exit); sub exit { } sub handler { local \$0='$__filename'; $__sub; }}; + { + # hide our variables within this block + my($__filename,$__mtime,$__package,$__sub); + eval $__eval; + } + if ( $@ ) + { + warn $@; + return 500; + + } + + #cache it unless we're cleaning out each time + if ( ! $__delete ) + { + #$Cache{$filename}{pkgname} = $package; + #$Cache{$filename}{mtime} = $mtime; + $Cache{$__filename} = [ $__path, $__name, $__package, $__mtime ]; + } + } + + $0=$__filename; + @ARGV = ( $__name ); + my $__QS = $ENV{'QUERY_STRING'}; + if (( $__QS ne '')&&(index( $__QS, '=' ) == -1 )) + { + push( @ARGV, split( $__QS ) ); + } + eval {$__package->handler;}; + + delete_package($__package) if $__delete; + return 0; + #take a look if you want + #print Devel::Symdump->rnew($package)->as_string, $/; +} + + +my $req = FCGI::Request(); +my $count = 0; +my $ret; +my $max_req = -1; +if ( $ENV{'FCGI_PERL_MAX_REQ'} eq '' ) +{ + $max_req = 500; +} +else +{ + $max_req = int($ENV{'FCGI_PERL_MAX_REQ'}); +} + +while($req->accept() >= 0) +{ + my $filename = $ENV{'SCRIPT_FILENAME'}; + + # Make it looks like ActiveState's PerlEx, otherwise CGI.pm won't reset + # request parameters + $ENV{'GATEWAY_INTERFACE'} = 'CGI-PerlEx/1.1'; + + if ( $filename ne '' ) + { + $ret = execute_file( $filename, 0 ); + ++$count; + if ( $ret ) + { + if ( $ret == 404 ) + { + print( "Status: 404\r\nContent-type: text/plain\r\n\r\n", + "ERROR: file not find: \'$filename\'!\n" ); + } + elsif ( $ret == 500 ) + { + print( "Status: 500\r\nContent-type: text/plain\r\n\r\n", + "ERROR: \'$filename\' is not a valid Perl script!\n" ); + } + } + } + else + { + print( "Content-type: text/plain\r\n\r\n", + "ERROR: missing environment variable \'SCRIPT_FILENAME\'!\n" ); + } + + $req->Finish(); + last if ( ( $max_req != 0 )&&( $count >= $max_req ) ); +} + diff --git a/install/lscp/fcgi-bin/lsphp b/install/lscp/fcgi-bin/lsphp new file mode 100755 index 000000000..7353b60d5 Binary files /dev/null and b/install/lscp/fcgi-bin/lsphp differ diff --git a/install/lscp/logs/access.log b/install/lscp/logs/access.log new file mode 100644 index 000000000..e69de29bb diff --git a/install/lscp/logs/error.log b/install/lscp/logs/error.log new file mode 100644 index 000000000..9bb457b6d --- /dev/null +++ b/install/lscp/logs/error.log @@ -0,0 +1,10 @@ +2018-09-18 06:38:39.581642 [NOTICE] Loading LiteSpeed/0.1.0 Open ... +2018-09-18 06:38:39.581657 [NOTICE] Using [OpenSSL 1.1.0i 14 Aug 2018] +2018-09-18 06:38:39.585545 [NOTICE] [AutoRestarter] new child process with pid=12238 is forked! +2018-09-18 06:38:39.589894 [NOTICE] [child: 12238] Successfully change current user to lscpd +2018-09-18 06:38:39.589931 [NOTICE] Child: 12238] Core dump is disabled. +2018-09-18 06:38:39.589989 [NOTICE] [Child: 12238] Setup swapping space... +2018-09-18 06:38:39.590167 [NOTICE] [Child: 12238] LiteSpeed/0.1.0 Open starts successfully! +2018-09-18 06:38:40.000485 [NOTICE] [PID: 12236]: forked cgid: 12241 +2018-09-18 06:39:39.062994 [INFO] checkStatusFile() called with uid 994 randoffset -1. +2018-09-18 06:39:39.063978 [INFO] checkStatusFile() return 0. diff --git a/install/lscp/logs/error.log.2018_09_18 b/install/lscp/logs/error.log.2018_09_18 new file mode 100644 index 000000000..e684ec7f1 --- /dev/null +++ b/install/lscp/logs/error.log.2018_09_18 @@ -0,0 +1,2 @@ +2018-09-18 06:38:39.581194 [WARN] Can not listen on address[/tmp/lscpd/cgid/cgid.sock.*]: No such file or directory, please clean up manually! +2018-09-18 06:38:39.581328 [ERROR] Cannot create a valid unix domain socket for CGI daemon. diff --git a/install/lscp/logs/lsrestart.log b/install/lscp/logs/lsrestart.log new file mode 100644 index 000000000..aa903f8b9 --- /dev/null +++ b/install/lscp/logs/lsrestart.log @@ -0,0 +1,2 @@ +Tue Sep 18 06:38:39 UTC 2018 +start, LSWS running: 0 diff --git a/install/lscp/logs/stderr.log b/install/lscp/logs/stderr.log new file mode 100644 index 000000000..e69de29bb diff --git a/install/lscp/modules/cache.so b/install/lscp/modules/cache.so new file mode 100755 index 000000000..d960c9e9f Binary files /dev/null and b/install/lscp/modules/cache.so differ diff --git a/install/lscp/modules/modinspector.so b/install/lscp/modules/modinspector.so new file mode 100755 index 000000000..1afe8810f Binary files /dev/null and b/install/lscp/modules/modinspector.so differ diff --git a/install/lscp/modules/modreqparser.so b/install/lscp/modules/modreqparser.so new file mode 100755 index 000000000..937fb78d2 Binary files /dev/null and b/install/lscp/modules/modreqparser.so differ diff --git a/install/lscp/modules/uploadprogress.so b/install/lscp/modules/uploadprogress.so new file mode 100755 index 000000000..d7d855469 Binary files /dev/null and b/install/lscp/modules/uploadprogress.so differ diff --git a/install/lscp/share/autoindex/bwlimit.html b/install/lscp/share/autoindex/bwlimit.html new file mode 100644 index 000000000..965f42909 --- /dev/null +++ b/install/lscp/share/autoindex/bwlimit.html @@ -0,0 +1,128 @@ + +509 Bandwidth Limit Exceeded + +

Bandwidth Limit Exceeded

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +The server is temporarily unable to service your request due to the site owner reaching his/her bandwidth limit. Please try again later. + +
+ diff --git a/install/lscp/share/autoindex/default.php b/install/lscp/share/autoindex/default.php new file mode 100644 index 000000000..d28142a37 --- /dev/null +++ b/install/lscp/share/autoindex/default.php @@ -0,0 +1,434 @@ +nameFormat = '%-' . ($this->nameWidth + 4) . '.' . ($this->nameWidth + 4) .'s'; + } +} + +class IMG_Mapping +{ + var $suffixes; + var $imageName; + var $desc; + var $alt; + function IMG_Mapping( $arrSuffix, $imgName, $altName, $descr ) + { + $this->suffixes = $arrSuffix; + $this->imageName = $imgName; + $this->alt = $altName; + $this->desc = $descr; + } + function found($ext) + { + return in_array($ext, $this->suffixes); + } +} + +class AllImgs +{ + var $mapping, $default_img, $dir_img; + + function AllImgs() + { + $this->mapping = array( + new IMG_Mapping( array( 'gif', 'png', 'jpg', 'jpeg', 'tif', 'tiff', 'bmp', 'svg', 'raw'), + 'image.png', '[IMG]', '' ), + new IMG_Mapping( array( 'html', 'htm', 'shtml', 'php', 'phtml', + 'css', 'js' ), + 'html.png', '[HTM]', '' ), + new IMG_Mapping( array( 'txt', 'md5', 'c', 'cpp', 'cc', 'h', 'sh' ), + 'text.png', '[TXT]', '' ), + new IMG_Mapping( array( 'gz', 'tgz', 'zip', 'Z', 'z'), + 'compress.png', '[CMP]', '' ), + new IMG_Mapping( array( 'bin', 'exe' ), + 'binary.png','[BIN]', '' ), + new IMG_Mapping( array( 'mpg', 'avi', 'mpeg', 'ram', 'wmv' ), + 'movie.png','[VID]', '' ), + new IMG_Mapping( array( 'mp3', 'mp2', 'ogg', 'wav', 'wma', + 'aac', 'mp4', 'rm'), + 'sound.png', '[SND]', '' ) + + ); + + $this->default_img = new IMG_Mapping( NULL, 'unknown.png', 'unknown', '' ); + $this->dir_img = new IMG_Mapping( NULL, 'folder.png', 'directory', '' ); + $this->parent_img = new IMG_Mapping( NULL, 'up.png', 'up', '' ); + } + + function findImgMapping($file) + { + $found = NULL; + $pos = strrpos( $file, '.' ); + if ( $pos !== FALSE ) + { + $ext = substr($file, $pos+1); + if ( $ext !== FALSE ) + { + $l = count($this->mapping); + for ( $i = 0 ; $i < $l ; ++$i ) + { + if ( in_array($ext, $this->mapping[$i]->suffixes) ) + { + $found = $this->mapping[$i]; + break; + } + } + } + } + if ( !isset($found) ) + $found = $this->default_img; + return $found; + } +} + +// END of customization section + + + +class FileStat +{ + var $name; + var $size; + var $mtime; + var $isdir; + var $img; + + function FileStat($filename) + { + $this->name = $filename; + } +} + +function shouldExclude( $file, &$excludes ) +{ + $ex = reset( $excludes ); + foreach( $excludes as $ex ) + { + if ( fnmatch( $ex, $file ) ) + return true; + } + return false; +} + +function readDirList( $path, &$excludes, &$map ) +{ + $handle = opendir( $path ); + if ( $handle === false ) + { + return null; + } + clearstatcache(); + $list = array(); + if ( isset( $_SERVER['LS_AI_INDEX_IGNORE'] ) ) + { + $ignore = explode( ' ', $_SERVER['LS_AI_INDEX_IGNORE'] ); + $excludes = array_merge( $ignore, $excludes ); + } + while( false !== ($file=readdir($handle)) ) + { + if ( shouldExclude( $file, $excludes ) ) + continue; + $fileStat = new FileStat($file); + $s = stat("$path$file"); + $fileStat->mtime = $s[9]; + $fileStat->isdir = ($s[2] & 040000)? '/':''; + + // get image mapping + if ( $fileStat->isdir ) + { + $fileStat->size = -1; + $fileStat->img = $map->dir_img; + } + else + { + if ( $s[12] > 0 ) + $fileStat->size = 512*$s[12]; + else + $fileStat->size = $s[7]; + $fileStat->img = $map->findImgMapping($file); + } + + $list[] = $fileStat; + } + closedir( $handle ); + return $list; +} + +function printOneEntry( $base, $name, $fileStat, $setting ) +{ + $encoded = str_replace(array('%2F', '%26amp%3B'), array('/', '%26'), + rawurlencode( $base . $fileStat->name )); + if ( isset($_SERVER['LS_FI_OFF'])&& $_SERVER['LS_FI_OFF'] ) + { + $buf = '
  • ' . '' . sprintf( $setting->nameFormat, $name."
  • \n"); + } + else + { + $buf = '' . $fileStat->img->alt . ' '; + if ( strlen( $name ) > $setting->nameWidth ) + { + $name = substr( $name, 0, $setting->nameWidth - 3 ). '...'; + } + $buf .= sprintf( $setting->nameFormat, $name.""); + if ( $fileStat->mtime != -1 ) + $buf .= date($setting->Time_Format, $fileStat->mtime); + else + $buf .= ' '; + if ( $fileStat->size != -1 ) + $buf .= sprintf( "%7ldk ", ( $fileStat->size + 1023 ) / 1024); + else + $buf .= ' - '; + $buf .= ' ' . $fileStat->img->desc; + $buf .= "\n"; + } + echo $buf; + +} + +function printIncludes( $path, $name ) +{ + $testNames = array( "$name.html", "$name.htm", $name ); + foreach ( $testNames as $n ) + { + $filename = $path . $n; + + if ( file_exists($filename) ) + { + $content = file_get_contents($filename); + if ( $n == $name ) + { + echo "
    \n";
    +                echo $content;
    +                echo "
    \n"; + } + else + echo $content; + break; + } + } +} + +function printFileList( $list, $base_uri, $setting ) +{ + foreach( $list as $fileStat ) + { + if ( $fileStat->isdir ) + { + printOneEntry( $base_uri, $fileStat->name, $fileStat, $setting ); + } + } + + foreach( $list as $fileStat ) + { + if ( !$fileStat->isdir ) + { + printOneEntry( $base_uri, $fileStat->name, $fileStat, $setting ); + } + } + +} + + +function cmpNA( $a, $b ) +{ + return strcmp( $a->name, $b->name ); +} + +function cmpND( $a, $b ) +{ + return -cmpNA( $a, $b ); +} + +function cmpSA( $a, $b ) +{ + $ret = $a->size - $b->size; + if ( $ret ) + return $ret; + return cmpNA( $a, $b ); +} + +function cmpSD( $a, $b ) +{ + return -cmpSA( $a, $b ); +} + +function cmpMA( $a, $b ) +{ + return $a->mtime - $b->mtime; + +} + +function cmpMD( $a, $b ) +{ + return -cmpMA( $a, $b ); +} + +function cmpDA( $a, $b ) +{ + $ret = strcmp( $a->img->desc, $b->img->desc ); + if ( $ret ) + return $ret; + return strcmp( $a->name, $b->name ); +} + +function cmpDD( $a, $b ) +{ + return -cmpDA( $a, $b ); +} + + + + +//phpinfo(); +$pos = strpos( $_SERVER['REQUEST_URI'], '?' ); +if ( $pos === FALSE ) +{ + $uri = $_SERVER['REQUEST_URI']; +} +else +{ + $uri = substr( $_SERVER['REQUEST_URI'], 0, $pos ); +} + +$uri = urldecode( $uri ); +$path = $_SERVER['LS_AI_PATH']; + +$mime_type = $_SERVER['LS_AI_MIME_TYPE']; +if ( $mime_type ) + header( "Content-Type: $mime_type" ); + +if ( !$path ) +{ + echo "[ERROR] Auto Index script can not be accessed directly!"; + return ; +} + + +if (get_magic_quotes_gpc()) +{ + $uri = stripslashes( $uri ); + $path = stripslashes( $path ); +} + +$uri = htmlentities($uri,ENT_COMPAT,"UTF-8"); + +$setting = new UserSettings(); +$map = new AllImgs(); +$sortOrder = $_SERVER['QUERY_STRING']; +if ( $sortOrder == '' + || strlen($sortOrder) > 2 + || ! in_array($sortOrder, array('NA','ND','MA','MD','SA','SD','DA','DD'))) { + $sortOrder = 'NA'; // set to default +} + +$NameSort = ($sortOrder == 'NA') ? 'ND' : 'NA'; +$ModSort = ($sortOrder == 'MA') ? 'MD' : 'MA'; +$SizeSort = ($sortOrder == 'SA') ? 'SD' : 'SA'; +$DescSort = ($sortOrder == 'DA') ? 'DD' : 'DA'; + +if ( !$path ) +{ + header("HTTP/1.1 403 Forbidden" ); + echo "

    403 Access Denied

    "; + exit; +} +else +{ + $list = readDirList( $path, $setting->Exclude_Patterns, $map ); + if ( $list === null ) + { + header("HTTP/1.1 403 Forbidden" ); + echo "

    403 Access Denied

    "; + exit; + } +} + + +echo " + + + + Index of ", $uri, " + +

    Index of ", $uri, "

    "; + +if ( isset($setting->HeaderName) ) + printIncludes( $path, $setting->HeaderName ); + +if ( isset($_SERVER['LS_FI_OFF'])&& $_SERVER['LS_FI_OFF'] ) +{ + $header = "
      \n"; +} +else +{ + $header = "
      IconPath/blank.png\" alt=\"     \"> ";
      +    $header .= sprintf( $setting->nameFormat, 'Name' );
      +    $header .= " Last modified         Size  Description \n   
      "; +} +echo $header; + +if ( $uri != '/' ) +{ + $fileStat = new FileStat(''); + $fileStat->mtime = filemtime($path); + $fileStat->img = $map->parent_img; + $fileStat->size = -1; + $base = substr( $uri, 0, strlen( $uri ) - 1 ); + $off = strrpos( $base, '/' ); + if ( $off !== FALSE ) + { + $base = substr( $base, 0, $off + 1 ); + printOneEntry( $base, "Parent Directory", $fileStat, $setting ); + } + +} +$cmpFunc = "cmp$sortOrder"; +usort( $list, $cmpFunc ); +printFileList( $list, $uri, $setting ); + +if ( isset($_SERVER['LS_FI_OFF'])&& $_SERVER['LS_FI_OFF'] ) +{ + echo "
    \n"; +} +else +{ + echo "
    "; +} + +if ( isset($setting->ReadmeName) ) { + printIncludes( $path, $setting->ReadmeName ); +} + +echo "
    Proudly Served by LiteSpeed Web Server at ".$_SERVER['SERVER_NAME']." Port ".$_SERVER['SERVER_PORT']."
    + +"; diff --git a/install/lscp/share/autoindex/icons/binary.png b/install/lscp/share/autoindex/icons/binary.png new file mode 100644 index 000000000..ff27e84de Binary files /dev/null and b/install/lscp/share/autoindex/icons/binary.png differ diff --git a/install/lscp/share/autoindex/icons/blank.png b/install/lscp/share/autoindex/icons/blank.png new file mode 100644 index 000000000..a91d98a98 Binary files /dev/null and b/install/lscp/share/autoindex/icons/blank.png differ diff --git a/install/lscp/share/autoindex/icons/compress.png b/install/lscp/share/autoindex/icons/compress.png new file mode 100644 index 000000000..59e7e90c7 Binary files /dev/null and b/install/lscp/share/autoindex/icons/compress.png differ diff --git a/install/lscp/share/autoindex/icons/folder.png b/install/lscp/share/autoindex/icons/folder.png new file mode 100644 index 000000000..68f7e8688 Binary files /dev/null and b/install/lscp/share/autoindex/icons/folder.png differ diff --git a/install/lscp/share/autoindex/icons/html.png b/install/lscp/share/autoindex/icons/html.png new file mode 100644 index 000000000..bead1092d Binary files /dev/null and b/install/lscp/share/autoindex/icons/html.png differ diff --git a/install/lscp/share/autoindex/icons/image.png b/install/lscp/share/autoindex/icons/image.png new file mode 100644 index 000000000..b6b09ed41 Binary files /dev/null and b/install/lscp/share/autoindex/icons/image.png differ diff --git a/install/lscp/share/autoindex/icons/movie.png b/install/lscp/share/autoindex/icons/movie.png new file mode 100644 index 000000000..80f18a9e0 Binary files /dev/null and b/install/lscp/share/autoindex/icons/movie.png differ diff --git a/install/lscp/share/autoindex/icons/sound.png b/install/lscp/share/autoindex/icons/sound.png new file mode 100644 index 000000000..ca40f3e71 Binary files /dev/null and b/install/lscp/share/autoindex/icons/sound.png differ diff --git a/install/lscp/share/autoindex/icons/text.png b/install/lscp/share/autoindex/icons/text.png new file mode 100644 index 000000000..c6f59b5c6 Binary files /dev/null and b/install/lscp/share/autoindex/icons/text.png differ diff --git a/install/lscp/share/autoindex/icons/unknown.png b/install/lscp/share/autoindex/icons/unknown.png new file mode 100644 index 000000000..89e42e000 Binary files /dev/null and b/install/lscp/share/autoindex/icons/unknown.png differ diff --git a/install/lscp/share/autoindex/icons/up.png b/install/lscp/share/autoindex/icons/up.png new file mode 100644 index 000000000..4a2e23f48 Binary files /dev/null and b/install/lscp/share/autoindex/icons/up.png differ diff --git a/plogical/website.py b/plogical/website.py index e882dbb8a..5823dbe5b 100644 --- a/plogical/website.py +++ b/plogical/website.py @@ -144,7 +144,7 @@ class WebsiteManager: if ACLManager.currentContextPermission(currentACL, 'createWebsite') == 0: return ACLManager.loadErrorJson('createWebSiteStatus', 0) - domain = data['domainName'] + domain = data['domainName'].lstrip('http://').lstrip('https://').rstrip('/') adminEmail = data['adminEmail'] phpSelection = data['phpSelection'] packageName = data['package'] @@ -159,7 +159,7 @@ class WebsiteManager: ## Create Configurations - execPath = "sudo python " + virtualHostUtilities.cyberPanel + "/plogical/virtualHostUtilities.py" + execPath = "sudo /usr/local/CyberCP/bin/python2 " + virtualHostUtilities.cyberPanel + "/plogical/virtualHostUtilities.py" execPath = execPath + " createVirtualHost --virtualHostName " + domain + \ " --administratorEmail " + adminEmail + " --phpVersion '" + phpSelection + \ "' --virtualHostUser " + externalApp + " --ssl " + str(data['ssl']) + " --dkimCheck " \ @@ -186,7 +186,7 @@ class WebsiteManager: admin = Administrator.objects.get(pk=userID) masterDomain = data['masterDomain'] - domain = data['domainName'] + domain = data['domainName'].lstrip('http://').lstrip('https://').rstrip('/') phpSelection = data['phpSelection'] path = data['path'] tempStatusPath = "/home/cyberpanel/" + str(randint(1000, 9999)) diff --git a/static/websiteFunctions/websiteFunctions.js b/static/websiteFunctions/websiteFunctions.js index e61bd4640..fbf022336 100644 --- a/static/websiteFunctions/websiteFunctions.js +++ b/static/websiteFunctions/websiteFunctions.js @@ -2389,6 +2389,38 @@ app.controller('websitePages', function ($scope, $http, $timeout, $window) { } + // REWRITE Template + + const httpToHTTPS = `### Rewrite Rules Added by CyberPanel Rewrite Rule Generator + +RewriteEngine On +RewriteCond %{HTTPS} !=on +RewriteRule ^/?(.*) https://%{SERVER_NAME}/$1 [R,L] + +### End CyberPanel Generated Rules. + +`; + + const nonWWWToWWW = `### Rewrite Rules Added by CyberPanel Rewrite Rule Generator + +RewriteEngine On +RewriteCond %{HTTP_HOST} !^www\. [NC] +RewriteRule ^(.*)$ http://www.%{HTTP_HOST}%{REQUEST_URI} [R=301,L] + +### End CyberPanel Generated Rules. + +`; + + $scope.applyRewriteTemplate = function () { + + if($scope.rewriteTemplate === "Force HTTP -> HTTPS"){ + $scope.rewriteRules = httpToHTTPS + $scope.rewriteRules; + }else if($scope.rewriteTemplate === "Force NON-WWW -> WWW"){ + $scope.rewriteRules = nonWWWToWWW + $scope.rewriteRules; + } + }; + + }); /* Java script code to create account ends here */ diff --git a/websiteFunctions/static/websiteFunctions/websiteFunctions.js b/websiteFunctions/static/websiteFunctions/websiteFunctions.js index e61bd4640..fbf022336 100644 --- a/websiteFunctions/static/websiteFunctions/websiteFunctions.js +++ b/websiteFunctions/static/websiteFunctions/websiteFunctions.js @@ -2389,6 +2389,38 @@ app.controller('websitePages', function ($scope, $http, $timeout, $window) { } + // REWRITE Template + + const httpToHTTPS = `### Rewrite Rules Added by CyberPanel Rewrite Rule Generator + +RewriteEngine On +RewriteCond %{HTTPS} !=on +RewriteRule ^/?(.*) https://%{SERVER_NAME}/$1 [R,L] + +### End CyberPanel Generated Rules. + +`; + + const nonWWWToWWW = `### Rewrite Rules Added by CyberPanel Rewrite Rule Generator + +RewriteEngine On +RewriteCond %{HTTP_HOST} !^www\. [NC] +RewriteRule ^(.*)$ http://www.%{HTTP_HOST}%{REQUEST_URI} [R=301,L] + +### End CyberPanel Generated Rules. + +`; + + $scope.applyRewriteTemplate = function () { + + if($scope.rewriteTemplate === "Force HTTP -> HTTPS"){ + $scope.rewriteRules = httpToHTTPS + $scope.rewriteRules; + }else if($scope.rewriteTemplate === "Force NON-WWW -> WWW"){ + $scope.rewriteRules = nonWWWToWWW + $scope.rewriteRules; + } + }; + + }); /* Java script code to create account ends here */ diff --git a/websiteFunctions/templates/websiteFunctions/website.html b/websiteFunctions/templates/websiteFunctions/website.html index addddb5fc..431f6695b 100644 --- a/websiteFunctions/templates/websiteFunctions/website.html +++ b/websiteFunctions/templates/websiteFunctions/website.html @@ -443,7 +443,7 @@

    -
    +
    @@ -659,13 +659,29 @@
    -

    {% trans "Current rewrite rules in the file fetched." %} Click +

    {% trans "It is not required to modify rules if you are using OpenLiteSpeed." %} + Click to read more about whats changed in rewrite - rules from v1.7 onwards.

    + rules from v1.8 onwards.

    + + +
    + +
    + +
    +
    + +
    +

    {% trans "Could not fetch current rewrite rules. Error message:" %} {$ errorMessage $}

    @@ -697,7 +713,7 @@
    -
    @@ -893,7 +909,7 @@
    -
    +
    @@ -902,16 +918,17 @@
    -