Skip to main content

There's more than Cpanel in this world

My brother bought simple local e-commerce application. PHP application actually. It's quite simple, the typical add to cart stuff with extra features to track affiliation. Nothing that Drupal/Ubercart can't do. But I can see a reason for people to buy that. Buying off the shelf software is cheap (provided it work out of the box) compared to developer's time to setup an open source equivalent.

I'm hosting all my brother's website so for this one I just created another user inside my Webfaction account, point the php/symlink application to the DocumentRoot inside that user's home directory, create mysql database and all set to go. But there's one problem. Clicking on certain link that supposed to open a popup just load up the main page instead of the desired page.

Since it look like a routing problem, I take look at .htaccess file. There seem to be few rules that route incoming url to the php file. Looking at source code, it turned me off a lot. IonCube encoded. Nah, I can see a reason for them to protect their hardwork. But for me to debug some 'proprietary' code ? No way. So I just asked my brother to request a support.

The first response said that the .htaccess file cannot be uploaded. I don't know how he come to the conclusion. The file is there. So I replied (to my brother) to let them know that the file is there, attached a copy of that file and asked them to verify whether the file is correct or not. I'd also mentioned that mod_rewrite is enabled, in case they're thinking of that. Some other rewrite is working so there's no reason to say mod_rewrite not working.

Another reply that really made me think enough is enough. They're complaining that they can't access something like http://thesite.com/cpanel or http://thesite.com:2083/cpanel. Wth .... so there must be a cpanel in all hosting in this world ??? The problem is simple enough to debug, writing this blog post would take much longer than that.

What I did was rename index.php to index2.php and create my own index.php. There I just print_r($_SERVER) to see all the incoming request variables. Everything look quite ordinary except for the DOCUMENT_ROOT value. My main webfaction account is at /home/myname and the DocumentRoot is located at /home/myname/webapps/thesite which is a symlink to /home/seconduser/thesite. For some reason, the DOCUMENT_ROOT value that end up in the $_SERVER variable is /home/myname/webapps/_ rather than /home/seconduser/thesite. Looked back into the .htaccess file and there's a rule that use %DOCUMENT_ROOT (RewriteCond %{DOCUMENT_ROOT}%1.php -f) which basically check if the %1.php file exists or not otherwise redirect the request to index.php. So that is it. Since DOCUMENT_ROOT value is wrong, the rule doesn't match and always redirect to index.php. My fix - hardcode the DOCUMENT_ROOT value in the rule. Done.

I'm not that annoyed if this is just some open source project. I'm more than willing to spare some of my time identifying the problem and creating patch if required. But for something that need to pay and I can't even read the code, I deserved this rant.

Comments

Popular posts from this blog

PHP with docker

A friend asking about a PHP library and I decided to test whether that library is working. But I don't have PHP environment setup (we're Python shop btw). But thanks to docker, that's easy these days. docker run -it --tty --rm --volume $PWD:/app --user $(id -u):$(id -g) composer require google/apiclient:^2.0 Then we just need to create the script to run, still in the same directory:- include_once __DIR__ . '/vendor/autoload.php'; $GCSE_API_KEY = "nqwkoigrhe893utnih_gibberish_q2ihrgu9qjnr"; $GCSE_SEARCH_ENGINE_ID = "937592689593725455:msi299dkne4de"; $client = new Google_Client(); $client->setApplicationName("My_App"); $client->setDeveloperKey($GCSE_API_KEY); $service = new Google_Service_Customsearch($client); $optParams = array("cx"=>self::GCSE_SEARCH_ENGINE_ID); $results = $service->cse->listCse("lol cats", $optParams); And we can run that script again using docker:- docker run -it --...

Ubuntu 22.04 Wayland share screen

 After switching to Dell XPS 13 which running Ubuntu 22.04, I noticed that trying to share screen through Google Meet, it shows this:-    This - Use operating system settings, I never saw it before. Usually here we will be presented the windows that we want to share.  It turned out that screen sharing in Ubuntu 22.04 indeed an issue, due to the use of Wayland instead of Xorg as its display server. Many suggested to disable wayland and back to use Xorg. I try to avoid that since Wayland seems to works fine so far. After some searching, the conclusion seems we can make this working by installing some packages. sudo apt install xdg-desktop-portal xdg-desktop-portal-gnome But it turned out that I have already installed the packages! So what were the problems?  Well, turn out it's more psychological than technical. Since the pop up is different than what I'm used to before, I never click the allow button. But clicking the allow button we will see this:-   Which...

The rise of localhost

I noticed a pattern in dex world, where you build client backend to participate in the network, and then build a web app that simply connect to  localhost:someport  for the UI. To check my scuttlebutt updates, I opened up http://localhost:8027/. For those using Ethereum Parity wallet, they can open it at http://localhost:8180/. ZeroNet users are browsing at http://localhost:43110/. But Parity for example, try to make it seamless, they still provide a dns - web3.site which then redirected to home.web3.site which simply resolved to 127.0.0.1. But this I think bring up some problem, especially non-tech user which think that Parity is a website hosted by Parity Technologies. I seen this in a some articles about the latest bug .