2023年5月7日日曜日

MacOS Venture に PHPを入れて PukiWiki を移行した

 


Pukiwiki でメモしたデータがあるので Mac Mini M2 に持っていく。

PukiWiki は PHP のアプリケーションであるため、PHP を動かさなければならない。

  1. Mac Mini M2 で Apacheを動かした時、PHPがサポートされていないので CGI で動かす設定をしたが、これだけではだめなようなので、結局、PHP をインストールした。
  2. インストールした PHPは「署名して認証」しないと動かなかった。
  3. PukiWiki は最新版にアップデートする必要があった。

PHP インストール


$ brew install php
...
$ To enable PHP in Apache add the following to httpd.conf and restart Apache:
LoadModule php_module /opt/homebrew/opt/php/lib/httpd/modules/libphp.so

<FilesMatch \.php$>
SetHandler application/x-httpd-php
</FilesMatch>

Finally, check DirectoryIndex includes index.php
DirectoryIndex index.php index.html

The php.ini and php-fpm.ini file can be found in:
/opt/homebrew/etc/php/8.2/

To start php now and restart at login:
brew services start php

httpd.conf を編集したが、エラーがでている。

 $ apachectl configtest
 [Fri Feb 24 20:46:41.855315 2023] [so:error] [pid 13516]
 AH06665: No code signing authority for module
 at /opt/homebrew/opt/php/lib/httpd/modules/libphp.so specified in LoadModule directive.

apachectl restart したが

 <?php
  phpinfo();
 ?>

phpinfo() も動かない。Apache のエラーログを見たところ、error が吐かれている。


$ cat /private/var/log/apache2/error_log

'/opt/homebrew/Cellar/php/8.2.3/lib/php/20220829/opcache.so' not valid
for use in process: mapped file has no Team ID and is not a platform binary
(signed with custom identity or adhoc?)), ....

署名して認証


~/Library/Keychains に login.keychain-db ファイルを確認して codesign を実行。


$ codesign --sign "myCA" --force --keychain ~/Library/Keychains/login.keychain-db \
/opt/homebrew/opt/php/lib/httpd/modules/libphp.so

httpd.conf に署名。

LoadModule php_module /opt/homebrew/opt/php/lib/httpd/modules/libphp.so "myCA"


PukiWki

phpinfo() は動いたが、PukiWiki は動かない。
index.php の error_reportting(E_ALL) をコメントアウトしたところ

<?php
// PukiWiki - Yet another WikiWikiWeb clone.
// $Id: index.php,v 1.9 2006/05/13 07:39:49 henoheno Exp $
// Copyright (C) 2001-2006 PukiWiki Developers Team
// License: GPL v2 or (at your option) any later version

// Error reporting
//error_reporting(0); // Nothing
error_reporting(E_ERROR | E_PARSE); // Avoid E_WARNING, E_NOTICE, etc
//error_reporting(E_ALL); // Debug purpose

エラーが表示された。
「Fatal error: Array and string offset access syntax with curly braces is no longer supported in /Users/xxx/pukiwiki/lib/func.php on line 607」

https://pukiwiki.osdn.jp/?FAQ/45 によると

「PukiWiki 1.4.7 はPHP5.4以降に対応しておらず、まったく動作しません。PukiWiki 1.5.0 へのバージョンアップを行ってください。」

とのことなので最新版の 1.5.4 をダウンロードして展開して 
 pukiwiki/wiki/ フォルダのファイルを以前の wiki フォルダで上書きした。

PukiWiki はちゃんとメンテナンスされているようで、よかった。


参考

【macOS 12 Monterey】コード署名証明書によるPHPモジュール有効化 
https://pointsandlines.jp/server-side/php/code-signing-in-macos-monterey

Mac Mini M2とWindowsで共有できるSDカードにパスワードを設定



以前、 SSDに dmg ファイルを作成しパスワード設定していたが、これだとWindowsでは利用できない。

ChatGPTに”WindowsとMacで共有できてパスワードが設定できるSDカードの作り方を教えて”と聞いてみたら「TrueCrypt」を教えてくれた。

VeraCrypt が後継のようなのでインストールしようとしたところ、MacFUSEも必要そうなので、確認したところ

"ただし、注意点として、MacFUSEは古いバージョンのMac OS Xでのみサポートされています。Mac OS X 10.13 High Sierra以降のバージョンでは、macOSのセキュリティ機能が更新されたため、MacFUSEを使用する場合は、一部の設定変更が必要となります。したがって、使用する前に、必ず公式サイトやドキュメントを確認してください。"

といわれた。

実際、MacFUSE と VeraCrypt をインストールして利用を進めると
「電源ボタンを長押し ... 起動セキュリティーユーティリティで...」と表示された。

シリコンMac(Mac Mini M2)の場合、10秒以上電源ボタンを長押しして起動すると、メンテナンス画面になるので「オプション」を選択して、画面左上のメニューの「ユーティリティ」を選ぶのがポイントだった。

 Windowsの方にも VeraCrypt を入れて 256GBのSDカードに130GBのストレージを作成したが、フォーマットに30分以上かかったのではないだろうか。


参考

Appleシリコンを搭載したMacのセキュリティーポリシー変更手順
https://support.d-imaging.sony.co.jp/mac/security/11/ja/index.html

2018年4月9日月曜日

Migration Python2.7への移行

1. 以前のプログラムのソースをダウンロードして、 app.xml を変更して deployする

