レベルエンター山本大のブログ

面白いプログラミング教育を若い人たちに

BLOCKVROCKリファレンス目次はこちら

NodeからRDSの接続で SSL/TLSの証明書を rds-ca-2019に更新する

RDS のCA証明書が2019になるとアナウンスがあって、最終警告っぽいメールがきてたので慌てて対応。

 

そのメールのタイトルはこちら。

重要なお知らせ:2020年2月5日までにお客様のAmazon RDS SSL/TLS証明書の更新を行ってください | Important Reminder: Update Your Amazon RDS SSL/TLS Certificates by February 5, 2020

 

 

ドキュメントを見て、証明書をダウンロードして、

https://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/UsingWithRDS.SSL.html

 

クライアントからテストしてみたらここまではスムーズに通る

mysql -h myinstance.c9akciq32.rds-us-east-1.amazonaws.com
--ssl-ca=[full path]rds-combined-ca-bundle.pem --ssl-mode=REQUIRED

 

しかし nodejsのプロジェクトからmysql2を利用したDBアクセスが疎通しない。

 なんとか動かしてみられたので、原因を記録

 

原因1:中間証明書を含むpemをつかっていない

原因2:Node v12以降は、TLSv1.0が使えない

 

対処1:中間証明書とRoot証明書を含むpemを使う

https://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/UsingWithRDS.SSL.html

 

対処2:(暫定対処)

Node v11を使う

(最新が使いたいので、Connection のオプションに以下などとしてみたが疎通しない。)

暫定対処で、v11を使うことにした。 

nを使ってNodeのバージョンを切り替えられるようにする

// インストール

npm i -g n

// リストアップ

sudo n list 

// バージョンのインストールと利用(11.x.xが入って有効になる)

sudo  n v11 

// バージョン確認

node -v

 

 

恒久対処に向けて覚書

Nodeのバージョンをあげたい。TLSv1.3を使ってセキュアにDBアクセスしたい。

mysql2のConnection生成時に以下を書いてみたが、Node11なら通る。Node13なら通らない。

,ssl : {
ca: fs.readFileSync( [Caのパス] )
,rejectUnauthorized: false
,maxVersion: 'TLSv1.3'
,minVersion: 'TLSv1.3'
}

 

 

 

物体の位置

物体の位置は、3つの軸で決定します(X軸、Y軸、Z軸)

Xは左右(プラスになるほど 右)

Yは上下(プラスになるほど 上)

Zは奥行き(プラスになるほど 手前)

を表します。

 

以下のサンプルプログラムでは

赤い物体を左右に

青い物体を上下に

黄色い物体は、奥と手前(カメラ初期位置から見ると後ろ)

に配置しています。

 

f:id:iad_otomamay:20191211135258p:plain

物体の位置

 

 

 

[公式]物体の位置

物体を受け止める土台を作る

動きのあるブロックは、重力を受けるようになるのでそのままでは落下していきます。

「静止した物体」属性をつけたブロックは、動きのある物体に対して衝突判定があります。

静止した物体の大きさのXとZ方向を広くすれば、重力のある物体を受け止める土台として機能します。

 

以下のプログラムでは青色のブロックが土台となります。

f:id:iad_otomamay:20191203191025p:plain

ブロックを受け止める

 

[公式]ブロックを受け止める

物理エンジンで物体に重さをつける

BLOCKVROCKでは、物理法則をコンピュータで計算再現して、物体に重さや衝突の判定を設定することができます。 ブロックに「動きのある物体」の属性を繋げましょう。

Y座標を少し上にセットしておくと分かりやすいです。

 

f:id:iad_otomamay:20191202180155p:plain

物理エンジンで重力をつける

 実行すると物体が、上からしたに落ちていく様子がみられます。

重力を発生させたのですが、これだけではあっという間に落ちてしまいます。

 

 

[公式]物理エンジンで重力をつける

物体の回転(Z軸)

Z軸は奥行きを表しますので、物体の中心を手前から奥に向かって通る軸を中心に回転します。

Z軸による回転は、カメラの目線が回転軸と平行になるため、時計回りであることがわかりやすいですね。

 

f:id:iad_otomamay:20191129170435p:plain

物体の回転(Z軸)

 

[公式]z軸60,90,135回転

物体の回転(Y軸)

Y軸での回転は、物体の中心に縦の軸を通してそれを中心に回転するということです。

やはり+になるほど時計回りに回転し、マイナスになるほど反時計回りに回ります。

 

今回は、マイナスの回転もやってみます。

f:id:iad_otomamay:20191129164956p:plain

y軸90,45,-45回転

[公式]y軸90,45,-45回転

物体の回転(X軸)

物体を回転させる回転属性については、初期段階で最も混乱するポイントのようです。

軸を中心にして+であれば時計回りに回転するというルールさえ理解できれば、あとはトライアンドエラーで作りたい角度を確認しながら進めていくのが良いです。

 

このサンプルでは、X軸で30度、45度、60度に回転させています。

半角英数字ブロックで、目印となるラベルを書いています

 

f:id:iad_otomamay:20191129163942p:plain

x軸で30度45度60度回転

 

[公式]x軸30,45,60回転