503 python -V   // まず Mac にインストールされている python のバージョンを確認
504 pwd
505 curl https://sdk.cloud.google.com | bash // google cloud SDK のインストール
506 source ./.bash_profile 
510 cd google-cloud-sdk/  // 以前作成したアプリのダウンロードの準備
514 mkdir google-cloud
515 cd google-cloud
516 appcfg.py download_app -A snsimglink-hrd -V 1 ./ -oauth2  // appcfg.py がみつからない
517 python appcfg.py download_app -A snsimglink-hrd -V 1 ./ -oauth2 // 無駄な試み 
519 cd ..
520 cd google-cloud-sdk/
523 find . -name appcfg.py -print  // みあたらない
527 pip install google-cloud-storage // google-cloud-storage をいれればいいのか? 
528 sudo easy_install pip   // pip がなかったのでまず pip を install
529 pip install --upgrade google-cloud-storage

// https://cloud.google.com/appengine/docs/standard/python/download#appengine_sdk 
// appcfg.py を入手するには
// 以前の GoogleAppEngineLauncher-1.9.68.dmg 
// をインストールする必要があった
537 cd google-cloud 
// google cloud のコンソールで application の名前とバージョンを確認
540 appcfg.py -A museum-in-cloud-hrd -V 1 download_app ./museum-in-cloud
543 cd snsimglink/
547 dev_appserver.py . // 試しにローカルで動かそうとするもいろいろエラーで動かない
548 gcloud app deploy
549 cloudg auth login
550 cloudg app deploy
551 cloudg config set project museum-in-cloud-hrd

553 gcl app deoudloyp  // app.xmlappclitaion, version をコメントアウト
      ERROR: 
      (gcloud.app.deploy) The [application] field is specified in file ..
      (gcloud.app.deploy) The [version] field is specified in file ..
 ...
        This field is not used by gcloud and must be removed. 
    Versions are generated automatically by default but can also be manually specified 
    by setting the `--version` flag on individual command executions.

555 gcloud app deploy -v 2 // バージョン指定しないと deploy するたびに新しいバージョンになってしまう

2.  webapp を webapp2 にdjango を jinja2 に変更する

Python2.7 でも django はサポートされているようなので引き続き使おうとしたが
サンプルプログラムを動かすために SQL Cloud などの設定も必要

gusestbook のサンプルプログラムが更新されていて、ここで jinja2 が使われていたので、
jinja2 を利用することにした。
app.xml
---
#application: museum-in-cloud-hrd
#version: 1
#runtime: python
runtime: python27
api_version: 1
threadsafe: true

handlers:

- url: /blog
#  script: hw_blog.py
  script: hw_blog.app

libraries:
- name: webapp2
  version: latest
- name: jinja2
  version: latest
#- name: django
#  version: "1.2"

hw.py
---
#from google.appengine.ext import webapp
import webapp2
import jinja2
JINJA_ENVIRONMENT = jinja2.Environment(
loader=jinja2.FileSystemLoader(os.path.dirname(__file__)+"/templates4j"),  //この環境固有
    extensions=['jinja2.ext.autoescape'],
    autoescape=True)
#from google.appengine.ext import vendor
#vendor.add('lib')

3.   jinja2 用に templateファルを変更する

 ifequal endifequal を if endif 
{% value %} を {{ value }} に変更
変数の中に html のタグなどを記述していた場合は {{ value | safe }} とする

4.  準備中

準備中
console
参考






2013年4月4日木曜日

StoryBoard push segue sample

1 StoryBoard によりButtonを配置して、右クリックしながら次の ControllerViewの画面までドラッグし、modalと接続することでコードの記述なしで画面の遷移を実装することができます。
  1. push segue (push セグエ)
    NavigationBarを用意して画面遷移をする場合に利用する。
    NavigationBarを用意せずに、Push形式でSegueを作成してはいけません。
  2. modal segue (modal セグエ)
    NavigationBarを使わずにビュー間を移動する場合に利用する。
    Modalセグエ(モーダル セグエ)で遷移すると、ソースビュー(遷移元ビュー)の上にターゲットビュー(遷移先ビュー)が生成され重ねられます。従って、モーダルでループ遷移は作らないようにしてください。
  3. custom segue (custom セグエ)
    UIStoryboardSegueクラスを継承したサブクラスを作成することで、トランジション効果を独自に演出することができます
  4. relation ship (関係:リレーション)
    リレーションはシーンとシーンをつなぐ接続の一種ですが、セグエではありません。
    TabBarControllerと各Tabbarのボタンに関連付けられてる子ビューをつなげる場合などに使います。























2.  tab sample





















3  push sample

先頭の NavigationControllerなしで push を使用すると以下のようなエラーとなります

*** Terminating app due to uncaught exception 'NSGenericException', reason: 'Push segues can only be used when the source controller is managed by an instance of UINavigationController.'























参考


画面間のデータの受け渡し

Storyboard上でビュー上に配置したボタンを右クリックしながら遷移させたいビューまでドラッグして接続するだけです。このときにpush, modal, customの3つの遷移の仕方が選べます。pushは次のビューが右から左に出てくるエフェクトで、modalは下から上に出てくるエフェクトです。customは自分でこのエフェクトを作成するときに使います。
http://d.hatena.ne.jp/Kesin/20120908/1347079921

Swift UI チュートリアル Loading watchOS が終わらない?

Loading watchOS が終わらない? ディスク容量の残量が少ないので不要なシュミレーターを削除したとこころ watchOSのものが全部なくなってしまっていた。 WatchOS を削除して再度インストールしても復活せず。 Create a new simulator で ...